@tensorflow/tfjs-core
Version:
Hardware-accelerated JavaScript library for machine intelligence
299 lines (298 loc) • 15.4 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", { value: true });
var tf = require("../index");
var test_util_1 = require("../test_util");
var jasmine_util_1 = require("../jasmine_util");
jasmine_util_1.describeWithFlags('maxPool', test_util_1.ALL_ENVS, function () {
it('x=[1,1,1] f=[1,1] s=1 [0] => [0]', function () {
var x = tf.tensor3d([0], [1, 1, 1]);
var result = tf.maxPool(x, 1, 1, 0);
test_util_1.expectArraysClose(result, [0]);
});
it('x=[3,3,1] f=[2,2] s=1', function () {
var x = tf.tensor3d([1, 2, 3, 4, 5, 6, 7, 9, 8], [3, 3, 1]);
var result = tf.maxPool(x, 2, 1, 0);
expect(result.shape).toEqual([2, 2, 1]);
test_util_1.expectArraysClose(result, [5, 6, 9, 9]);
});
it('x=[2,3,3,1] f=[2,2] s=1', function () {
var x = tf.tensor4d([1, 2, 3, 4, 5, 6, 7, 9, 8, 1, 2, 3, 4, 5, 6, 7, 8, 9], [2, 3, 3, 1]);
var result = tf.maxPool(x, 2, 1, 0);
expect(result.shape).toEqual([2, 2, 2, 1]);
test_util_1.expectArraysClose(result, [5, 6, 9, 9, 5, 6, 8, 9]);
});
it('[x=[3,3,1] f=[2,2] s=1 ignores NaNs', function () {
var x = tf.tensor3d([1, 2, 3, 4, 5, 6, 7, NaN, 9], [3, 3, 1]);
var result = tf.maxPool(x, 2, 1, 0);
expect(result.shape).toEqual([2, 2, 1]);
test_util_1.expectArraysClose(result, [5, 6, 7, 9]);
});
it('x=[3,3,2] f=[2,2] s=1', function () {
var x = tf.tensor3d([1, 99, 2, 88, 3, 77, 4, 66, 5, 55, 6, 44, 7, 33, 9, 22, 8, 11], [3, 3, 2]);
var result = tf.maxPool(x, 2, 1, 0);
expect(result.shape).toEqual([2, 2, 2]);
test_util_1.expectArraysClose(result, [5, 99, 6, 88, 9, 66, 9, 55]);
});
it('x=[4,4,1] f=[2,2] s=2', function () {
var x = tf.tensor3d([0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15], [4, 4, 1]);
var result = tf.maxPool(x, 2, 2, 0);
expect(result.shape).toEqual([2, 2, 1]);
test_util_1.expectArraysClose(result, [5, 7, 13, 15]);
});
it('x=[2,2,1] f=[2,2] s=1 p=same', function () {
var x = tf.tensor3d([1, 2, 3, 4], [2, 2, 1]);
var fSize = 2;
var strides = 1;
var result = tf.maxPool(x, fSize, strides, 'same');
expect(result.shape).toEqual([2, 2, 1]);
test_util_1.expectArraysClose(result, [4, 4, 4, 4]);
});
it('throws when x is not rank 3', function () {
var x = tf.tensor2d([1, 2, 3, 4, 5, 6, 7, 8, 9], [3, 3]);
expect(function () { return tf.maxPool(x, 2, 1, 0); }).toThrowError();
});
it('throws when dimRoundingMode is set and pad is not a number', function () {
var x = tf.tensor3d([1, 2, 3, 4], [2, 2, 1]);
var pad = 'valid';
var dimRoundingMode = 'round';
expect(function () { return tf.maxPool(x, 2, 1, pad, dimRoundingMode); }).toThrowError();
});
it('throws when passed a non-tensor', function () {
expect(function () { return tf.maxPool({}, 2, 1, 'valid'); })
.toThrowError(/Argument 'x' passed to 'maxPool' must be a Tensor/);
});
});
jasmine_util_1.describeWithFlags('maxPoolBackprop', test_util_1.ALL_ENVS, function () {
it('gradients x=[3,3,1] f=[2,2] s=1 no dup max value, test #1', function () {
var dy = tf.tensor3d([1, 2, 3, 4], [2, 2, 1]);
var x = tf.tensor3d([1, 2, 3, 4, 5, 6, 7, 8, 9], [3, 3, 1]);
var expected = [0, 0, 0, 0, 1, 2, 0, 3, 4];
var dx = tf.grad(function (x) { return x.maxPool(2, 1, 0); })(x, dy);
expect(dx.shape).toEqual(x.shape);
test_util_1.expectArraysClose(dx, expected);
});
it('gradients x=[3,3,1] f=[2,2] s=1 no dup max value, test #2', function () {
var dy = tf.tensor3d([1, 2, 3, 4], [2, 2, 1]);
var x = tf.tensor3d([9, 5, 6, 6, 8, 4, 9, 5, 10], [3, 3, 1]);
var expected = [1, 0, 0, 0, 2, 0, 3, 0, 4];
var dx = tf.grad(function (x) { return x.maxPool(2, 1, 0); })(x, dy);
expect(dx.shape).toEqual(x.shape);
test_util_1.expectArraysClose(dx, expected);
});
it('gradients x=[2,3,3,1] f=[2,2] s=1 no duplicate max value', function () {
var dy = tf.tensor4d([1, 2, 3, 4, 1, 2, 3, 4], [2, 2, 2, 1]);
var x = tf.tensor4d([1, 2, 3, 4, 5, 6, 7, 8, 9, 9, 5, 6, 6, 8, 4, 9, 5, 10], [2, 3, 3, 1]);
var expected = [0, 0, 0, 0, 1, 2, 0, 3, 4, 1, 0, 0, 0, 2, 0, 3, 0, 4];
var dx = tf.grad(function (x) { return x.maxPool(2, 1, 0); })(x, dy);
expect(dx.shape).toEqual(x.shape);
test_util_1.expectArraysClose(dx, expected);
});
it('gradient x=[3,3,1] f=[2,2] s=1 dup max value, test 1', function () {
var dy = tf.tensor3d([1, 2, 3, 4], [2, 2, 1]);
var x = tf.tensor3d([0, 0, 0, 0, 5, 0, 0, 0, 0], [3, 3, 1]);
var expected = [0, 0, 0, 0, 10, 0, 0, 0, 0];
var dx = tf.grad(function (x) { return x.maxPool(2, 1, 0); })(x, dy);
expect(dx.shape).toEqual(x.shape);
test_util_1.expectArraysClose(dx, expected);
});
it('gradient x=[3,3,1] f=[2,2] s=1 dup max value, test 2', function () {
var dy = tf.tensor3d([1, 2, 3, 4], [2, 2, 1]);
var x = tf.tensor3d([1, 3, 2, 1, 2, 1, 1, 1, 5], [3, 3, 1]);
var expected = [0, 3, 0, 0, 3, 0, 0, 0, 4];
var dx = tf.grad(function (x) { return x.maxPool(2, 1, 0); })(x, dy);
expect(dx.shape).toEqual(x.shape);
test_util_1.expectArraysClose(dx, expected);
});
it('gradient x=[2,3,3,1] f=[2,2] s=1 dup max value in 2nd input', function () {
var dy = tf.tensor4d([1, 2, 3, 4, 5, 6, 7, 8], [2, 2, 2, 1]);
var x = tf.tensor4d([1, 2, 3, 4, 5, 6, 7, 8, 9, 1, 2, 3, 4, 5, 6, 7, 9, 8], [2, 3, 3, 1]);
var expected = new Float32Array([0, 0, 0, 0, 1, 2, 0, 3, 4, 0, 0, 0, 0, 5, 6, 0, 15, 0]);
var dx = tf.grad(function (x) { return x.maxPool(2, 1, 0); })(x, dy);
expect(dx.shape).toEqual(x.shape);
test_util_1.expectArraysClose(dx, expected);
});
it('gradient x=[4,4,1] f=[2,2] s=2 test #1', function () {
var dy = tf.tensor3d([1, 2, 3, 4], [2, 2, 1]);
var x = tf.tensor3d([0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15], [4, 4, 1]);
var expected = [0, 0, 0, 0, 0, 1, 0, 2, 0, 0, 0, 0, 0, 3, 0, 4];
var dx = tf.grad(function (x) { return x.maxPool(2, 2, 0); })(x, dy);
expect(dx.shape).toEqual(x.shape);
test_util_1.expectArraysClose(dx, expected);
});
it('gradient x=[4,4,1] f=[2,2] s=2 test #2', function () {
var dy = tf.tensor3d([1, 2, 3, 4], [2, 2, 1]);
var x = tf.tensor3d([1, 2, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 2, 2, 1], [4, 4, 1]);
var expected = [0, 1, 2, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 4, 0];
var dx = tf.grad(function (x) { return x.maxPool(2, 2, 0); })(x, dy);
expect(dx.shape).toEqual(x.shape);
test_util_1.expectArraysClose(dx, expected);
});
it('gradient x=[5,5,1] f=[3,3] s=2 no duplicate max value', function () {
var dy = tf.tensor3d([1, 2, 3, 4], [2, 2, 1]);
var x = tf.tensor3d([
0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12,
13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24
], [5, 5, 1]);
var expected = [
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1,
0, 2, 0, 0, 0, 0, 0, 0, 0, 3, 0, 4
];
var dx = tf.grad(function (x) { return x.maxPool(3, 2, 0); })(x, dy);
expect(dx.shape).toEqual(x.shape);
test_util_1.expectArraysClose(dx, expected);
});
it('gradient x=[5,5,1] f=[3,3] s=2 duplicate max value', function () {
var dy = tf.tensor3d([1, 2, 3, 4], [2, 2, 1]);
var x = tf.tensor3d([
0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 24,
13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 12
], [5, 5, 1]);
var expected = [
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 10,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0
];
var dx = tf.grad(function (x) { return x.maxPool(3, 2, 0); })(x, dy);
expect(dx.shape).toEqual(x.shape);
test_util_1.expectArraysClose(dx, expected);
});
it('gradient x=[3,3,2] f=[2,2] s=1, no duplicate max value', function () {
var dy = tf.tensor3d([1, 44, 2, 33, 3, 22, 4, 11], [2, 2, 2]);
var x = tf.tensor3d([1, 99, 2, 55, 3, 66, 4, 66, 5, 88, 6, 44, 7, 99, 8, 55, 9, 100], [3, 3, 2]);
var expected = [0, 44, 0, 0, 0, 0, 0, 0, 1, 33, 2, 0, 0, 22, 3, 0, 4, 11];
var dx = tf.grad(function (x) { return x.maxPool(2, 1, 0); })(x, dy);
expect(dx.shape).toEqual(x.shape);
test_util_1.expectArraysClose(dx, expected);
});
it('gradient x=[3,3,2] f=[2,2] s=1 duplicate max value', function () {
var dy = tf.tensor3d([1, 44, 2, 33, 3, 22, 4, 11], [2, 2, 2]);
var x = tf.tensor3d([0, 1, 0, 3, 0, 2, 0, 1, 5, 2, 0, 1, 0, 1, 0, 1, 0, 5], [3, 3, 2]);
var expected = new Float32Array([0, 0, 0, 77, 0, 0, 0, 0, 10, 22, 0, 0, 0, 0, 0, 0, 0, 11]);
var dx = tf.grad(function (x) { return x.maxPool(2, 1, 0); })(x, dy);
expect(dx.shape).toEqual(x.shape);
test_util_1.expectArraysClose(dx, expected);
});
it('gradient x=[4,4,2] f=[2,2] s=1', function () {
var dy = tf.tensor3d([1, 11, 2, 22, 3, 33, 4, 44], [2, 2, 2]);
var x = tf.tensor3d([
0, 1, 1, 2, 2, 2, 3, 1, 4, 1, 5, 1, 6, 1, 7, 1,
8, 1, 9, 1, 10, 1, 11, 1, 12, 1, 13, 2, 14, 2, 15, 1
], [4, 4, 2]);
var expected = [
0, 0, 0, 11, 0, 22, 0, 0, 0, 0, 1, 0, 0, 0, 2, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 33, 0, 44, 4, 0
];
var dx = tf.grad(function (x) { return x.maxPool(2, 2, 0); })(x, dy);
expect(dx.shape).toEqual(x.shape);
test_util_1.expectArraysClose(dx, expected);
});
it('gradient x=5x5x2, f=3, s=2 no duplicate max value', function () {
var dy = tf.tensor3d([1, 11, 2, 22, 3, 33, 4, 44], [2, 2, 2]);
var x = tf.tensor3d([
0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8,
8, 9, 9, 10, 10, 11, 11, 12, 24, 13, 13, 14, 14, 15, 15, 16, 16,
17, 17, 18, 18, 19, 19, 20, 20, 21, 21, 22, 22, 23, 23, 24, 12
], [5, 5, 2]);
var expected = [
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 1, 110, 0, 0, 2, 0, 0, 0, 0, 0,
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 3, 0, 0, 0, 4, 0
];
var dx = tf.grad(function (x) { return x.maxPool(3, 2, 0); })(x, dy);
expect(dx.shape).toEqual(x.shape);
test_util_1.expectArraysClose(dx, expected);
});
});
jasmine_util_1.describeWithFlags('avgPool', test_util_1.ALL_ENVS, function () {
it('x=[1,1,1] f=[1,1] s=1 [0] => [0]', function () {
var a = tf.tensor3d([0], [1, 1, 1]);
var result = tf.avgPool(a, 1, 1, 0);
test_util_1.expectArraysClose(result, [0]);
});
it('x=[3,3,1] f=[2,2] s=1', function () {
var a = tf.tensor3d([1, 2, 3, 4, 5, 6, 7, 9, 8], [3, 3, 1]);
var result = tf.avgPool(a, 2, 1, 0);
expect(result.shape).toEqual([2, 2, 1]);
expect(result.dtype).toBe('float32');
test_util_1.expectArraysClose(result, [3, 4, 6.25, 7]);
});
it('input int32 throws error', function () {
var a = tf.tensor3d([1, 2, 3, 4, 5, 6, 7, 9, 8], [3, 3, 1], 'int32');
expect(function () { return tf.avgPool(a, 2, 1, 0); }).toThrowError();
});
it('x=[2,3,3,1] f=[2,2], s=1', function () {
var a = tf.tensor4d([1, 2, 3, 4, 5, 6, 7, 9, 8, 1, 2, 3, 4, 5, 6, 7, 8, 9], [2, 3, 3, 1]);
var result = tf.avgPool(a, 2, 1, 0);
expect(result.shape).toEqual([2, 2, 2, 1]);
test_util_1.expectArraysClose(result, [3, 4, 6.25, 7, 3, 4, 6, 7]);
});
it('x=[3,3,1] f=[2,2] s=1 propagates NaNs', function () {
var a = tf.tensor3d([1, 2, 3, 4, 5, 6, 7, NaN, 8], [3, 3, 1]);
var result = tf.avgPool(a, 2, 1, 0);
expect(result.shape).toEqual([2, 2, 1]);
test_util_1.expectArraysClose(result, [3, 4, NaN, NaN]);
});
it('x=[3,3,2] f=[2,2] s=1', function () {
var a = tf.tensor3d([1, 99, 2, 88, 3, 77, 4, 66, 5, 55, 6, 44, 7, 33, 9, 22, 8, 11], [3, 3, 2]);
var result = tf.avgPool(a, 2, 1, 0);
expect(result.shape).toEqual([2, 2, 2]);
test_util_1.expectArraysClose(result, [3, 77, 4, 66, 6.25, 44, 7, 33]);
});
it('x=[4,4,1] f=[2,2] s=2', function () {
var a = tf.tensor3d([0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15], [4, 4, 1]);
var result = tf.avgPool(a, 2, 2, 0);
expect(result.shape).toEqual([2, 2, 1]);
test_util_1.expectArraysClose(result, [2.5, 4.5, 10.5, 12.5]);
});
it('x=[2,2,1] f=[2,2] s=1 p=same', function () {
var a = tf.tensor3d([1, 2, 3, 4], [2, 2, 1]);
var fSize = 2;
var strides = 1;
var result = tf.avgPool(a, fSize, strides, 'same');
expect(result.shape).toEqual([2, 2, 1]);
test_util_1.expectArraysClose(result, [2.5, 3, 3.5, 4]);
});
it('gradient x=[1,1,1] f=[1,1] s=1 [0] => [0]', function () {
var x = tf.tensor3d([0], [1, 1, 1]);
var dy = tf.tensor3d([0], [1, 1, 1]);
var dx = tf.grad(function (x) { return x.avgPool(1, 1, 0); })(x, dy);
expect(dx.shape).toEqual(x.shape);
test_util_1.expectArraysClose(dx, [0]);
});
it('gradient x=[3,3,1] f=[2,2] s=1', function () {
var x = tf.tensor3d([1, 2, 3, 4, 5, 6, 7, 9, 8], [3, 3, 1]);
var dy = tf.tensor3d([1, 2, 3, 4], [2, 2, 1]);
var avgMultiplier = 1 / (2 * 2);
var dx = tf.grad(function (x) { return x.avgPool(2, 1, 0); })(x, dy);
expect(dx.shape).toEqual(x.shape);
test_util_1.expectArraysClose(dx, [
1 * avgMultiplier, 3 * avgMultiplier, 2 * avgMultiplier,
4 * avgMultiplier, 10 * avgMultiplier, 6 * avgMultiplier,
3 * avgMultiplier, 7 * avgMultiplier, 4 * avgMultiplier
]);
});
it('gradient x=[2,3,3,1] f=[2,2], s=1', function () {
var x = tf.tensor4d([1, 2, 3, 4, 5, 6, 7, 9, 8, 1, 2, 3, 4, 5, 6, 7, 8, 9], [2, 3, 3, 1]);
var dy = tf.tensor4d([1, 2, 3, 4, 1, 2, 3, 4], [2, 2, 2, 1]);
var avgMultiplier = 1 / (2 * 2);
var dx = tf.grad(function (x) { return x.avgPool(2, 1, 0); })(x, dy);
expect(dx.shape).toEqual(x.shape);
test_util_1.expectArraysClose(dx, [
1 * avgMultiplier, 3 * avgMultiplier, 2 * avgMultiplier,
4 * avgMultiplier, 10 * avgMultiplier, 6 * avgMultiplier,
3 * avgMultiplier, 7 * avgMultiplier, 4 * avgMultiplier,
1 * avgMultiplier, 3 * avgMultiplier, 2 * avgMultiplier,
4 * avgMultiplier, 10 * avgMultiplier, 6 * avgMultiplier,
3 * avgMultiplier, 7 * avgMultiplier, 4 * avgMultiplier
]);
});
it('throws when dimRoundingMode is set and pad is not a number', function () {
var x = tf.tensor3d([1, 2, 3, 4], [2, 2, 1]);
var pad = 'valid';
var dimRoundingMode = 'round';
expect(function () { return tf.avgPool(x, 2, 1, pad, dimRoundingMode); }).toThrowError();
});
it('throws when passed a non-tensor', function () {
expect(function () { return tf.avgPool({}, 2, 1, 'valid'); })
.toThrowError(/Argument 'x' passed to 'avgPool' must be a Tensor/);
});
});