UNPKG

@tensorflow/tfjs-layers

Version:

TensorFlow layers API in JavaScript

196 lines 18.3 kB
/** * @license * Copyright 2018 Google LLC * * Use of this source code is governed by an MIT-style * license that can be found in the LICENSE file or at * https://opensource.org/licenses/MIT. * ============================================================================= */ // tslint:disable-next-line:max-line-length import { Constant, GlorotNormal, GlorotUniform, HeNormal, HeUniform, Identity, LeCunNormal, LeCunUniform, Ones, Orthogonal, RandomNormal, RandomUniform, TruncatedNormal, VarianceScaling, Zeros } from './initializers'; /** * Initializer that generates tensors initialized to 0. * * @doc {heading: 'Initializers', namespace: 'initializers'} */ export function zeros() { return new Zeros(); } /** * Initializer that generates tensors initialized to 1. * * @doc {heading: 'Initializers', namespace: 'initializers'} */ export function ones() { return new Ones(); } /** * Initializer that generates values initialized to some constant. * * @doc {heading: 'Initializers', namespace: 'initializers'} */ export function constant(args) { return new Constant(args); } /** * Initializer that generates random values initialized to a uniform * distribution. * * Values will be distributed uniformly between the configured minval and * maxval. * * @doc {heading: 'Initializers', namespace: 'initializers'} */ export function randomUniform(args) { return new RandomUniform(args); } /** * Initializer that generates random values initialized to a normal * distribution. * * @doc {heading: 'Initializers', namespace: 'initializers'} */ export function randomNormal(args) { return new RandomNormal(args); } /** * Initializer that generates random values initialized to a truncated normal * distribution. * * These values are similar to values from a `RandomNormal` except that values * more than two standard deviations from the mean are discarded and re-drawn. * This is the recommended initializer for neural network weights and filters. * * @doc {heading: 'Initializers', namespace: 'initializers'} */ export function truncatedNormal(args) { return new TruncatedNormal(args); } /** * Initializer that generates the identity matrix. * Only use for square 2D matrices. * * @doc {heading: 'Initializers', namespace: 'initializers'} */ export function identity(args) { return new Identity(args); } /** * Initializer capable of adapting its scale to the shape of weights. * With distribution=NORMAL, samples are drawn from a truncated normal * distribution centered on zero, with `stddev = sqrt(scale / n)` where n is: * - number of input units in the weight tensor, if mode = FAN_IN. * - number of output units, if mode = FAN_OUT. * - average of the numbers of input and output units, if mode = FAN_AVG. * With distribution=UNIFORM, * samples are drawn from a uniform distribution * within [-limit, limit], with `limit = sqrt(3 * scale / n)`. * * @doc {heading: 'Initializers',namespace: 'initializers'} */ export function varianceScaling(config) { return new VarianceScaling(config); } /** * Glorot uniform initializer, also called Xavier uniform initializer. * It draws samples from a uniform distribution within [-limit, limit] * where `limit` is `sqrt(6 / (fan_in + fan_out))` * where `fan_in` is the number of input units in the weight tensor * and `fan_out` is the number of output units in the weight tensor * * Reference: * Glorot & Bengio, AISTATS 2010 * http://jmlr.org/proceedings/papers/v9/glorot10a/glorot10a.pdf. * * @doc {heading: 'Initializers', namespace: 'initializers'} */ export function glorotUniform(args) { return new GlorotUniform(args); } /** * Glorot normal initializer, also called Xavier normal initializer. * It draws samples from a truncated normal distribution centered on 0 * with `stddev = sqrt(2 / (fan_in + fan_out))` * where `fan_in` is the number of input units in the weight tensor * and `fan_out` is the number of output units in the weight tensor. * * Reference: * Glorot & Bengio, AISTATS 2010 * http://jmlr.org/proceedings/papers/v9/glorot10a/glorot10a.pdf * * @doc {heading: 'Initializers', namespace: 'initializers'} */ export function glorotNormal(args) { return new GlorotNormal(args); } /** * He normal initializer. * * It draws samples from a truncated normal distribution centered on 0 * with `stddev = sqrt(2 / fanIn)` * where `fanIn` is the number of input units in the weight tensor. * * Reference: * He et al., http://arxiv.org/abs/1502.01852 * * @doc {heading: 'Initializers', namespace: 'initializers'} */ export function heNormal(args) { return new HeNormal(args); } /** * He uniform initializer. * * It draws samples from a uniform distribution within [-limit, limit] * where `limit` is `sqrt(6 / fan_in)` * where `fanIn` is the number of input units in the weight tensor. * * Reference: * He et al., http://arxiv.org/abs/1502.01852 * * @doc {heading: 'Initializers',namespace: 'initializers'} */ export function heUniform(args) { return new HeUniform(args); } /** * LeCun normal initializer. * * It draws samples from a truncated normal distribution centered on 0 * with `stddev = sqrt(1 / fanIn)` * where `fanIn` is the number of input units in the weight tensor. * * References: * [Self-Normalizing Neural Networks](https://arxiv.org/abs/1706.02515) * [Efficient Backprop](http://yann.lecun.com/exdb/publis/pdf/lecun-98b.pdf) * * @doc {heading: 'Initializers', namespace: 'initializers'} */ export function leCunNormal(args) { return new LeCunNormal(args); } /** * LeCun uniform initializer. * * It draws samples from a uniform distribution in the interval * `[-limit, limit]` with `limit = sqrt(3 / fanIn)`, * where `fanIn` is the number of input units in the weight tensor. * * @doc {heading: 'Initializers', namespace: 'initializers'} */ export function leCunUniform(args) { return new LeCunUniform(args); } /** * Initializer that generates a random orthogonal matrix. * * Reference: * [Saxe et al., http://arxiv.org/abs/1312.6120](http://arxiv.org/abs/1312.6120) * * @doc {heading: 'Initializers', namespace: 'initializers'} */ export function orthogonal(args) { return new Orthogonal(args); } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"exports_initializers.js","sourceRoot":"","sources":["../../../../../tfjs-layers/src/exports_initializers.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AACH,2CAA2C;AAC3C,OAAO,EAAC,QAAQ,EAAgB,YAAY,EAAE,aAAa,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,EAA6B,WAAW,EAAE,YAAY,EAAE,IAAI,EAAE,UAAU,EAAkB,YAAY,EAAoB,aAAa,EAA8C,eAAe,EAAuB,eAAe,EAAuB,KAAK,EAAC,MAAM,gBAAgB,CAAC;AAExX;;;;GAIG;AACH,MAAM,UAAU,KAAK;IACnB,OAAO,IAAI,KAAK,EAAE,CAAC;AACrB,CAAC;AAED;;;;GAIG;AACH,MAAM,UAAU,IAAI;IAClB,OAAO,IAAI,IAAI,EAAE,CAAC;AACpB,CAAC;AAED;;;;GAIG;AACH,MAAM,UAAU,QAAQ,CAAC,IAAkB;IACzC,OAAO,IAAI,QAAQ,CAAC,IAAI,CAAC,CAAC;AAC5B,CAAC;AAED;;;;;;;;GAQG;AACH,MAAM,UAAU,aAAa,CAAC,IAAuB;IACnD,OAAO,IAAI,aAAa,CAAC,IAAI,CAAC,CAAC;AACjC,CAAC;AAED;;;;;GAKG;AACH,MAAM,UAAU,YAAY,CAAC,IAAsB;IACjD,OAAO,IAAI,YAAY,CAAC,IAAI,CAAC,CAAC;AAChC,CAAC;AAED;;;;;;;;;GASG;AACH,MAAM,UAAU,eAAe,CAAC,IAAyB;IACvD,OAAO,IAAI,eAAe,CAAC,IAAI,CAAC,CAAC;AACnC,CAAC;AAED;;;;;GAKG;AACH,MAAM,UAAU,QAAQ,CAAC,IAAkB;IACzC,OAAO,IAAI,QAAQ,CAAC,IAAI,CAAC,CAAC;AAC5B,CAAC;AAED;;;;;;;;;;;;GAYG;AACH,MAAM,UAAU,eAAe,CAAC,MAA2B;IACzD,OAAO,IAAI,eAAe,CAAC,MAAM,CAAC,CAAC;AACrC,CAAC;AAED;;;;;;;;;;;;GAYG;AACH,MAAM,UAAU,aAAa,CAAC,IAA6B;IACzD,OAAO,IAAI,aAAa,CAAC,IAAI,CAAC,CAAC;AACjC,CAAC;AAED;;;;;;;;;;;;GAYG;AACH,MAAM,UAAU,YAAY,CAAC,IAA6B;IACxD,OAAO,IAAI,YAAY,CAAC,IAAI,CAAC,CAAC;AAChC,CAAC;AAED;;;;;;;;;;;GAWG;AACH,MAAM,UAAU,QAAQ,CAAC,IAA6B;IACpD,OAAO,IAAI,QAAQ,CAAC,IAAI,CAAC,CAAC;AAC5B,CAAC;AAED;;;;;;;;;;;GAWG;AACH,MAAM,UAAU,SAAS,CAAC,IAA6B;IACrD,OAAO,IAAI,SAAS,CAAC,IAAI,CAAC,CAAC;AAC7B,CAAC;AAED;;;;;;;;;;;;GAYG;AACH,MAAM,UAAU,WAAW,CAAC,IAA6B;IACvD,OAAO,IAAI,WAAW,CAAC,IAAI,CAAC,CAAC;AAC/B,CAAC;AAED;;;;;;;;GAQG;AACH,MAAM,UAAU,YAAY,CAAC,IAA6B;IACxD,OAAO,IAAI,YAAY,CAAC,IAAI,CAAC,CAAC;AAChC,CAAC;AAED;;;;;;;GAOG;AACH,MAAM,UAAU,UAAU,CAAC,IAAoB;IAC7C,OAAO,IAAI,UAAU,CAAC,IAAI,CAAC,CAAC;AAC9B,CAAC","sourcesContent":["/**\n * @license\n * Copyright 2018 Google LLC\n *\n * Use of this source code is governed by an MIT-style\n * license that can be found in the LICENSE file or at\n * https://opensource.org/licenses/MIT.\n * =============================================================================\n */\n// tslint:disable-next-line:max-line-length\nimport {Constant, ConstantArgs, GlorotNormal, GlorotUniform, HeNormal, HeUniform, Identity, IdentityArgs, Initializer, LeCunNormal, LeCunUniform, Ones, Orthogonal, OrthogonalArgs, RandomNormal, RandomNormalArgs, RandomUniform, RandomUniformArgs, SeedOnlyInitializerArgs, TruncatedNormal, TruncatedNormalArgs, VarianceScaling, VarianceScalingArgs, Zeros} from './initializers';\n\n/**\n * Initializer that generates tensors initialized to 0.\n *\n * @doc {heading: 'Initializers', namespace: 'initializers'}\n */\nexport function zeros(): Zeros {\n  return new Zeros();\n}\n\n/**\n * Initializer that generates tensors initialized to 1.\n *\n * @doc {heading: 'Initializers', namespace: 'initializers'}\n */\nexport function ones(): Initializer {\n  return new Ones();\n}\n\n/**\n * Initializer that generates values initialized to some constant.\n *\n * @doc {heading: 'Initializers', namespace: 'initializers'}\n */\nexport function constant(args: ConstantArgs): Initializer {\n  return new Constant(args);\n}\n\n/**\n * Initializer that generates random values initialized to a uniform\n * distribution.\n *\n * Values will be distributed uniformly between the configured minval and\n * maxval.\n *\n * @doc {heading: 'Initializers', namespace: 'initializers'}\n */\nexport function randomUniform(args: RandomUniformArgs): Initializer {\n  return new RandomUniform(args);\n}\n\n/**\n * Initializer that generates random values initialized to a normal\n * distribution.\n *\n * @doc {heading: 'Initializers', namespace: 'initializers'}\n */\nexport function randomNormal(args: RandomNormalArgs): Initializer {\n  return new RandomNormal(args);\n}\n\n/**\n * Initializer that generates random values initialized to a truncated normal\n * distribution.\n *\n * These values are similar to values from a `RandomNormal` except that values\n * more than two standard deviations from the mean are discarded and re-drawn.\n * This is the recommended initializer for neural network weights and filters.\n *\n * @doc {heading: 'Initializers', namespace: 'initializers'}\n */\nexport function truncatedNormal(args: TruncatedNormalArgs): Initializer {\n  return new TruncatedNormal(args);\n}\n\n/**\n * Initializer that generates the identity matrix.\n * Only use for square 2D matrices.\n *\n * @doc {heading: 'Initializers', namespace: 'initializers'}\n */\nexport function identity(args: IdentityArgs): Initializer {\n  return new Identity(args);\n}\n\n/**\n * Initializer capable of adapting its scale to the shape of weights.\n * With distribution=NORMAL, samples are drawn from a truncated normal\n * distribution centered on zero, with `stddev = sqrt(scale / n)` where n is:\n *   - number of input units in the weight tensor, if mode = FAN_IN.\n *   - number of output units, if mode = FAN_OUT.\n *   - average of the numbers of input and output units, if mode = FAN_AVG.\n * With distribution=UNIFORM,\n * samples are drawn from a uniform distribution\n * within [-limit, limit], with `limit = sqrt(3 * scale / n)`.\n *\n * @doc {heading: 'Initializers',namespace: 'initializers'}\n */\nexport function varianceScaling(config: VarianceScalingArgs): Initializer {\n  return new VarianceScaling(config);\n}\n\n/**\n * Glorot uniform initializer, also called Xavier uniform initializer.\n * It draws samples from a uniform distribution within [-limit, limit]\n * where `limit` is `sqrt(6 / (fan_in + fan_out))`\n * where `fan_in` is the number of input units in the weight tensor\n * and `fan_out` is the number of output units in the weight tensor\n *\n * Reference:\n *   Glorot & Bengio, AISTATS 2010\n *       http://jmlr.org/proceedings/papers/v9/glorot10a/glorot10a.pdf.\n *\n * @doc {heading: 'Initializers', namespace: 'initializers'}\n */\nexport function glorotUniform(args: SeedOnlyInitializerArgs): Initializer {\n  return new GlorotUniform(args);\n}\n\n/**\n * Glorot normal initializer, also called Xavier normal initializer.\n * It draws samples from a truncated normal distribution centered on 0\n * with `stddev = sqrt(2 / (fan_in + fan_out))`\n * where `fan_in` is the number of input units in the weight tensor\n * and `fan_out` is the number of output units in the weight tensor.\n *\n * Reference:\n *   Glorot & Bengio, AISTATS 2010\n *       http://jmlr.org/proceedings/papers/v9/glorot10a/glorot10a.pdf\n *\n * @doc {heading: 'Initializers', namespace: 'initializers'}\n */\nexport function glorotNormal(args: SeedOnlyInitializerArgs): Initializer {\n  return new GlorotNormal(args);\n}\n\n/**\n * He normal initializer.\n *\n * It draws samples from a truncated normal distribution centered on 0\n * with `stddev = sqrt(2 / fanIn)`\n * where `fanIn` is the number of input units in the weight tensor.\n *\n * Reference:\n *     He et al., http://arxiv.org/abs/1502.01852\n *\n * @doc {heading: 'Initializers', namespace: 'initializers'}\n */\nexport function heNormal(args: SeedOnlyInitializerArgs): Initializer {\n  return new HeNormal(args);\n}\n\n/**\n * He uniform initializer.\n *\n * It draws samples from a uniform distribution within [-limit, limit]\n * where `limit` is `sqrt(6 / fan_in)`\n * where `fanIn` is the number of input units in the weight tensor.\n *\n * Reference:\n *     He et al., http://arxiv.org/abs/1502.01852\n *\n * @doc {heading: 'Initializers',namespace: 'initializers'}\n */\nexport function heUniform(args: SeedOnlyInitializerArgs): Initializer {\n  return new HeUniform(args);\n}\n\n/**\n * LeCun normal initializer.\n *\n * It draws samples from a truncated normal distribution centered on 0\n * with `stddev = sqrt(1 / fanIn)`\n * where `fanIn` is the number of input units in the weight tensor.\n *\n * References:\n *   [Self-Normalizing Neural Networks](https://arxiv.org/abs/1706.02515)\n *   [Efficient Backprop](http://yann.lecun.com/exdb/publis/pdf/lecun-98b.pdf)\n *\n * @doc {heading: 'Initializers', namespace: 'initializers'}\n */\nexport function leCunNormal(args: SeedOnlyInitializerArgs): Initializer {\n  return new LeCunNormal(args);\n}\n\n/**\n * LeCun uniform initializer.\n *\n * It draws samples from a uniform distribution in the interval\n * `[-limit, limit]` with `limit = sqrt(3 / fanIn)`,\n * where `fanIn` is the number of input units in the weight tensor.\n *\n * @doc {heading: 'Initializers', namespace: 'initializers'}\n */\nexport function leCunUniform(args: SeedOnlyInitializerArgs): Initializer {\n  return new LeCunUniform(args);\n}\n\n/**\n * Initializer that generates a random orthogonal matrix.\n *\n * Reference:\n * [Saxe et al., http://arxiv.org/abs/1312.6120](http://arxiv.org/abs/1312.6120)\n *\n * @doc {heading: 'Initializers', namespace: 'initializers'}\n */\nexport function orthogonal(args: OrthogonalArgs): Initializer {\n  return new Orthogonal(args);\n}\n"]}