/**
|
* @license
|
* Copyright 2018 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 { expectArraysClose, expectArraysEqual } from '../test_util';
|
let defaultValue;
|
describeWithFlags('sparseToDense', ALL_ENVS, () => {
|
beforeEach(() => defaultValue = tf.scalar(0, 'int32'));
|
it('should work for scalar indices', async () => {
|
const indices = tf.scalar(2, 'int32');
|
const values = tf.scalar(100, 'int32');
|
const shape = [6];
|
const result = tf.sparseToDense(indices, values, shape, defaultValue);
|
expect(result.shape).toEqual(shape);
|
expect(result.dtype).toEqual(values.dtype);
|
expectArraysClose(await result.data(), [0, 0, 100, 0, 0, 0]);
|
});
|
it('should work for vector', async () => {
|
const indices = tf.tensor1d([0, 2, 4], 'int32');
|
const values = tf.tensor1d([100, 101, 102], 'int32');
|
const shape = [6];
|
const result = tf.sparseToDense(indices, values, shape, defaultValue);
|
expect(result.shape).toEqual(shape);
|
expect(result.dtype).toEqual(values.dtype);
|
expectArraysClose(await result.data(), [100, 0, 101, 0, 102, 0]);
|
});
|
it('should work for scalar value', async () => {
|
const indices = tf.tensor1d([0, 2, 4], 'int32');
|
const values = tf.scalar(10, 'int32');
|
const shape = [6];
|
const result = tf.sparseToDense(indices, values, shape, defaultValue);
|
expect(result.shape).toEqual(shape);
|
expect(result.dtype).toEqual(values.dtype);
|
expectArraysClose(await result.data(), [10, 0, 10, 0, 10, 0]);
|
});
|
it('should work for matrix', async () => {
|
const indices = tf.tensor2d([0, 1, 1, 1], [2, 2], 'int32');
|
const values = tf.tensor1d([5, 6], 'float32');
|
const shape = [2, 2];
|
const result = tf.sparseToDense(indices, values, shape, defaultValue.toFloat());
|
expect(result.shape).toEqual(shape);
|
expect(result.dtype).toEqual(values.dtype);
|
expectArraysClose(await result.data(), [0, 5, 0, 6]);
|
});
|
it('should work for string', async () => {
|
const indices = tf.tensor2d([0, 1, 1, 1], [2, 2], 'int32');
|
const values = tf.tensor1d(['a', 'b'], 'string');
|
const shape = [2, 2];
|
const result = tf.sparseToDense(indices, values, shape, tf.scalar('c', 'string'));
|
expect(result.shape).toEqual(shape);
|
expect(result.dtype).toEqual(values.dtype);
|
expectArraysEqual(await result.data(), ['c', 'a', 'c', 'b']);
|
});
|
it('should throw exception if default value does not match dtype', () => {
|
const indices = tf.tensor2d([0, 1, 1, 1], [2, 2], 'int32');
|
const values = tf.tensor1d([5, 6], 'float32');
|
const shape = [2, 2];
|
expect(() => tf.sparseToDense(indices, values, shape, tf.scalar(1, 'int32')))
|
.toThrowError();
|
});
|
it('should allow setting default value', async () => {
|
const indices = tf.tensor2d([0, 1, 1, 1], [2, 2], 'int32');
|
const values = tf.tensor1d([5, 6], 'float32');
|
const shape = [2, 2];
|
const result = tf.sparseToDense(indices, values, shape, tf.scalar(1));
|
expect(result.shape).toEqual(shape);
|
expect(result.dtype).toEqual(values.dtype);
|
expectArraysClose(await result.data(), [1, 5, 1, 6]);
|
});
|
it('no default value passed', async () => {
|
const indices = tf.tensor2d([0, 1, 1, 1], [2, 2], 'int32');
|
const values = tf.tensor1d([5, 6], 'float32');
|
const shape = [2, 2];
|
const result = tf.sparseToDense(indices, values, shape);
|
expect(result.shape).toEqual(shape);
|
expect(result.dtype).toEqual(values.dtype);
|
expectArraysClose(await result.data(), [0, 5, 0, 6]);
|
});
|
it('should support TensorLike inputs', async () => {
|
const indices = [[0, 1], [1, 1]];
|
const values = [5, 6];
|
const shape = [2, 2];
|
const result = tf.sparseToDense(indices, values, shape, defaultValue.toFloat());
|
expect(result.shape).toEqual(shape);
|
expect(result.dtype).toEqual('float32');
|
expectArraysClose(await result.data(), [0, 5, 0, 6]);
|
});
|
it('should work with 0-sized tensors', async () => {
|
const indices = tf.zeros([0], 'int32');
|
const values = tf.zeros([0]);
|
const defaultValue = tf.scalar(5);
|
const result = tf.sparseToDense(indices, values, [3], defaultValue);
|
expectArraysClose(await result.data(), [5, 5, 5]);
|
});
|
it('should throw error when indices are not int32', () => {
|
const indices = tf.scalar(2, 'float32');
|
const values = tf.scalar(100, 'int32');
|
const shape = [6];
|
expect(() => tf.sparseToDense(indices, values, shape, defaultValue))
|
.toThrow();
|
});
|
it('should throw error when indices rank > 2', () => {
|
const indices = tf.tensor3d([1], [1, 1, 1], 'int32');
|
const values = tf.tensor1d([100], 'float32');
|
const shape = [6];
|
expect(() => tf.sparseToDense(indices, values, shape, defaultValue))
|
.toThrow();
|
});
|
it('should throw error when values has rank > 1', () => {
|
const indices = tf.tensor1d([0, 4, 2], 'int32');
|
const values = tf.tensor2d([1.0, 2.0, 3.0], [3, 1], 'float32');
|
const shape = [6];
|
expect(() => tf.sparseToDense(indices, values, shape, defaultValue))
|
.toThrow();
|
});
|
it('should throw error when values has wrong size', () => {
|
const indices = tf.tensor1d([0, 4, 2], 'int32');
|
const values = tf.tensor1d([1.0, 2.0, 3.0, 4.0], 'float32');
|
const shape = [6];
|
expect(() => tf.sparseToDense(indices, values, shape, defaultValue))
|
.toThrow();
|
});
|
it('should throw error when shape is not integer', () => {
|
const indices = [[0, 1], [1, 1]];
|
const values = [5, 6];
|
const shape = [2.22, 2.22];
|
expect(() => tf.sparseToDense(indices, values, shape, tf.scalar(1)))
|
.toThrow();
|
});
|
});
|
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sparse_to_dense_test.js","sourceRoot":"","sources":["../../../../../../tfjs-core/src/ops/sparse_to_dense_test.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright 2018 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 */\n\nimport * as tf from '../index';\nimport {ALL_ENVS, describeWithFlags} from '../jasmine_util';\nimport {expectArraysClose, expectArraysEqual} from '../test_util';\n\nlet defaultValue: tf.Scalar;\ndescribeWithFlags('sparseToDense', ALL_ENVS, () => {\n  beforeEach(() => defaultValue = tf.scalar(0, 'int32'));\n  it('should work for scalar indices', async () => {\n    const indices = tf.scalar(2, 'int32');\n    const values = tf.scalar(100, 'int32');\n    const shape = [6];\n    const result = tf.sparseToDense(indices, values, shape, defaultValue);\n    expect(result.shape).toEqual(shape);\n    expect(result.dtype).toEqual(values.dtype);\n    expectArraysClose(await result.data(), [0, 0, 100, 0, 0, 0]);\n  });\n  it('should work for vector', async () => {\n    const indices = tf.tensor1d([0, 2, 4], 'int32');\n    const values = tf.tensor1d([100, 101, 102], 'int32');\n    const shape = [6];\n    const result = tf.sparseToDense(indices, values, shape, defaultValue);\n    expect(result.shape).toEqual(shape);\n    expect(result.dtype).toEqual(values.dtype);\n    expectArraysClose(await result.data(), [100, 0, 101, 0, 102, 0]);\n  });\n  it('should work for scalar value', async () => {\n    const indices = tf.tensor1d([0, 2, 4], 'int32');\n    const values = tf.scalar(10, 'int32');\n    const shape = [6];\n    const result = tf.sparseToDense(indices, values, shape, defaultValue);\n    expect(result.shape).toEqual(shape);\n    expect(result.dtype).toEqual(values.dtype);\n    expectArraysClose(await result.data(), [10, 0, 10, 0, 10, 0]);\n  });\n  it('should work for matrix', async () => {\n    const indices = tf.tensor2d([0, 1, 1, 1], [2, 2], 'int32');\n    const values = tf.tensor1d([5, 6], 'float32');\n    const shape = [2, 2];\n    const result =\n        tf.sparseToDense(indices, values, shape, defaultValue.toFloat());\n    expect(result.shape).toEqual(shape);\n    expect(result.dtype).toEqual(values.dtype);\n    expectArraysClose(await result.data(), [0, 5, 0, 6]);\n  });\n  it('should work for string', async () => {\n    const indices = tf.tensor2d([0, 1, 1, 1], [2, 2], 'int32');\n    const values = tf.tensor1d(['a', 'b'], 'string');\n    const shape = [2, 2];\n    const result =\n        tf.sparseToDense(indices, values, shape, tf.scalar('c', 'string'));\n    expect(result.shape).toEqual(shape);\n    expect(result.dtype).toEqual(values.dtype);\n    expectArraysEqual(await result.data(), ['c', 'a', 'c', 'b']);\n  });\n\n  it('should throw exception if default value does not match dtype', () => {\n    const indices = tf.tensor2d([0, 1, 1, 1], [2, 2], 'int32');\n    const values = tf.tensor1d([5, 6], 'float32');\n    const shape = [2, 2];\n    expect(\n        () => tf.sparseToDense(indices, values, shape, tf.scalar(1, 'int32')))\n        .toThrowError();\n  });\n\n  it('should allow setting default value', async () => {\n    const indices = tf.tensor2d([0, 1, 1, 1], [2, 2], 'int32');\n    const values = tf.tensor1d([5, 6], 'float32');\n    const shape = [2, 2];\n    const result = tf.sparseToDense(indices, values, shape, tf.scalar(1));\n    expect(result.shape).toEqual(shape);\n    expect(result.dtype).toEqual(values.dtype);\n    expectArraysClose(await result.data(), [1, 5, 1, 6]);\n  });\n\n  it('no default value passed', async () => {\n    const indices = tf.tensor2d([0, 1, 1, 1], [2, 2], 'int32');\n    const values = tf.tensor1d([5, 6], 'float32');\n    const shape = [2, 2];\n    const result = tf.sparseToDense(indices, values, shape);\n    expect(result.shape).toEqual(shape);\n    expect(result.dtype).toEqual(values.dtype);\n    expectArraysClose(await result.data(), [0, 5, 0, 6]);\n  });\n\n  it('should support TensorLike inputs', async () => {\n    const indices = [[0, 1], [1, 1]];\n    const values = [5, 6];\n    const shape = [2, 2];\n    const result =\n        tf.sparseToDense(indices, values, shape, defaultValue.toFloat());\n    expect(result.shape).toEqual(shape);\n    expect(result.dtype).toEqual('float32');\n    expectArraysClose(await result.data(), [0, 5, 0, 6]);\n  });\n\n  it('should work with 0-sized tensors', async () => {\n    const indices = tf.zeros([0], 'int32');\n    const values = tf.zeros([0]);\n    const defaultValue = tf.scalar(5);\n    const result = tf.sparseToDense(indices, values, [3], defaultValue);\n    expectArraysClose(await result.data(), [5, 5, 5]);\n  });\n\n  it('should throw error when indices are not int32', () => {\n    const indices = tf.scalar(2, 'float32');\n    const values = tf.scalar(100, 'int32');\n    const shape = [6];\n    expect(() => tf.sparseToDense(indices, values, shape, defaultValue))\n        .toThrow();\n  });\n\n  it('should throw error when indices rank > 2', () => {\n    const indices = tf.tensor3d([1], [1, 1, 1], 'int32');\n    const values = tf.tensor1d([100], 'float32');\n    const shape = [6];\n    expect(() => tf.sparseToDense(indices, values, shape, defaultValue))\n        .toThrow();\n  });\n\n  it('should throw error when values has rank > 1', () => {\n    const indices = tf.tensor1d([0, 4, 2], 'int32');\n    const values = tf.tensor2d([1.0, 2.0, 3.0], [3, 1], 'float32');\n    const shape = [6];\n    expect(() => tf.sparseToDense(indices, values, shape, defaultValue))\n        .toThrow();\n  });\n\n  it('should throw error when values has wrong size', () => {\n    const indices = tf.tensor1d([0, 4, 2], 'int32');\n    const values = tf.tensor1d([1.0, 2.0, 3.0, 4.0], 'float32');\n    const shape = [6];\n    expect(() => tf.sparseToDense(indices, values, shape, defaultValue))\n        .toThrow();\n  });\n\n  it('should throw error when shape is not integer', () => {\n    const indices = [[0, 1], [1, 1]];\n    const values = [5, 6];\n    const shape = [2.22, 2.22];\n    expect(() => tf.sparseToDense(indices, values, shape, tf.scalar(1)))\n        .toThrow();\n  });\n});\n"]}
|