/** * @license * Copyright 2020 Google LLC. 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 * as tf from '../index'; import { ALL_ENVS, describeWithFlags } from '../jasmine_util'; import { expectArraysEqual } from '../test_util'; async function expectTensor(tensor, shape, value) { const length = shape.length === 0 ? 1 : shape.reduce((a, b) => a * b); expect(tensor.shape).toEqual(shape); expectArraysEqual(await tensor.data(), new Array(length).fill(value)); } describeWithFlags('squeeze', ALL_ENVS, () => { it('default', async () => { const assertType = async (dtype) => { const value = dtype === 'string' ? 'test' : 0.0; // Nothing to squeeze. await expectTensor(tf.squeeze(tf.fill([2], value)), [2], value); // Squeeze the middle element away. await expectTensor(tf.squeeze(tf.fill([2, 1, 2], value)), [2, 2], value); // Squeeze on both ends. await expectTensor(tf.squeeze(tf.fill([1, 2, 1, 3, 1], value)), [2, 3], value); }; await assertType('string'); await assertType('float32'); }); it('specific dimension', async () => { const assertType = async (dtype) => { const value = dtype === 'string' ? 'test' : 0.0; const shape = [1, 2, 1, 3, 1]; // Positive squeeze dim index. await expectTensor(tf.squeeze(tf.fill(shape, value), [0]), [2, 1, 3, 1], value); await expectTensor(tf.squeeze(tf.fill(shape, value), [2, 4]), [1, 2, 3], value); await expectTensor(tf.squeeze(tf.fill(shape, value), [0, 4, 2]), [2, 3], value); // Negative squeeze dim index. await expectTensor(tf.squeeze(tf.fill(shape, value), [-1]), [1, 2, 1, 3], value); await expectTensor(tf.squeeze(tf.fill(shape, value), [-3, -5]), [2, 3, 1], value); await expectTensor(tf.squeeze(tf.fill(shape, value), [-3, -5, -1]), [2, 3], value); }; await assertType('string'); await assertType('float32'); }); it('all ones', async () => { const assertType = async (dtype) => { const value = dtype === 'string' ? 'test' : 0.0; await expectTensor(tf.squeeze(tf.fill([1, 1, 1], value)), [], value); }; await assertType('string'); await assertType('float32'); }); it('squeeze only ones', async () => { const assertType = async (dtype) => { const value = dtype === 'string' ? 'test' : 0.0; const shape = [1, 1, 3]; await expectTensor(tf.squeeze(tf.fill(shape, value)), [3], value); await expectTensor(tf.squeeze(tf.fill(shape, value), [0]), [1, 3], value); await expectTensor(tf.squeeze(tf.fill(shape, value), [1]), [1, 3], value); expect(() => tf.squeeze(tf.fill(shape, value), [2])).toThrowError(); }; await assertType('string'); await assertType('float32'); }); it('squeeze errors', async () => { const assertType = async (dtype) => { const value = dtype === 'string' ? 'test' : 0.0; const shape = [1, 2, 1]; expect(() => tf.squeeze(tf.fill(shape, value), [-4])).toThrowError(); expect(() => tf.squeeze(tf.fill(shape, value), [0, -4])).toThrowError(); expect(() => tf.squeeze(tf.fill(shape, value), [3])).toThrowError(); expect(() => tf.squeeze(tf.fill(shape, value), [2, 3])).toThrowError(); }; await assertType('string'); await assertType('float32'); }); }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"squeeze_test.js","sourceRoot":"","sources":["../../../../../../tfjs-core/src/ops/squeeze_test.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright 2020 Google LLC. All Rights Reserved.\n * Licensed under the Apache License, Version 2.0 (the \"License\");\n * you may not use this file except in compliance with the License.\n * You may obtain a copy of the License at\n *\n * http://www.apache.org/licenses/LICENSE-2.0\n *\n * Unless required by applicable law or agreed to in writing, software\n * distributed under the License is distributed on an \"AS IS\" BASIS,\n * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\n * See the License for the specific language governing permissions and\n * limitations under the License.\n * =============================================================================\n */\nimport * as tf from '../index';\nimport {ALL_ENVS, describeWithFlags} from '../jasmine_util';\nimport {expectArraysEqual} from '../test_util';\n\nasync function expectTensor(\n    tensor: tf.Tensor, shape: number[], value: string|number) {\n  const length = shape.length === 0 ? 1 : shape.reduce((a, b) => a * b);\n  expect(tensor.shape).toEqual(shape);\n  expectArraysEqual(await tensor.data(), new Array(length).fill(value));\n}\n\ndescribeWithFlags('squeeze', ALL_ENVS, () => {\n  it('default', async () => {\n    const assertType = async (dtype: 'string'|'float32') => {\n      const value = dtype === 'string' ? 'test' : 0.0;\n      // Nothing to squeeze.\n      await expectTensor(tf.squeeze(tf.fill([2], value)), [2], value);\n\n      // Squeeze the middle element away.\n      await expectTensor(tf.squeeze(tf.fill([2, 1, 2], value)), [2, 2], value);\n\n      // Squeeze on both ends.\n      await expectTensor(\n          tf.squeeze(tf.fill([1, 2, 1, 3, 1], value)), [2, 3], value);\n    };\n\n    await assertType('string');\n    await assertType('float32');\n  });\n\n  it('specific dimension', async () => {\n    const assertType = async (dtype: 'string'|'float32') => {\n      const value = dtype === 'string' ? 'test' : 0.0;\n      const shape = [1, 2, 1, 3, 1];\n      // Positive squeeze dim index.\n      await expectTensor(\n          tf.squeeze(tf.fill(shape, value), [0]), [2, 1, 3, 1], value);\n      await expectTensor(\n          tf.squeeze(tf.fill(shape, value), [2, 4]), [1, 2, 3], value);\n      await expectTensor(\n          tf.squeeze(tf.fill(shape, value), [0, 4, 2]), [2, 3], value);\n\n      // Negative squeeze dim index.\n      await expectTensor(\n          tf.squeeze(tf.fill(shape, value), [-1]), [1, 2, 1, 3], value);\n      await expectTensor(\n          tf.squeeze(tf.fill(shape, value), [-3, -5]), [2, 3, 1], value);\n      await expectTensor(\n          tf.squeeze(tf.fill(shape, value), [-3, -5, -1]), [2, 3], value);\n    };\n\n    await assertType('string');\n    await assertType('float32');\n  });\n\n  it('all ones', async () => {\n    const assertType = async (dtype: 'string'|'float32') => {\n      const value = dtype === 'string' ? 'test' : 0.0;\n      await expectTensor(tf.squeeze(tf.fill([1, 1, 1], value)), [], value);\n    };\n\n    await assertType('string');\n    await assertType('float32');\n  });\n\n  it('squeeze only ones', async () => {\n    const assertType = async (dtype: 'string'|'float32') => {\n      const value = dtype === 'string' ? 'test' : 0.0;\n      const shape = [1, 1, 3];\n      await expectTensor(tf.squeeze(tf.fill(shape, value)), [3], value);\n      await expectTensor(tf.squeeze(tf.fill(shape, value), [0]), [1, 3], value);\n      await expectTensor(tf.squeeze(tf.fill(shape, value), [1]), [1, 3], value);\n      expect(() => tf.squeeze(tf.fill(shape, value), [2])).toThrowError();\n    };\n\n    await assertType('string');\n    await assertType('float32');\n  });\n\n  it('squeeze errors', async () => {\n    const assertType = async (dtype: 'string'|'float32') => {\n      const value = dtype === 'string' ? 'test' : 0.0;\n      const shape = [1, 2, 1];\n      expect(() => tf.squeeze(tf.fill(shape, value), [-4])).toThrowError();\n      expect(() => tf.squeeze(tf.fill(shape, value), [0, -4])).toThrowError();\n      expect(() => tf.squeeze(tf.fill(shape, value), [3])).toThrowError();\n      expect(() => tf.squeeze(tf.fill(shape, value), [2, 3])).toThrowError();\n    };\n\n    await assertType('string');\n    await assertType('float32');\n  });\n});\n"]}