normalize_ops_test.cpp 4.75 KB
Newer Older
Shucai Xiao's avatar
Shucai Xiao committed
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
#include <migraphx/normalize_ops.hpp>
#include <migraphx/dead_code_elimination.hpp>
#include <migraphx/pass_manager.hpp>
#include <migraphx/make_op.hpp>
#include <migraphx/functional.hpp>
#include <migraphx/op/normalize_attribute.hpp>
#include <basic_ops.hpp>
#include <test.hpp>

struct normalize_test_op
{
    std::vector<int64_t> axes = {};

    template <class Self, class F>
    static auto reflect(Self& self, F f)
    {
        return migraphx::pack(f(self.axes, "axes"));
    }

    migraphx::value attributes() const
    {
        migraphx::value normalize;
        normalize["axes"] = migraphx::value::array{migraphx::op::normalize_attribute::clip_max,
                                                   migraphx::op::normalize_attribute::clip_min};
        return {{"normalize_axes", normalize}};
    }

    std::string name() const { return "normalize_ops_test::test_op"; }
    migraphx::shape normalize_compute_shape(std::vector<migraphx::shape> inputs) const
    {
        return inputs[0];
    }
    migraphx::argument compute(migraphx::context&,
                               const migraphx::shape& output_shape,
                               const std::vector<migraphx::argument>&) const
    {
        return {output_shape};
    }
};

Paul Fultz II's avatar
Paul Fultz II committed
41
void run_pass(migraphx::module& m)
Shucai Xiao's avatar
Shucai Xiao committed
42
{
Paul Fultz II's avatar
Paul Fultz II committed
43
    migraphx::run_passes(m, {migraphx::normalize_ops{}, migraphx::dead_code_elimination{}});
Shucai Xiao's avatar
Shucai Xiao committed
44
45
}

Paul Fultz II's avatar
Paul Fultz II committed
46
migraphx::module create_gather(int64_t axis)
Shucai Xiao's avatar
Shucai Xiao committed
47
{
Paul Fultz II's avatar
Paul Fultz II committed
48
    migraphx::module m;
Shucai Xiao's avatar
Shucai Xiao committed
49
50
    migraphx::shape sd{migraphx::shape::float_type, {2, 3, 4}};
    migraphx::shape si{migraphx::shape::int64_type, {2, 3}};
Paul Fultz II's avatar
Paul Fultz II committed
51
52
53
54
    auto di = m.add_parameter("data", sd);
    auto ii = m.add_parameter("ind", si);
    auto r  = m.add_instruction(migraphx::make_op("gather", {{"axis", axis}}), di, ii);
    m.add_return({r});
Shucai Xiao's avatar
Shucai Xiao committed
55

Paul Fultz II's avatar
Paul Fultz II committed
56
    return m;
Shucai Xiao's avatar
Shucai Xiao committed
57
58
59
60
61
}

TEST_CASE(gather_test)
{

Paul Fultz II's avatar
Paul Fultz II committed
62
63
64
    auto m1 = create_gather(-3);
    auto m2 = create_gather(0);
    run_pass(m1);
Shucai Xiao's avatar
Shucai Xiao committed
65

Paul Fultz II's avatar
Paul Fultz II committed
66
    EXPECT(m1 == m2);
Shucai Xiao's avatar
Shucai Xiao committed
67
68
69
70
}

TEST_CASE(gather_test_1)
{
Paul Fultz II's avatar
Paul Fultz II committed
71
72
73
    auto m1 = create_gather(1);
    auto m2 = create_gather(1);
    run_pass(m1);
Shucai Xiao's avatar
Shucai Xiao committed
74

Paul Fultz II's avatar
Paul Fultz II committed
75
    EXPECT(m1 == m2);
Shucai Xiao's avatar
Shucai Xiao committed
76
77
}

kahmed10's avatar
kahmed10 committed
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
migraphx::module create_padded_op(const std::vector<size_t>& pad_vals)
{
    migraphx::module m;
    migraphx::shape s{migraphx::shape::float_type, {2, 3, 4, 5}};
    auto si = m.add_parameter("data", s);
    auto r  = m.add_instruction(migraphx::make_op("pooling", {{"padding", pad_vals}}), si);
    m.add_return({r});

    return m;
}

TEST_CASE(padding_attr_test)
{
    migraphx::module m1 = create_padded_op({0, 1});
    migraphx::module m2 = create_padded_op({0, 1, 0, 1});
    run_pass(m1);

    EXPECT(m1 == m2);
}

Paul Fultz II's avatar
Paul Fultz II committed
98
migraphx::module create_reduce_mean(const std::vector<int64_t>& axes)
Shucai Xiao's avatar
Shucai Xiao committed
99
{
Paul Fultz II's avatar
Paul Fultz II committed
100
    migraphx::module m;
Shucai Xiao's avatar
Shucai Xiao committed
101
    migraphx::shape s{migraphx::shape::float_type, {2, 3, 4, 5}};
Paul Fultz II's avatar
Paul Fultz II committed
102
103
104
    auto si = m.add_parameter("data", s);
    auto r  = m.add_instruction(migraphx::make_op("reduce_mean", {{"axes", axes}}), si);
    m.add_return({r});
Shucai Xiao's avatar
Shucai Xiao committed
105

Paul Fultz II's avatar
Paul Fultz II committed
106
    return m;
Shucai Xiao's avatar
Shucai Xiao committed
107
108
109
110
}

