"megatron/vscode:/vscode.git/clone" did not exist on "b886b7bb972afe72bac0f5de4f42a4a7bae8ebef"
rewrite_pooling_test.cpp 8.12 KB
Newer Older
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
/*
 * The MIT License (MIT)
 *
 * Copyright (c) 2015-2022 Advanced Micro Devices, Inc. All rights reserved.
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this software and associated documentation files (the "Software"), to deal
 * in the Software without restriction, including without limitation the rights
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 * copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in
 * all copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 * THE SOFTWARE.
 */
Shucai Xiao's avatar
Shucai Xiao committed
24
#include <migraphx/rewrite_pooling.hpp>
25
#include <migraphx/op/pooling.hpp>
Shucai Xiao's avatar
Shucai Xiao committed
26
27
#include <migraphx/dead_code_elimination.hpp>
#include <migraphx/program.hpp>
28
#include <migraphx/ref/target.hpp>
Shucai Xiao's avatar
Shucai Xiao committed
29
30
31
32
#include <migraphx/instruction.hpp>
#include <migraphx/generate.hpp>
#include <migraphx/ranges.hpp>
#include <test.hpp>
33
34
#include <migraphx/make_op.hpp>

Shucai Xiao's avatar
Shucai Xiao committed
35
36
37
#include <migraphx/verify.hpp>

bool is_pooling(migraphx::instruction& ins) { return ins.name() == "pooling"; }
Paul Fultz II's avatar
Paul Fultz II committed
38
static void opt_pooling(migraphx::module& m)
Shucai Xiao's avatar
Shucai Xiao committed
39
40
41
{
    migraphx::rewrite_pooling rp;
    migraphx::dead_code_elimination dce;
Paul Fultz II's avatar
Paul Fultz II committed
42
43
    rp.apply(m);
    dce.apply(m);
Shucai Xiao's avatar
Shucai Xiao committed
44
45
46
47
48
}

TEST_CASE(rewrite_pooling_test)
{
    migraphx::shape s{migraphx::shape::float_type, {2, 2, 3, 4, 5}};
49
    auto pooling_program = [&](const migraphx::op::pooling_mode mode) {
Paul Fultz II's avatar
Paul Fultz II committed
50
51
52
53
54
55
56
57
58
59
        migraphx::module m;
        auto input = m.add_parameter("x", s);
        auto ret   = m.add_instruction(migraphx::make_op("pooling",
                                                       {{"mode", mode},
                                                        {"padding", {0, 0, 0}},
                                                        {"stride", {1, 1, 1}},
                                                        {"lengths", {3, 4, 5}}}),
                                     input);
        m.add_return({ret});
        return m;
Shucai Xiao's avatar
Shucai Xiao committed
60
61
62
    };

    auto opt_program = [&](const migraphx::operation& reduce_op) {
Paul Fultz II's avatar
Paul Fultz II committed
63
64
65
66
        migraphx::module m;
        auto input = m.add_parameter("x", s);
        auto rsp   = m.add_instruction(migraphx::make_op("reshape", {{"dims", {4, -1}}}), input);
        auto rdm   = m.add_instruction(reduce_op, rsp);
67
        auto ret =
Paul Fultz II's avatar
Paul Fultz II committed
68
69
70
            m.add_instruction(migraphx::make_op("reshape", {{"dims", {2, 2, 1, 1, 1}}}), rdm);
        m.add_return({ret});
        return m;
Shucai Xiao's avatar
Shucai Xiao committed
71
72
    };

73
    auto test_rewrite = [&](const migraphx::op::pooling_mode mode, const migraphx::operation& op) {
Paul Fultz II's avatar
Paul Fultz II committed
74
75
76
77
        migraphx::module m1 = pooling_program(mode);
        migraphx::module m2 = opt_program(op);
        opt_pooling(m1);
        EXPECT(m1 == m2);
Shucai Xiao's avatar
Shucai Xiao committed
78
79
    };

80
81
82
    test_rewrite(migraphx::op::pooling_mode::average,
                 migraphx::make_op("reduce_mean", {{"axes", {1}}}));
    test_rewrite(migraphx::op::pooling_mode::max, migraphx::make_op("reduce_max", {{"axes", {1}}}));
Shucai Xiao's avatar
Shucai Xiao committed
83
84
85
86
87
88
}

TEST_CASE(rewrite_avepooling_na1_test)
{
    migraphx::shape s{migraphx::shape::float_type, {2, 2, 3, 4, 5}};
    auto pooling_program = [&]() {
Paul Fultz II's avatar
Paul Fultz II committed
89
90
91
        migraphx::module m;

        auto input = m.add_parameter("x", s);
92
93
94
95
96
97
98
        auto ret =
            m.add_instruction(migraphx::make_op("pooling",
                                                {{"mode", migraphx::op::pooling_mode::average},
                                                 {"padding", {0, 1, 0}},
                                                 {"stride", {1, 1, 1}},
                                                 {"lengths", {3, 4, 5}}}),
                              input);
Paul Fultz II's avatar
Paul Fultz II committed
99
100
        m.add_return({ret});
        return m;
Shucai Xiao's avatar
Shucai Xiao committed
101
102
    };

Paul Fultz II's avatar
Paul Fultz II committed
103
104
    migraphx::module m1 = pooling_program();
    migraphx::module m2 = m1;
105

Paul Fultz II's avatar
Paul Fultz II committed
106
107
    opt_pooling(m1);
    EXPECT(m1 == m2);
Shucai Xiao's avatar
Shucai Xiao committed
108
109
110
111
112
113
}

