propagate_constant_test.cpp 1.78 KB
Newer Older
Paul's avatar
Paul committed
1
#include <migraphx/propagate_constant.hpp>
Paul's avatar
Paul committed
2
#include <migraphx/dead_code_elimination.hpp>
3
#include <migraphx/op/add.hpp>
Paul's avatar
Paul committed
4
5
6
7
8
9
#include <basic_ops.hpp>
#include <test.hpp>

struct const_prop_target
{
    std::string name() const { return "const_prop"; }
Paul's avatar
Paul committed
10
    std::vector<migraphx::pass> get_passes(migraphx::context&) const
Paul's avatar
Paul committed
11
    {
Paul's avatar
Paul committed
12
        return {migraphx::propagate_constant{}, migraphx::dead_code_elimination{}};
Paul's avatar
Paul committed
13
    }
Paul's avatar
Paul committed
14
    migraphx::context get_context() const { return {}; }
Paul's avatar
Paul committed
15
16
};

Paul's avatar
Paul committed
17
TEST_CASE(const_add1)
Paul's avatar
Paul committed
18
{
Paul's avatar
Paul committed
19
    migraphx::program p1;
Paul's avatar
Paul committed
20
21
    auto one = p1.add_literal(1);
    auto two = p1.add_literal(2);
Paul's avatar
Paul committed
22
    auto sum = p1.add_instruction(migraphx::op::add{}, one, two);
Paul's avatar
Paul committed
23
24
25
    p1.add_instruction(pass_op{}, sum);
    p1.compile(const_prop_target{});

Paul's avatar
Paul committed
26
    migraphx::program p2;
Paul's avatar
Paul committed
27
28
29
30
31
    auto total = p2.add_literal(3);
    p2.add_instruction(pass_op{}, total);
    EXPECT(p1 == p2);
}

Paul's avatar
Paul committed
32
TEST_CASE(const_add2)
Paul's avatar
Paul committed
33
{
Paul's avatar
Paul committed
34
35
    migraphx::program p1;
    auto one = p1.add_parameter("one", {migraphx::shape::int32_type, {1}});
Paul's avatar
Paul committed
36
    auto two = p1.add_literal(2);
Paul's avatar
Paul committed
37
    auto sum = p1.add_instruction(migraphx::op::add{}, one, two);
Paul's avatar
Paul committed
38
39
40
    p1.add_instruction(pass_op{}, sum);
    p1.compile(const_prop_target{});

Paul's avatar
Paul committed
41
    migraphx::program p2;
Paul's avatar
Paul committed
42
43
44
45
46
    auto total = p2.add_literal(3);
    p2.add_instruction(pass_op{}, total);
    EXPECT(p1 != p2);
}

Paul's avatar
Paul committed
47
TEST_CASE(const_add3)
Paul's avatar
Paul committed
48
{
Paul's avatar
Paul committed
49
    migraphx::program p1;
Paul's avatar
Paul committed
50
51
    auto one  = p1.add_literal(1);
    auto two  = p1.add_literal(2);
Paul's avatar
Paul committed
52
53
    auto sum1 = p1.add_instruction(migraphx::op::add{}, one, two);
    auto sum2 = p1.add_instruction(migraphx::op::add{}, sum1, two);
Paul's avatar
Paul committed
54
55
56
    p1.add_instruction(pass_op{}, sum2);
    p1.compile(const_prop_target{});

Paul's avatar
Paul committed
57
    migraphx::program p2;
Paul's avatar
Paul committed
58
59
60
61
62
    auto total = p2.add_literal(5);
    p2.add_instruction(pass_op{}, total);
    EXPECT(p1 == p2);
}

Paul's avatar
Paul committed
63
int main(int argc, const char* argv[]) { test::run(argc, argv); }