test_fp32_fp16_sub.cpp 800 Bytes
Newer Older
1
2
3
4

#include "verify_program.hpp"
#include <migraphx/program.hpp>
#include <migraphx/generate.hpp>
5
6
#include <migraphx/make_op.hpp>

7
8
9
10
11
12
13
#include <migraphx/quantization.hpp>

struct test_fp32_fp16_sub : verify_program<test_fp32_fp16_sub>
{
    migraphx::program create_program() const
    {
        migraphx::program p;
14
        auto* mm = p.get_main_module();
15
        migraphx::shape s{migraphx::shape::float_type, {2, 3}};
16
17
        auto p1   = mm->add_parameter("x", s);
        auto p2   = mm->add_parameter("y", s);
18
19
20
        auto sum  = mm->add_instruction(migraphx::make_op("add"), p1, p2);
        auto diff = mm->add_instruction(migraphx::make_op("sub"), sum, p2);
        mm->add_instruction(migraphx::make_op("add"), diff, p1);
21
22
23
24
25
        migraphx::quantize_fp16(p, {"sub"});

        return p;
    };
};