1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
|
// Copyright 2019 Oath Inc. Licensed under the terms of the Apache 2.0 license. See LICENSE in the project root.
#include <vespa/eval/eval/tensor_spec.h>
#include <vespa/eval/tensor/default_tensor_engine.h>
#include <vespa/eval/tensor/sparse/sparse_tensor.h>
#include <vespa/vespalib/testkit/test_kit.h>
using vespalib::eval::Value;
using vespalib::eval::TensorSpec;
using namespace vespalib::tensor;
std::unique_ptr<Tensor>
makeTensor(const TensorSpec &spec)
{
auto value = DefaultTensorEngine::ref().from_spec(spec);
const auto *tensor = dynamic_cast<const Tensor *>(value->as_tensor());
ASSERT_TRUE(tensor);
value.release();
return std::unique_ptr<Tensor>(const_cast<Tensor *>(tensor));
}
void
assertAdd(const TensorSpec &source, const TensorSpec &arg, const TensorSpec &expected)
{
auto sourceTensor = makeTensor(source);
auto argTensor = makeTensor(arg);
auto resultTensor = sourceTensor->add(*argTensor);
auto actual = resultTensor->toSpec();
EXPECT_EQUAL(actual, expected);
}
TEST("require that cells can be added to a sparse tensor")
{
assertAdd(TensorSpec("tensor(x{},y{})")
.add({{"x","a"},{"y","b"}}, 2)
.add({{"x","c"},{"y","d"}}, 3),
TensorSpec("tensor(x{},y{})")
.add({{"x","a"},{"y","b"}}, 5)
.add({{"x","e"},{"y","f"}}, 7),
TensorSpec("tensor(x{},y{})")
.add({{"x","a"},{"y","b"}}, 5)
.add({{"x","c"},{"y","d"}}, 3)
.add({{"x","e"},{"y","f"}}, 7));
}
TEST_MAIN() { TEST_RUN_ALL(); }
|