quantization.cpp 3.32 KB
Newer Older
Shucai Xiao's avatar
Shucai Xiao committed
1
2
3
4
#include <iostream>
#include <vector>
#include <migraphx/operators.hpp>
#include <migraphx/instruction.hpp>
Shucai Xiao's avatar
Shucai Xiao committed
5
#include <migraphx/quantization.hpp>
Shucai Xiao's avatar
Shucai Xiao committed
6
#include <migraphx/generate.hpp>
7
#include <migraphx/ref/target.hpp>
Shucai Xiao's avatar
Shucai Xiao committed
8
9
10
11
12
13
14
#include <migraphx/gpu/target.hpp>
#include <migraphx/verify.hpp>
#include <migraphx/quantization.hpp>
#include <migraphx/dead_code_elimination.hpp>
#include <migraphx/propagate_constant.hpp>
#include <migraphx/pass_manager.hpp>
#include <migraphx/onnx.hpp>
15
#include <test.hpp>
Shucai Xiao's avatar
Shucai Xiao committed
16
17
#include <migraphx/half.hpp>

Shucai Xiao's avatar
Shucai Xiao committed
18
TEST_CASE(gpu_target_copy)
Shucai Xiao's avatar
Shucai Xiao committed
19
{
Shucai Xiao's avatar
Shucai Xiao committed
20
    migraphx::target gpu_t = migraphx::gpu::target{};
21
    migraphx::target ref_t = migraphx::ref::target{};
Shucai Xiao's avatar
Shucai Xiao committed
22
    migraphx::shape s{migraphx::shape::int8_type, {2, 3, 4, 5}};
Shucai Xiao's avatar
Shucai Xiao committed
23

24
25
26
    auto ref_arg_orig  = migraphx::generate_argument(s, 0x123456L);
    auto gpu_arg       = gpu_t.copy_to(ref_arg_orig);
    auto ref_arg_final = gpu_t.copy_from(gpu_arg);
Shucai Xiao's avatar
Shucai Xiao committed
27

Shucai Xiao's avatar
Shucai Xiao committed
28
    std::vector<int8_t> val_orig;
29
    ref_arg_orig.visit([&](auto v) { val_orig.assign(v.begin(), v.end()); });
Shucai Xiao's avatar
Shucai Xiao committed
30
    std::vector<int8_t> val_final;
31
    ref_arg_final.visit([&](auto v) { val_final.assign(v.begin(), v.end()); });
Shucai Xiao's avatar
Shucai Xiao committed
32

Shucai Xiao's avatar
Shucai Xiao committed
33
    EXPECT(migraphx::verify_range(val_orig, val_final));
Shucai Xiao's avatar
Shucai Xiao committed
34
35
}

Shucai Xiao's avatar
Shucai Xiao committed
36
37
38
39
TEST_CASE(int8_quantization)
{
    auto run_prog = [](migraphx::program p,
                       const migraphx::target& t,
40
                       migraphx::parameter_map& m_in,
Shucai Xiao's avatar
Shucai Xiao committed
41
                       std::vector<float>& res) {
42
        std::vector<migraphx::parameter_map> cali_data;
Shucai Xiao's avatar
Shucai Xiao committed
43
44
45
        cali_data.push_back(m_in);
        migraphx::quantize_int8(p, t, cali_data);
        p.compile(t);
46
        migraphx::parameter_map m;
Shucai Xiao's avatar
Shucai Xiao committed
47
48
49
50
51
52
53
54
55
56
57
58
        for(auto&& x : p.get_parameter_shapes())
        {
            if(m_in.count(x.first) > 0)
            {
                m[x.first] = t.copy_to(m_in[x.first]);
            }
            else
            {
                m[x.first] = t.allocate(x.second);
            }
        }

59
        auto result = t.copy_from(p.eval(m).back());
Shucai Xiao's avatar
Shucai Xiao committed
60
61
62
63
64
        result.visit([&](auto v) { res.assign(v.begin(), v.end()); });
    };

    auto create_program = [] {
        migraphx::program p;
65
        auto* mm = p.get_main_module();
Shucai Xiao's avatar
Shucai Xiao committed
66
        migraphx::shape sa{migraphx::shape::float_type, {5, 16}};
Shucai Xiao's avatar
Shucai Xiao committed
67
        migraphx::shape sb{migraphx::shape::float_type, {16, 8}};
Shucai Xiao's avatar
Shucai Xiao committed
68
        migraphx::shape sc{migraphx::shape::float_type, {5, 8}};
69
70
71
72
        auto pa = mm->add_parameter("a", sa);
        auto pb = mm->add_parameter("b", sb);
        auto pc = mm->add_parameter("c", sc);
        mm->add_instruction(migraphx::op::dot{}, pa, pb, pc);
Shucai Xiao's avatar
Shucai Xiao committed
73
74
75
76
77
78

        return p;
    };

    {
        auto p = create_program();
79
        migraphx::parameter_map m;
Shucai Xiao's avatar
Shucai Xiao committed
80
        migraphx::shape sa{migraphx::shape::float_type, {5, 16}};
Shucai Xiao's avatar
Shucai Xiao committed
81
        migraphx::shape sb{migraphx::shape::float_type, {16, 8}};
Shucai Xiao's avatar
Shucai Xiao committed
82
        migraphx::shape sc{migraphx::shape::float_type, {5, 8}};
Shucai Xiao's avatar
Shucai Xiao committed
83
        m["a"] = migraphx::generate_argument(sa);
Shucai Xiao's avatar
Shucai Xiao committed
84
        m["b"] = migraphx::generate_argument(sb);
Shucai Xiao's avatar
Shucai Xiao committed
85
        m["c"] = migraphx::generate_argument(sc);
86
87
88
        std::vector<float> ref_result;
        migraphx::target ref_t = migraphx::ref::target{};
        run_prog(p, ref_t, m, ref_result);
Shucai Xiao's avatar
Shucai Xiao committed
89
90
91
92
93

        std::vector<float> gpu_result;
        migraphx::target gpu_t = migraphx::gpu::target{};
        run_prog(p, gpu_t, m, gpu_result);

94
        EXPECT(migraphx::verify_range(ref_result, gpu_result));
Shucai Xiao's avatar
Shucai Xiao committed
95
96
97
    }
}

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