test_gpu.cpp 4.91 KB
Newer Older
Shucai Xiao's avatar
Shucai Xiao committed
1
#include <numeric>
Paul Fultz II's avatar
Paul Fultz II committed
2
3
4
5
6
7
8
9
#include <migraphx/migraphx.h>
#include <migraphx/migraphx.hpp>
#include "test.hpp"

TEST_CASE(load_and_run)
{
    auto p             = migraphx::parse_onnx("conv_relu_maxpool_test.onnx");
    auto shapes_before = p.get_output_shapes();
10
11
    migraphx::compile_options options;
    options.set_offload_copy();
Paul Fultz II's avatar
Paul Fultz II committed
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
    p.compile(migraphx::target("gpu"), options);
    auto shapes_after = p.get_output_shapes();
    CHECK(shapes_before.size() == 1);
    CHECK(shapes_before.size() == shapes_after.size());
    CHECK(bool{shapes_before.front() == shapes_after.front()});
    migraphx::program_parameters pp;
    auto param_shapes = p.get_parameter_shapes();
    for(auto&& name : param_shapes.names())
    {
        pp.add(name, migraphx::argument::generate(param_shapes[name]));
    }
    auto outputs = p.eval(pp);
    CHECK(shapes_before.size() == outputs.size());
    CHECK(bool{shapes_before.front() == outputs.front().get_shape()});
}

Shucai Xiao's avatar
Shucai Xiao committed
28
29
30
31
32
TEST_CASE(if_pl_test)
{
    auto run_prog = [&](auto cond) {
        auto p             = migraphx::parse_onnx("if_pl_test.onnx");
        auto shapes_before = p.get_output_shapes();
33
34
        migraphx::compile_options options;
        options.set_offload_copy();
Shucai Xiao's avatar
Shucai Xiao committed
35
36
37
38
39
40
41
42
43
44
45
46
47
        p.compile(migraphx::target("gpu"), options);
        auto shapes_after = p.get_output_shapes();
        CHECK(shapes_before.size() == 1);
        CHECK(bool{shapes_before.front() == shapes_after.front()});

        migraphx::program_parameters pp;
        auto param_shapes = p.get_parameter_shapes();
        auto xs           = param_shapes["x"];
        std::vector<float> xd(xs.bytes() / sizeof(float), 1.0);
        pp.add("x", migraphx::argument(xs, xd.data()));
        auto ys = param_shapes["y"];
        std::vector<float> yd(ys.bytes() / sizeof(float), 2.0);
        pp.add("y", migraphx::argument(ys, yd.data()));
Paul Fultz II's avatar
Paul Fultz II committed
48
        char ccond = cond;
Shucai Xiao's avatar
Shucai Xiao committed
49
50
51
52
53
54
        pp.add("cond", migraphx::argument(param_shapes["cond"], &ccond));

        auto outputs = p.eval(pp);
        auto output  = outputs[0];
        auto lens    = output.get_shape().lengths();
        auto elem_num =
Shucai Xiao's avatar
Shucai Xiao committed
55
            std::accumulate(lens.begin(), lens.end(), 1, std::multiplies<int>());
Shucai Xiao's avatar
Shucai Xiao committed
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
        float* data_ptr = reinterpret_cast<float*>(output.data());
        std::vector<float> ret(data_ptr, data_ptr + elem_num);

        return ret;
    };

    // then branch
    {
        auto result_vector      = run_prog(true);
        std::vector<float> gold = {2, 3, 4, 5, 6, 7};
        EXPECT(result_vector == gold);
    }

    // else branch
    {
        auto result_vector      = run_prog(false);
        std::vector<float> gold = {1, 2, 3, 4, 5, 6};
        EXPECT(result_vector == gold);
    }
}

Shucai Xiao's avatar
Shucai Xiao committed
77
78
79
80
81
82
83
TEST_CASE(loop_test)
{
    auto run_prog = [&](int64_t max_iter_num) {
        migraphx::onnx_options parse_options;
        parse_options.set_default_loop_iterations(max_iter_num);
        auto p             = migraphx::parse_onnx("loop_default_test.onnx", parse_options);
        auto shapes_before = p.get_output_shapes();
84
85
        migraphx::compile_options options;
        options.set_offload_copy();
Shucai Xiao's avatar
Shucai Xiao committed
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
        p.compile(migraphx::target("gpu"), options);
        auto shapes_after = p.get_output_shapes();
        CHECK(shapes_before.size() == 2);
        CHECK(bool{shapes_before.front() == shapes_after.front()});

        migraphx::program_parameters pp;
        auto param_shapes     = p.get_parameter_shapes();
        auto aas              = param_shapes["a"];
        std::vector<float> xd = {1.0f};
        pp.add("a", migraphx::argument(aas, xd.data()));
        auto bbs              = param_shapes["b"];
        std::vector<float> yd = {2.0};
        pp.add("b", migraphx::argument(bbs, yd.data()));

        auto outputs = p.eval(pp);
        auto output  = outputs[0];
        auto lens    = output.get_shape().lengths();
        auto elem_num =
Shucai Xiao's avatar
Shucai Xiao committed
104
            std::accumulate(lens.begin(), lens.end(), 1, std::multiplies<int>());
Shucai Xiao's avatar
Shucai Xiao committed
105
106
107
108
109
110
        float* data_ptr = reinterpret_cast<float*>(output.data());
        std::vector<std::vector<float>> ret;
        ret.push_back({data_ptr, data_ptr + elem_num});

        output   = outputs[1];
        lens     = output.get_shape().lengths();
Shucai Xiao's avatar
Shucai Xiao committed
111
        elem_num = std::accumulate(lens.begin(), lens.end(), 1, std::multiplies<int>());
Shucai Xiao's avatar
Shucai Xiao committed
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
        data_ptr = reinterpret_cast<float*>(output.data());
        ret.push_back({data_ptr, data_ptr + elem_num});

        return ret;
    };

    {
        auto result_vector       = run_prog(10);
        std::vector<float> gold0 = {2.0f};
        EXPECT(result_vector.at(0) == gold0);
        std::vector<float> gold1 = {-2, 4, 0, 0, 0, 0, 0, 0, 0, 0};
        EXPECT(result_vector.at(1) == gold1);
    }

    {
        auto result_vector       = run_prog(15);
        std::vector<float> gold0 = {2.0f};
        EXPECT(result_vector.at(0) == gold0);
        std::vector<float> gold1 = {-2, 4, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0};
        EXPECT(result_vector.at(1) == gold1);
    }
}

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