propagate_constant_test.cpp 3.12 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, {migraphx::propagate_constant{}, migraphx::dead_code_elimination{}});
}
Paul's avatar
Paul committed
14

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

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

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

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

Paul's avatar
Paul committed
45
TEST_CASE(const_multiadd)
Paul's avatar
Paul committed
46
{
Paul's avatar
Paul committed
47
    migraphx::program p1;
Paul's avatar
Paul committed
48
49
    auto one  = p1.add_literal(1);
    auto two  = p1.add_literal(2);
Paul's avatar
Paul committed
50
51
    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
52
    p1.add_instruction(pass_op{}, sum2);
53
    run_pass(p1);
Paul's avatar
Paul committed
54

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

Paul's avatar
Paul committed
61
TEST_CASE(const_add_mul)
Paul's avatar
Paul committed
62
63
64
65
{
    migraphx::program p1;
    auto one  = p1.add_literal(1);
    auto two  = p1.add_literal(2);
Paul's avatar
Paul committed
66
    auto mul  = p1.add_instruction(migraphx::op::mul{}, two, two);
Paul's avatar
Paul committed
67
68
69
    auto sum1 = p1.add_instruction(migraphx::op::add{}, one, mul);
    auto sum2 = p1.add_instruction(migraphx::op::add{}, sum1, two);
    p1.add_instruction(pass_op{}, sum2);
70
    run_pass(p1);
Paul's avatar
Paul committed
71
72
73
74
75
76
77

    migraphx::program p2;
    auto total = p2.add_literal(7);
    p2.add_instruction(pass_op{}, total);
    EXPECT(p1 == p2);
}

Paul's avatar
Paul committed
78
79
80
TEST_CASE(const_add_scalar)
{
    migraphx::program p1;
Paul's avatar
Paul committed
81
82
    auto one = p1.add_instruction(migraphx::op::scalar{{2, 2}}, p1.add_literal(1));
    auto two = p1.add_instruction(migraphx::op::scalar{{2, 2}}, p1.add_literal(2));
Paul's avatar
Paul committed
83
84
    auto sum = p1.add_instruction(migraphx::op::add{}, one, two);
    p1.add_instruction(pass_op{}, sum);
85
    run_pass(p1);
Paul's avatar
Paul committed
86
87

    migraphx::program p2;
Paul's avatar
Paul committed
88
89
    auto total =
        p2.add_literal(migraphx::literal{{migraphx::shape::int32_type, {2, 2}}, {3, 3, 3, 3}});
Paul's avatar
Paul committed
90
91
92
93
94
95
96
97
    p2.add_instruction(pass_op{}, total);
    EXPECT(p1 == p2);
}

TEST_CASE(const_scalar)
{
    migraphx::program p1;
    {
Paul's avatar
Paul committed
98
        auto one = p1.add_instruction(migraphx::op::scalar{{2, 2}}, p1.add_literal(1));
Paul's avatar
Paul committed
99
100
        p1.add_instruction(pass_op{}, one);
    }
101
    run_pass(p1);
Paul's avatar
Paul committed
102
103
104

    migraphx::program p2;
    {
Paul's avatar
Paul committed
105
        auto one = p2.add_instruction(migraphx::op::scalar{{2, 2}}, p2.add_literal(1));
Paul's avatar
Paul committed
106
107
108
109
110
        p2.add_instruction(pass_op{}, one);
    }
    EXPECT(p1 == p2);
}

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