TEST_CASE(rewrite_avepooling_na2_test)
{
    migraphx::shape s{migraphx::shape::float_type, {2, 2, 3, 4, 5}};
    auto pooling_program = [&]() {
Paul Fultz II's avatar
Paul Fultz II committed
114
115
116
        migraphx::module m;

        auto input = m.add_parameter("x", s);
117
118
119
120
121
122
123
        auto ret =
            m.add_instruction(migraphx::make_op("pooling",
                                                {{"mode", migraphx::op::pooling_mode::average},
                                                 {"padding", {0, 0, 0}},
                                                 {"stride", {1, 2, 1}},
                                                 {"lengths", {3, 4, 5}}}),
                              input);
Paul Fultz II's avatar
Paul Fultz II committed
124
125
        m.add_return({ret});
        return m;
Shucai Xiao's avatar
Shucai Xiao committed
126
127
    };

Paul Fultz II's avatar
Paul Fultz II committed
128
129
    migraphx::module m1 = pooling_program();
    migraphx::module m2 = m1;
130

Paul Fultz II's avatar
Paul Fultz II committed
131
132
    opt_pooling(m1);
    EXPECT(m1 == m2);
Shucai Xiao's avatar
Shucai Xiao committed
133
134
135
136
137
138
}

TEST_CASE(rewrite_avepooling_na3_test)
{
    migraphx::shape s{migraphx::shape::float_type, {2, 2, 3, 4, 5}};
    auto pooling_program = [&]() {
Paul Fultz II's avatar
Paul Fultz II committed
139
140
141
142
        migraphx::module m;

        auto input = m.add_parameter("x", s);
        auto ret   = m.add_instruction(migraphx::make_op("pooling",
143
                                                       {{"mode", migraphx::op::pooling_mode::max},
Paul Fultz II's avatar
Paul Fultz II committed
144
145
146
147
148
149
                                                        {"padding", {0, 0, 0}},
                                                        {"stride", {1, 1, 1}},
                                                        {"lengths", {3, 3, 5}}}),
                                     input);
        m.add_return({ret});
        return m;
Shucai Xiao's avatar
Shucai Xiao committed
150
151
    };

Paul Fultz II's avatar
Paul Fultz II committed
152
153
    migraphx::module m1 = pooling_program();
    migraphx::module m2 = m1;
154

Paul Fultz II's avatar
Paul Fultz II committed
155
156
    opt_pooling(m1);
    EXPECT(m1 == m2);
Shucai Xiao's avatar
Shucai Xiao committed
157
158
159
160
161
162
163
164
}

TEST_CASE(literal_rewrite_pooling_test)
{
    migraphx::shape s{migraphx::shape::float_type, {2, 2, 3, 4, 5}};
    std::vector<float> data(s.elements());
    std::iota(data.begin(), data.end(), 1.0f);

165
    auto pooling_program = [&](const migraphx::op::pooling_mode mode) {
Shucai Xiao's avatar
Shucai Xiao committed
166
        migraphx::program p;
167
168
169

        auto* mm   = p.get_main_module();
        auto input = mm->add_literal(migraphx::literal(s, data));
170
171
172
173
174
        auto ret   = mm->add_instruction(migraphx::make_op("pooling",
                                                         {{"mode", mode},
                                                          {"padding", {0, 0, 0}},
                                                          {"stride", {1, 1, 1}},
                                                          {"lengths", {3, 4, 5}}}),
175
176
                                       input);
        mm->add_return({ret});
Shucai Xiao's avatar
Shucai Xiao committed
177
178
179
180
181
        return p;
    };

    auto opt_program = [&](const migraphx::operation& op) {
        migraphx::program p;
182
183
        auto* mm   = p.get_main_module();
        auto input = mm->add_literal(migraphx::literal(s, data));
184
        auto rsp   = mm->add_instruction(migraphx::make_op("reshape", {{"dims", {4, -1}}}), input);
185
        auto rdm   = mm->add_instruction(op, rsp);
186
187
        auto ret =
            mm->add_instruction(migraphx::make_op("reshape", {{"dims", {2, 2, 1, 1, 1}}}), rdm);
188
        mm->add_return({ret});
Shucai Xiao's avatar
Shucai Xiao committed
189
190
191
192

        return p;
    };

193
194
    auto test_rewrite_pooling = [&](const migraphx::op::pooling_mode mode,
                                    const migraphx::operation& op) {
Shucai Xiao's avatar
Shucai Xiao committed
195
196
        migraphx::program p1 = pooling_program(mode);
        migraphx::program p2 = opt_program(op);
197
198
        p1.compile(migraphx::ref::target{});
        p2.compile(migraphx::ref::target{});
Shucai Xiao's avatar
Shucai Xiao committed
199
200
201
202
203
204
        auto result1 = p1.eval({}).back();
        auto result2 = p2.eval({}).back();
        visit_all(result1,
                  result2)([&](auto r1, auto r2) { EXPECT(migraphx::verify_range(r1, r2)); });
    };

205
206
207
208
    test_rewrite_pooling(migraphx::op::pooling_mode::max,
                         migraphx::make_op("reduce_max", {{"axes", {1}}}));
    test_rewrite_pooling(migraphx::op::pooling_mode::average,
                         migraphx::make_op("reduce_mean", {{"axes", {1}}}));
Shucai Xiao's avatar
Shucai Xiao committed
209
210
211
}

int main(int argc, const char* argv[]) { test::run(argc, argv); }