eliminate_contiguous_test.cpp 4.91 KB
Newer Older
Paul's avatar
Paul committed
1
2
#include <migraphx/eliminate_contiguous.hpp>
#include <migraphx/dead_code_elimination.hpp>
3
#include <migraphx/pass_manager.hpp>
4
#include <basic_ops.hpp>
5
6
#include <migraphx/make_op.hpp>

7
8
#include <test.hpp>

9
void run_pass(migraphx::program& p)
10
{
11
12
    migraphx::run_passes(*p.get_main_module(),
                         {migraphx::eliminate_contiguous{}, migraphx::dead_code_elimination{}});
13
}
14

Paul's avatar
Paul committed
15
TEST_CASE(standard_op)
16
{
Paul's avatar
Paul committed
17
    migraphx::program p;
18
19
20

    auto* mm = p.get_main_module();
    auto l   = mm->add_parameter("x", {migraphx::shape::float_type, {2, 2}});
21
22
    auto t   = mm->add_instruction(migraphx::make_op("transpose", {{"dims", {1, 0}}}), l);
    auto c   = mm->add_instruction(migraphx::make_op("contiguous"), t);
23
    mm->add_instruction(pass_standard_op{}, c);
Shucai Xiao's avatar
Shucai Xiao committed
24
    auto count = std::distance(mm->begin(), mm->end());
25
    run_pass(p);
Shucai Xiao's avatar
Shucai Xiao committed
26
    EXPECT(std::distance(mm->begin(), mm->end()) == count);
27
28
}

Paul's avatar
Paul committed
29
TEST_CASE(standard_op_const)
30
{
Paul's avatar
Paul committed
31
    migraphx::program p;
32
33
34

    auto* mm = p.get_main_module();
    auto l   = mm->add_literal(get_2x2());
35
36
    auto t   = mm->add_instruction(migraphx::make_op("transpose", {{"dims", {1, 0}}}), l);
    auto c   = mm->add_instruction(migraphx::make_op("contiguous"), t);
37
    mm->add_instruction(pass_standard_op{}, c);
38
    run_pass(p);
Shucai Xiao's avatar
Shucai Xiao committed
39
    EXPECT(std::distance(mm->begin(), mm->end()) == 2);
Paul's avatar
Paul committed
40
41
42
43
44
}

TEST_CASE(non_standard_op)
{
    migraphx::program p;
45
46
47

    auto* mm = p.get_main_module();
    auto l   = mm->add_parameter("x", {migraphx::shape::float_type, {2, 2}});
48
49
    auto t   = mm->add_instruction(migraphx::make_op("transpose", {{"dims", {1, 0}}}), l);
    auto c   = mm->add_instruction(migraphx::make_op("contiguous"), t);
50
    mm->add_instruction(pass_op{}, c);
Shucai Xiao's avatar
Shucai Xiao committed
51
    auto count = std::distance(mm->begin(), mm->end());
52
    run_pass(p);
Shucai Xiao's avatar
Shucai Xiao committed
53
    EXPECT(std::distance(mm->begin(), mm->end()) == count);
54
55
}

Paul's avatar
Paul committed
56
57
58
TEST_CASE(non_standard_op_const)
{
    migraphx::program p;
59
60
61

    auto* mm = p.get_main_module();
    auto l   = mm->add_literal(get_2x2());
62
63
    auto t   = mm->add_instruction(migraphx::make_op("transpose", {{"dims", {1, 0}}}), l);
    auto c   = mm->add_instruction(migraphx::make_op("contiguous"), t);
64
    mm->add_instruction(pass_op{}, c);
65
    run_pass(p);
Shucai Xiao's avatar
Shucai Xiao committed
66
    EXPECT(std::distance(mm->begin(), mm->end()) == 2);
Paul's avatar
Paul committed
67
68
}

