"src/targets/gpu/vscode:/vscode.git/clone" did not exist on "c22636712fb304cc9d16c7d47740669910b2ea3e"
eliminate_contiguous_test.cpp 4.38 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>

Paul Fultz II's avatar
Paul Fultz II committed
9
void run_pass(migraphx::module& m)
10
{
11
12
    migraphx::run_passes(
        m, {migraphx::eliminate_contiguous{"contiguous"}, migraphx::dead_code_elimination{}});
13
}
14

Paul's avatar
Paul committed
15
TEST_CASE(standard_op)
16
{
Paul Fultz II's avatar
Paul Fultz II committed
17
18
19
20
21
22
23
24
25
    migraphx::module m;

    auto l = m.add_parameter("x", {migraphx::shape::float_type, {2, 2}});
    auto t = m.add_instruction(migraphx::make_op("transpose", {{"dims", {1, 0}}}), l);
    auto c = m.add_instruction(migraphx::make_op("contiguous"), t);
    m.add_instruction(pass_standard_op{}, c);
    auto count = std::distance(m.begin(), m.end());
    run_pass(m);
    EXPECT(std::distance(m.begin(), m.end()) == count);
26
27
}

Paul's avatar
Paul committed
28
TEST_CASE(standard_op_const)
29
{
Paul Fultz II's avatar
Paul Fultz II committed
30
31
32
33
34
35
36
37
    migraphx::module m;

    auto l = m.add_literal(get_2x2());
    auto t = m.add_instruction(migraphx::make_op("transpose", {{"dims", {1, 0}}}), l);
    auto c = m.add_instruction(migraphx::make_op("contiguous"), t);
    m.add_instruction(pass_standard_op{}, c);
    run_pass(m);
    EXPECT(std::distance(m.begin(), m.end()) == 2);
Paul's avatar
Paul committed
38
39
40
41
}

TEST_CASE(non_standard_op)
{
Paul Fultz II's avatar
Paul Fultz II committed
42
43
44
45
46
47
48
49
50
    migraphx::module m;

    auto l = m.add_parameter("x", {migraphx::shape::float_type, {2, 2}});
    auto t = m.add_instruction(migraphx::make_op("transpose", {{"dims", {1, 0}}}), l);
    auto c = m.add_instruction(migraphx::make_op("contiguous"), t);
    m.add_instruction(pass_op{}, c);
    auto count = std::distance(m.begin(), m.end());
    run_pass(m);
    EXPECT(std::distance(m.begin(), m.end()) == count);
51
52
}

Paul's avatar
Paul committed
53
54
TEST_CASE(non_standard_op_const)
{
Paul Fultz II's avatar
Paul Fultz II committed
55
56
57
58
59
60
61
62
    migraphx::module m;

    auto l = m.add_literal(get_2x2());
    auto t = m.add_instruction(migraphx::make_op("transpose", {{"dims", {1, 0}}}), l);
    auto c = m.add_instruction(migraphx::make_op("contiguous"), t);
    m.add_instruction(pass_op{}, c);
    run_pass(m);
    EXPECT(std::distance(m.begin(), m.end()) == 2);
Paul's avatar
Paul committed
63
64
}

Paul Fultz II's avatar
Paul Fultz II committed
65
TEST_CASE(transpose_gem)
66
{
Paul Fultz II's avatar
Paul Fultz II committed
67
68
69
70
71
72
73
74
75
76
    migraphx::module m;

    auto l  = m.add_literal(get_2x2());
    auto t  = m.add_instruction(migraphx::make_op("transpose", {{"dims", {1, 0}}}), l);
    auto c  = m.add_instruction(migraphx::make_op("contiguous"), t);
    auto ic = m.add_instruction(migraphx::make_op("identity"), c);
    m.add_instruction(migraphx::make_op("dot"), ic, l);
    auto count = std::distance(m.begin(), m.end());
    run_pass(m);
    EXPECT(std::distance(m.begin(), m.end()) == (count - 1));
77
78
}

79
80
TEST_CASE(transpose_standard_op)
{
Paul Fultz II's avatar
Paul Fultz II committed
81
82
83
84
85
86
87
88
89
90
    migraphx::module m;

    auto l  = m.add_parameter("x", {migraphx::shape::float_type, {2, 2}});
    auto t  = m.add_instruction(migraphx::make_op("transpose", {{"dims", {1, 0}}}), l);
    auto c  = m.add_instruction(migraphx::make_op("contiguous"), t);
    auto sn = m.add_instruction(migraphx::make_op("sin"), c);
    m.add_instruction(pass_standard_op{}, sn);
    auto count = std::distance(m.begin(), m.end());
    run_pass(m);
    EXPECT(std::distance(m.begin(), m.end()) == count);
91
92
}

Paul's avatar
Paul committed
93
94
TEST_CASE(transpose_standard_op_const)
{
Paul Fultz II's avatar
Paul Fultz II committed
95
96
97
98
99
100
101
102
103
    migraphx::module m;

    auto l  = m.add_literal(get_2x2());
    auto t  = m.add_instruction(migraphx::make_op("transpose", {{"dims", {1, 0}}}), l);
    auto c  = m.add_instruction(migraphx::make_op("contiguous"), t);
    auto sn = m.add_instruction(migraphx::make_op("sin"), c);
    m.add_instruction(pass_standard_op{}, sn);
    run_pass(m);
    EXPECT(std::distance(m.begin(), m.end()) == 3);
Paul's avatar
Paul committed
104
105
}

106
107
TEST_CASE(no_packed_unary_op)
{
Paul Fultz II's avatar
Paul Fultz II committed
108
    migraphx::module m;
109

Paul Fultz II's avatar
Paul Fultz II committed
110
111
    auto l = m.add_literal(get_2x2());
    auto t = m.add_instruction(
112
        migraphx::make_op("slice", {{"axes", {1}}, {"starts", {1}}, {"ends", {2}}}), l);
Paul Fultz II's avatar
Paul Fultz II committed
113
114
115
116
117
118
    auto c  = m.add_instruction(migraphx::make_op("contiguous"), t);
    auto sn = m.add_instruction(migraphx::make_op("sin"), c);
    m.add_instruction(pass_standard_op{}, sn);
    auto count = std::distance(m.begin(), m.end());
    run_pass(m);
    EXPECT(std::distance(m.begin(), m.end()) == count - 1);
119
120
}

121
122
TEST_CASE(non_standard_return_input)
{
Paul Fultz II's avatar
Paul Fultz II committed
123
124
125
126
127
128
129
130
131
    migraphx::module m;

    auto l  = m.add_literal(get_2x2());
    auto tl = m.add_instruction(migraphx::make_op("transpose", {{"dims", {1, 0}}}), l);
    auto c  = m.add_instruction(migraphx::make_op("contiguous"), tl);
    m.add_return({c});
    auto count = std::distance(m.begin(), m.end());
    run_pass(m);
    EXPECT(std::distance(m.begin(), m.end()) == count);
132
133
}

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