TEST_CASE(reduce_mean_test)
{
Paul Fultz II's avatar
Paul Fultz II committed
111
112
113
    migraphx::module m1 = create_reduce_mean({0, 1, -1});
    migraphx::module m2 = create_reduce_mean({0, 1, 3});
    run_pass(m1);
Shucai Xiao's avatar
Shucai Xiao committed
114

Paul Fultz II's avatar
Paul Fultz II committed
115
    EXPECT(m1 == m2);
Shucai Xiao's avatar
Shucai Xiao committed
116
117
118
119
}

TEST_CASE(reduce_mean_test_1)
{
Paul Fultz II's avatar
Paul Fultz II committed
120
121
122
    migraphx::module m1 = create_reduce_mean({0, 1, 2});
    migraphx::module m2 = create_reduce_mean({0, 1, 2});
    run_pass(m1);
Shucai Xiao's avatar
Shucai Xiao committed
123

Paul Fultz II's avatar
Paul Fultz II committed
124
    EXPECT(m1 == m2);
Shucai Xiao's avatar
Shucai Xiao committed
125
126
}

Paul Fultz II's avatar
Paul Fultz II committed
127
128
129
migraphx::module create_slice(const std::vector<int64_t>& axes,
                              const std::vector<int64_t>& starts,
                              const std::vector<int64_t>& ends)
Shucai Xiao's avatar
Shucai Xiao committed
130
{
Paul Fultz II's avatar
Paul Fultz II committed
131
    migraphx::module m;
Shucai Xiao's avatar
Shucai Xiao committed
132
    migraphx::shape s{migraphx::shape::float_type, {2, 3, 4, 5}};
Paul Fultz II's avatar
Paul Fultz II committed
133
134
    auto si = m.add_parameter("data", s);
    auto r  = m.add_instruction(
Shucai Xiao's avatar
Shucai Xiao committed
135
        migraphx::make_op("slice", {{"axes", axes}, {"starts", starts}, {"ends", ends}}), si);
Paul Fultz II's avatar
Paul Fultz II committed
136
    m.add_return({r});
Shucai Xiao's avatar
Shucai Xiao committed
137

Paul Fultz II's avatar
Paul Fultz II committed
138
    return m;
Shucai Xiao's avatar
Shucai Xiao committed
139
140
141
142
}

TEST_CASE(slice_test)
{
Paul Fultz II's avatar
Paul Fultz II committed
143
144
145
    migraphx::module m1 = create_slice({0, 1, -1}, {-5, 1, -3}, {2, 2, 8});
    migraphx::module m2 = create_slice({0, 1, 3}, {0, 1, 2}, {2, 2, 5});
    run_pass(m1);
Shucai Xiao's avatar
Shucai Xiao committed
146

Paul Fultz II's avatar
Paul Fultz II committed
147
    EXPECT(m1 == m2);
Shucai Xiao's avatar
Shucai Xiao committed
148
149
150
151
}

TEST_CASE(slice_test_1)
{
Paul Fultz II's avatar
Paul Fultz II committed
152
153
154
    migraphx::module m1 = create_slice({0, 1, 3}, {0, 1, -3}, {1, 2, 5});
    migraphx::module m2 = create_slice({0, 1, 3}, {0, 1, 2}, {1, 2, 5});
    run_pass(m1);
Shucai Xiao's avatar
Shucai Xiao committed
155

Paul Fultz II's avatar
Paul Fultz II committed
156
    EXPECT(m1 == m2);
Shucai Xiao's avatar
Shucai Xiao committed
157
158
}

Paul Fultz II's avatar
Paul Fultz II committed
159
migraphx::module create_test_op(const std::vector<int64_t>& axes)
Shucai Xiao's avatar
Shucai Xiao committed
160
{
Paul Fultz II's avatar
Paul Fultz II committed
161
    migraphx::module m;
Shucai Xiao's avatar
Shucai Xiao committed
162
    migraphx::shape sd{migraphx::shape::float_type, {2, 3, 4}};
Paul Fultz II's avatar
Paul Fultz II committed
163
164
165
    auto di = m.add_parameter("data", sd);
    auto r  = m.add_instruction(normalize_test_op{axes}, di);
    m.add_return({r});
Shucai Xiao's avatar
Shucai Xiao committed
166

Paul Fultz II's avatar
Paul Fultz II committed
167
    return m;
Shucai Xiao's avatar
Shucai Xiao committed
168
169
170
171
172
}

TEST_CASE(test_op)
{
    std::vector<int64_t> axes1 = {-4, 5};
Paul Fultz II's avatar
Paul Fultz II committed
173
    auto m1                    = create_test_op(axes1);
Shucai Xiao's avatar
Shucai Xiao committed
174
175

    std::vector<int64_t> axes2 = {1, 2};
Paul Fultz II's avatar
Paul Fultz II committed
176
    auto m2                    = create_test_op(axes2);
Shucai Xiao's avatar
Shucai Xiao committed
177

Paul Fultz II's avatar
Paul Fultz II committed
178
179
    run_pass(m1);
    EXPECT(m1 == m2);
Shucai Xiao's avatar
Shucai Xiao committed
180
181
182
}

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