UNPKG

@tensorflow/tfjs-core

Version:

Hardware-accelerated JavaScript library for machine intelligence

97 lines (91 loc) 3.69 kB
/** * @license * Copyright 2020 Google Inc. All Rights Reserved. * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * ============================================================================= */ import {Tensor1D, Tensor2D} from '../tensor'; import {convertToTensor} from '../tensor_util_env'; import {TensorLike} from '../types'; import * as util from '../util'; import {batchNorm} from './batchnorm'; import {warnDeprecation} from './batchnorm_util'; import {op} from './operation'; /** * Batch normalization, strictly for 2D. For the more relaxed version, see * `tf.batchNorm`. * * @param x The input Tensor. * @param mean A mean Tensor. * @param variance A variance Tensor. * @param offset An offset Tensor. * @param scale A scale Tensor. * @param varianceEpsilon A small float number to avoid dividing by 0. */ function batchNorm2d_( x: Tensor2D|TensorLike, mean: Tensor2D|Tensor1D|TensorLike, variance: Tensor2D|Tensor1D|TensorLike, offset?: Tensor2D|Tensor1D|TensorLike, scale?: Tensor2D|Tensor1D|TensorLike, varianceEpsilon?: number): Tensor2D { const $x = convertToTensor(x, 'x', 'batchNorm'); const $mean = convertToTensor(mean, 'mean', 'batchNorm'); const $variance = convertToTensor(variance, 'variance', 'batchNorm'); let $scale: Tensor2D|Tensor1D; if (scale != null) { $scale = convertToTensor(scale, 'scale', 'batchNorm'); } let $offset: Tensor2D|Tensor1D; if (offset != null) { $offset = convertToTensor(offset, 'offset', 'batchNorm'); } util.assert( $x.rank === 2, () => `Error in batchNorm3D: x must be rank 3 but got rank ` + `${$x.rank}.`); util.assert( $mean.rank === 2 || $mean.rank === 1, () => `Error in batchNorm2D: mean must be rank 2 or rank 1 but ` + `got rank ${$mean.rank}.`); util.assert( $variance.rank === 2 || $variance.rank === 1, () => `Error in batchNorm2D: variance must be rank 2 or rank 1 ` + `but got rank ${$variance.rank}.`); if ($scale != null) { util.assert( $scale.rank === 2 || $scale.rank === 1, () => `Error in batchNorm2D: scale must be rank 2 or rank 1 ` + `but got rank ${$scale.rank}.`); } if ($offset != null) { util.assert( $offset.rank === 2 || $offset.rank === 1, () => `Error in batchNorm2D: offset must be rank 2 or rank 1 ` + `but got rank ${$offset.rank}.`); } return batchNorm($x, $mean, $variance, $offset, $scale, varianceEpsilon); } /** * @deprecated Please use `tf.batchNorm2d` instead and note the positional * argument change of scale, offset, and varianceEpsilon. */ function batchNormalization2d_( x: Tensor2D|TensorLike, mean: Tensor2D|Tensor1D|TensorLike, variance: Tensor2D|Tensor1D|TensorLike, varianceEpsilon = .001, scale?: Tensor2D|Tensor1D|TensorLike, offset?: Tensor2D|Tensor1D|TensorLike): Tensor2D { warnDeprecation(); return batchNorm2d_(x, mean, variance, offset, scale, varianceEpsilon); } // todo(yassogba): Remove batchNormalization2d since it is deprecated. export const batchNormalization2d = op({batchNormalization2d_}); export const batchNorm2d = op({batchNorm2d_});