summaryrefslogtreecommitdiffstats
path: root/vespajlib
diff options
context:
space:
mode:
authorJon Bratseth <bratseth@yahoo-inc.com>2017-01-17 14:02:54 +0100
committerJon Bratseth <bratseth@yahoo-inc.com>2017-01-17 14:02:54 +0100
commite3bb73e8be1a4704f23433b140d2b9380e2573c1 (patch)
tree71a24e9fae17848bfebc4f22165be900dfee912d /vespajlib
parent7d2fef1de33e24345b49ce5fb2e46cb1627923dc (diff)
Allow missing values
Fill missing values with 0 when building dense tensors.
Diffstat (limited to 'vespajlib')
-rw-r--r--vespajlib/src/main/java/com/yahoo/tensor/IndexedTensor.java10
-rw-r--r--vespajlib/src/test/java/com/yahoo/tensor/IndexedTensorTestCase.java10
2 files changed, 18 insertions, 2 deletions
diff --git a/vespajlib/src/main/java/com/yahoo/tensor/IndexedTensor.java b/vespajlib/src/main/java/com/yahoo/tensor/IndexedTensor.java
index bee93ddb4e0..a66caa8dd35 100644
--- a/vespajlib/src/main/java/com/yahoo/tensor/IndexedTensor.java
+++ b/vespajlib/src/main/java/com/yahoo/tensor/IndexedTensor.java
@@ -355,10 +355,16 @@ public class IndexedTensor implements Tensor {
offset + productOfDimensionsAfter(currentDimensionIndex, sizes) * i,
(List<Object>) currentDimension.get(i), sizes, values);
} else { // last dimension - fill values
- for (int i = 0; i < currentDimension.size(); i++)
- values[offset + i] = (double) currentDimension.get(i);
+ for (int i = 0; i < currentDimension.size(); i++) {
+ values[offset + i] = nullAsZero((Double)currentDimension.get(i)); // fill missing values as zero
+ }
}
}
+
+ private double nullAsZero(Double value) {
+ if (value == null) return 0;
+ return value;
+ }
@Override
public CellBuilder cell() {
diff --git a/vespajlib/src/test/java/com/yahoo/tensor/IndexedTensorTestCase.java b/vespajlib/src/test/java/com/yahoo/tensor/IndexedTensorTestCase.java
index 3a6a7f2f65d..09b6e79a101 100644
--- a/vespajlib/src/test/java/com/yahoo/tensor/IndexedTensorTestCase.java
+++ b/vespajlib/src/test/java/com/yahoo/tensor/IndexedTensorTestCase.java
@@ -3,6 +3,7 @@ package com.yahoo.tensor;
import junit.framework.TestCase;
import org.junit.Test;
+import java.util.Collections;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
@@ -63,6 +64,15 @@ public class IndexedTensorTestCase {
assertBuildingVWXYZ(type);
}
+ @Test
+ public void testUnderspecifiedBuilding() {
+ TensorType type = new TensorType.Builder().indexed("x").build();
+ Tensor.Builder builder = Tensor.Builder.of(type);
+ builder.cell(47.0, 98);
+ Tensor tensor = builder.build();
+ assertEquals(47.0, tensor.sum(Collections.singletonList("x")).asDouble(), 0.000001);
+ }
+
private void assertBuildingVWXYZ(TensorType type) {
IndexedTensor.Builder builder = IndexedTensor.Builder.of(type);
// Build in scrambled order