eval_test.cpp 1.61 KB
Newer Older
Paul's avatar
Paul committed
1
2
3
4
5
6

#include <rtg/program.hpp>
#include <rtg/argument.hpp>
#include <rtg/shape.hpp>
#include "test.hpp"

Paul's avatar
Paul committed
7
8
struct sum_op
{
Paul's avatar
Paul committed
9
    std::string name() const { return "sum"; }
Paul's avatar
Paul committed
10
11
12
    rtg::argument compute(std::vector<rtg::argument> args) const
    {
        rtg::argument result;
Paul's avatar
Paul committed
13
14
15
16
17
18
19
20
        if(args.size() != 2)
            throw "Wrong args";
        if(args[0].get_shape() != args[1].get_shape())
            throw "Wrong args";
        if(args[0].get_shape().lens().size() != 1)
            throw "Wrong args";
        if(args[0].get_shape().lens().front() != 1)
            throw "Wrong args";
Paul's avatar
Paul committed
21
22

        args[0].visit_at([&](auto x) {
Paul's avatar
Paul committed
23
            args[1].visit_at([&](auto y) { result = rtg::literal{x + y}.get_argument(); });
Paul's avatar
Paul committed
24
25
26
27
28
29
        });
        return result;
    }

    rtg::shape compute_shape(std::vector<rtg::shape> inputs) const
    {
Paul's avatar
Paul committed
30
31
        if(inputs.size() != 2)
            throw "Wrong inputs";
Paul's avatar
Paul committed
32
33
34
35
        return inputs.front();
    }
};

Paul's avatar
Paul committed
36
37
void literal_test()
{
Paul's avatar
Paul committed
38
    rtg::program p;
Paul's avatar
Paul committed
39
40
41

    auto one = p.add_literal(1);
    auto two = p.add_literal(2);
Paul's avatar
Paul committed
42
    p.add_instruction(sum_op{}, one, two);
Paul's avatar
Paul committed
43
44
45
46
47
    auto result = p.eval({});
    EXPECT(result == rtg::literal{3});
    EXPECT(result != rtg::literal{4});
}

Paul's avatar
Paul committed
48
49
void param_test()
{
Paul's avatar
Paul committed
50
51
    rtg::program p;

Paul's avatar
Paul committed
52
53
    auto x = p.add_parameter("x", {rtg::shape::int64_type});
    auto y = p.add_parameter("y", {rtg::shape::int64_type});
Paul's avatar
Paul committed
54

Paul's avatar
Paul committed
55
    p.add_instruction(sum_op{}, x, y);
Paul's avatar
Paul committed
56
57
    auto result =
        p.eval({{"x", rtg::literal{1}.get_argument()}, {"y", rtg::literal{2}.get_argument()}});
Paul's avatar
Paul committed
58
59
60
61
    EXPECT(result == rtg::literal{3});
    EXPECT(result != rtg::literal{4});
}

Paul's avatar
Paul committed
62
63
int main()
{
Paul's avatar
Paul committed
64
65
    literal_test();
    param_test();
Paul's avatar
Paul committed
66
}