propagate_constant_test.cpp 3.71 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/pass_manager.hpp>
4
#include <migraphx/op/add.hpp>
Paul's avatar
Paul committed
5
#include <migraphx/op/scalar.hpp>
Paul's avatar
Paul committed
6
#include <migraphx/op/mul.hpp>
Paul's avatar
Paul committed
7
8
9
#include <basic_ops.hpp>
#include <test.hpp>

10
void run_pass(migraphx::program& p)
Paul's avatar
Paul committed
11
{
12
13
    migraphx::run_passes(*p.get_main_module(),
                         {migraphx::propagate_constant{}, migraphx::dead_code_elimination{}});
14
}
Paul's avatar
Paul committed
15

Paul's avatar
Paul committed
16
TEST_CASE(const_add)
Paul's avatar
Paul committed
17
{
Paul's avatar
Paul committed
18
    migraphx::program p1;
19
20
21
22
23
    auto* mm1 = p1.get_main_module();
    auto one  = mm1->add_literal(1);
    auto two  = mm1->add_literal(2);
    auto sum  = mm1->add_instruction(migraphx::op::add{}, one, two);
    mm1->add_instruction(pass_op{}, sum);
24
    run_pass(p1);
Paul's avatar
Paul committed
25

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

Paul's avatar
Paul committed
33
TEST_CASE(const_add_parameter)
Paul's avatar
Paul committed
34
{
Paul's avatar
Paul committed
35
    migraphx::program p1;
36
37
38
39
40
    auto* mm1 = p1.get_main_module();
    auto one  = mm1->add_parameter("one", {migraphx::shape::int32_type, {1}});
    auto two  = mm1->add_literal(2);
    auto sum  = mm1->add_instruction(migraphx::op::add{}, one, two);
    mm1->add_instruction(pass_op{}, sum);
41
    run_pass(p1);
Paul's avatar
Paul committed
42

Paul's avatar
Paul committed
43
    migraphx::program p2;
44
45
46
    auto* mm2  = p2.get_main_module();
    auto total = mm2->add_literal(3);
    mm2->add_instruction(pass_op{}, total);
Paul's avatar
Paul committed
47
48
49
    EXPECT(p1 != p2);
}

Paul's avatar
Paul committed
50
TEST_CASE(const_multiadd)
Paul's avatar
Paul committed
51
{
Paul's avatar
Paul committed
52
    migraphx::program p1;
53
54
55
56
57
58
    auto* mm1 = p1.get_main_module();
    auto one  = mm1->add_literal(1);
    auto two  = mm1->add_literal(2);
    auto sum1 = mm1->add_instruction(migraphx::op::add{}, one, two);
    auto sum2 = mm1->add_instruction(migraphx::op::add{}, sum1, two);
    mm1->add_instruction(pass_op{}, sum2);
59
    run_pass(p1);
Paul's avatar
Paul committed
60

Paul's avatar
Paul committed
61
    migraphx::program p2;
62
63
64
    auto* mm2  = p2.get_main_module();
    auto total = mm2->add_literal(5);
    mm2->add_instruction(pass_op{}, total);
Paul's avatar
Paul committed
65
66
67
    EXPECT(p1 == p2);
}

Paul's avatar
Paul committed
68
TEST_CASE(const_add_mul)
Paul's avatar
Paul committed
69
70
{
    migraphx::program p1;
71
72
73
74
75
76
77
    auto* mm1 = p1.get_main_module();
    auto one  = mm1->add_literal(1);
    auto two  = mm1->add_literal(2);
    auto mul  = mm1->add_instruction(migraphx::op::mul{}, two, two);
    auto sum1 = mm1->add_instruction(migraphx::op::add{}, one, mul);
    auto sum2 = mm1->add_instruction(migraphx::op::add{}, sum1, two);
    mm1->add_instruction(pass_op{}, sum2);
78
    run_pass(p1);
Paul's avatar
Paul committed
79
80

    migraphx::program p2;
81
82
83
    auto* mm2  = p2.get_main_module();
    auto total = mm2->add_literal(7);
    mm2->add_instruction(pass_op{}, total);
Paul's avatar
Paul committed
84
85
86
    EXPECT(p1 == p2);
}

Paul's avatar
Paul committed
87
88
89
TEST_CASE(const_add_scalar)
{
    migraphx::program p1;
90
91
92
93
94
    auto* mm1 = p1.get_main_module();
    auto one  = mm1->add_instruction(migraphx::op::scalar{{2, 2}}, mm1->add_literal(1));
    auto two  = mm1->add_instruction(migraphx::op::scalar{{2, 2}}, mm1->add_literal(2));
    auto sum  = mm1->add_instruction(migraphx::op::add{}, one, two);
    mm1->add_instruction(pass_op{}, sum);
95
    run_pass(p1);
Paul's avatar
Paul committed
96
97

    migraphx::program p2;
98
    auto* mm2 = p2.get_main_module();
Paul's avatar
Paul committed
99
    auto total =
100
101
        mm2->add_literal(migraphx::literal{{migraphx::shape::int32_type, {2, 2}}, {3, 3, 3, 3}});
    mm2->add_instruction(pass_op{}, total);
Paul's avatar
Paul committed
102
103
104
105
106
107
108
    EXPECT(p1 == p2);
}

TEST_CASE(const_scalar)
{
    migraphx::program p1;
    {
109
110
111
        auto* mm1 = p1.get_main_module();
        auto one  = mm1->add_instruction(migraphx::op::scalar{{2, 2}}, mm1->add_literal(1));
        mm1->add_instruction(pass_op{}, one);
Paul's avatar
Paul committed
112
    }
113
    run_pass(p1);
Paul's avatar
Paul committed
114
115
116

    migraphx::program p2;
    {
117
118
119
        auto* mm2 = p2.get_main_module();
        auto one  = mm2->add_instruction(migraphx::op::scalar{{2, 2}}, mm2->add_literal(1));
        mm2->add_instruction(pass_op{}, one);
Paul's avatar
Paul committed
120
121
122
123
    }
    EXPECT(p1 == p2);
}

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