69
70
71
TEST_CASE(transpose_gemm)
{
    migraphx::program p;
72
73
74

    auto* mm = p.get_main_module();
    auto l   = mm->add_literal(get_2x2());
75
76
77
78
    auto t   = mm->add_instruction(migraphx::make_op("transpose", {{"dims", {1, 0}}}), l);
    auto c   = mm->add_instruction(migraphx::make_op("contiguous"), t);
    auto ic  = mm->add_instruction(migraphx::make_op("identity"), c);
    mm->add_instruction(migraphx::make_op("dot"), ic, l);
Shucai Xiao's avatar
Shucai Xiao committed
79
    auto count = std::distance(mm->begin(), mm->end());
80
    run_pass(p);
Shucai Xiao's avatar
Shucai Xiao committed
81
    EXPECT(std::distance(mm->begin(), mm->end()) == (count - 1));
82
83
}

84
85
86
TEST_CASE(transpose_standard_op)
{
    migraphx::program p;
87
88
89

    auto* mm = p.get_main_module();
    auto l   = mm->add_parameter("x", {migraphx::shape::float_type, {2, 2}});
90
91
92
    auto t   = mm->add_instruction(migraphx::make_op("transpose", {{"dims", {1, 0}}}), l);
    auto c   = mm->add_instruction(migraphx::make_op("contiguous"), t);
    auto sn  = mm->add_instruction(migraphx::make_op("sin"), c);
93
    mm->add_instruction(pass_standard_op{}, sn);
Shucai Xiao's avatar
Shucai Xiao committed
94
    auto count = std::distance(mm->begin(), mm->end());
95
    run_pass(p);
Shucai Xiao's avatar
Shucai Xiao committed
96
    EXPECT(std::distance(mm->begin(), mm->end()) == count);
97
98
}

Paul's avatar
Paul committed
99
100
101
TEST_CASE(transpose_standard_op_const)
{
    migraphx::program p;
102
103
104

    auto* mm = p.get_main_module();
    auto l   = mm->add_literal(get_2x2());
105
106
107
    auto t   = mm->add_instruction(migraphx::make_op("transpose", {{"dims", {1, 0}}}), l);
    auto c   = mm->add_instruction(migraphx::make_op("contiguous"), t);
    auto sn  = mm->add_instruction(migraphx::make_op("sin"), c);
108
    mm->add_instruction(pass_standard_op{}, sn);
109
    run_pass(p);
Shucai Xiao's avatar
Shucai Xiao committed
110
    EXPECT(std::distance(mm->begin(), mm->end()) == 3);
Paul's avatar
Paul committed
111
112
}

113
114
115
TEST_CASE(no_packed_unary_op)
{
    migraphx::program p;
116
117
118

    auto* mm = p.get_main_module();
    auto l   = mm->add_literal(get_2x2());
119
120
121
122
    auto t   = mm->add_instruction(
        migraphx::make_op("slice", {{"axes", {1}}, {"starts", {1}}, {"ends", {2}}}), l);
    auto c  = mm->add_instruction(migraphx::make_op("contiguous"), t);
    auto sn = mm->add_instruction(migraphx::make_op("sin"), c);
123
    mm->add_instruction(pass_standard_op{}, sn);
Shucai Xiao's avatar
Shucai Xiao committed
124
    auto count = std::distance(mm->begin(), mm->end());
125
    run_pass(p);
Shucai Xiao's avatar
Shucai Xiao committed
126
    EXPECT(std::distance(mm->begin(), mm->end()) == count - 1);
127
128
}

129
130
131
TEST_CASE(non_standard_return_input)
{
    migraphx::program p;
132
133
134

    auto* mm = p.get_main_module();
    auto l   = mm->add_literal(get_2x2());
135
136
    auto tl  = mm->add_instruction(migraphx::make_op("transpose", {{"dims", {1, 0}}}), l);
    auto c   = mm->add_instruction(migraphx::make_op("contiguous"), tl);
137
    mm->add_return({c});
Shucai Xiao's avatar
Shucai Xiao committed
138
    auto count = std::distance(mm->begin(), mm->end());
139
    run_pass(p);
Shucai Xiao's avatar
Shucai Xiao committed
140
    EXPECT(std::distance(mm->begin(), mm->end()) == count);
141
142
}

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