test_rsqrt.cpp 1 KB
Newer Older
1
2
3
4

#include "verify_program.hpp"
#include <migraphx/program.hpp>
#include <migraphx/generate.hpp>
5
#include <migraphx/make_op.hpp>
6
7
8
9
10
11

struct test_rsqrt : verify_program<test_rsqrt>
{
    migraphx::program create_program() const
    {
        migraphx::program p;
12
        auto* mm = p.get_main_module();
13
14
        std::vector<size_t> input_lens{1, 3, 16, 16};
        migraphx::shape s{migraphx::shape::float_type, input_lens};
15
16
17
        auto x       = mm->add_parameter("x", s);
        auto min_val = mm->add_literal(1.0f);
        auto max_val = mm->add_literal(std::numeric_limits<float>::max());
18
        min_val      = mm->add_instruction(
19
            migraphx::make_op("multibroadcast", {{"out_lens", input_lens}}), min_val);
20
        max_val = mm->add_instruction(
21
            migraphx::make_op("multibroadcast", {{"out_lens", input_lens}}), max_val);
22
23
        auto l0 = mm->add_instruction(migraphx::make_op("clip"), x, min_val, max_val);
        mm->add_instruction(migraphx::make_op("rsqrt"), l0);
24
25
26
        return p;
    };
};