diff options
author | Lester Solbakken <lesters@oath.com> | 2019-02-12 14:56:36 +0100 |
---|---|---|
committer | Lester Solbakken <lesters@oath.com> | 2019-02-12 14:56:36 +0100 |
commit | 08bf643ca8de76265205e45878b060f30aa5d187 (patch) | |
tree | 159a292a3f62ae3d7ca330437a7d84bc17979746 /vespajlib/src/test/java/com/yahoo/tensor/TensorTestCase.java | |
parent | 6cd73b95dcdcf95a07a726aab88147c2aa19a029 (diff) |
Implement tensor modify applyTo in Java
Diffstat (limited to 'vespajlib/src/test/java/com/yahoo/tensor/TensorTestCase.java')
-rw-r--r-- | vespajlib/src/test/java/com/yahoo/tensor/TensorTestCase.java | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/vespajlib/src/test/java/com/yahoo/tensor/TensorTestCase.java b/vespajlib/src/test/java/com/yahoo/tensor/TensorTestCase.java index 05fbb0dbdd9..2c9eefbd130 100644 --- a/vespajlib/src/test/java/com/yahoo/tensor/TensorTestCase.java +++ b/vespajlib/src/test/java/com/yahoo/tensor/TensorTestCase.java @@ -14,6 +14,7 @@ import java.util.ArrayList; import java.util.Collections; import java.util.List; import java.util.Set; +import java.util.function.DoubleBinaryOperator; import static com.yahoo.tensor.TensorType.Dimension.Type; import static org.junit.Assert.assertEquals; @@ -136,6 +137,26 @@ public class TensorTestCase { assertEquals("Generic computation implementation", 42, (int)dotProduct(vectorInJSpace, Collections.singletonList(matrixInKSpace))); } + @Test + public void testTensorModify() { + assertTensorModify((left, right) -> right, + Tensor.from("tensor(x{},y{})", "{{x:0,y:0}:1, {x:0,y:1}:2}"), + Tensor.from("tensor(x{},y{})", "{{x:0,y:1}:0}"), + Tensor.from("tensor(x{},y{})", "{{x:0,y:0}:1,{x:0,y:1}:0}")); + assertTensorModify((left, right) -> left + right, + Tensor.from("tensor(x[1],y[2])", "{{x:0,y:0}:1, {x:0,y:1}:2}"), + Tensor.from("tensor(x{},y{})", "{{x:0,y:1}:3}"), + Tensor.from("tensor(x[1],y[2])", "{{x:0,y:0}:1,{x:0,y:1}:5}")); + assertTensorModify((left, right) -> left * right, + Tensor.from("tensor(x[1],y[2])", "{{x:0,y:0}:1, {x:0,y:1}:2}"), + Tensor.from("tensor(x[1],y[3])", "{}"), + Tensor.from("tensor(x[1],y[2])", "{{x:0,y:0}:0,{x:0,y:1}:0}")); + } + + private void assertTensorModify(DoubleBinaryOperator op, Tensor init, Tensor update, Tensor expected) { + assertEquals(expected, init.modify(op, update.cells())); + } + private double dotProduct(Tensor tensor, List<Tensor> tensors) { double sum = 0; TensorFunction dotProductFunction = new Reduce(new Join(new ConstantTensor(tensor), |