test_conv_bias_clipped_relu.cpp 1.63 KB
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/instruction.hpp>

struct test_conv_bias_clipped_relu : verify_program<test_conv_bias_clipped_relu>
{
    migraphx::program create_program() const
    {
        migraphx::program p;
14
        auto* mm = p.get_main_module();
15
16
        std::vector<size_t> input_lens{4, 3, 3, 3};
        auto input =
17
            mm->add_parameter("x", migraphx::shape{migraphx::shape::float_type, {4, 3, 3, 3}});
18
        auto weights =
19
            mm->add_parameter("w", migraphx::shape{migraphx::shape::float_type, {4, 3, 3, 3}});
20
        auto l0        = migraphx::literal{migraphx::shape{migraphx::shape::float_type, {4}},
21
                                    {2.0f, 2.0f, 2.0f, 2.0f}};
22
23
24
25
26
27
        auto bias      = mm->add_literal(l0);
        auto conv      = mm->add_instruction(migraphx::make_op("convolution"), input, weights);
        auto bcast_add = mm->add_instruction(
            migraphx::make_op("broadcast", {{"axis", 1}, {"dims", conv->get_shape().lens()}}),
            bias);
        auto bias_add = mm->add_instruction(migraphx::make_op("add"), conv, bcast_add);
28
29
        auto min_val  = mm->add_literal(0.0f);
        auto max_val  = mm->add_literal(6.0f);
30
31
32
33
34
        min_val       = mm->add_instruction(
            migraphx::make_op("multibroadcast", {{"output_lens", input_lens}}), min_val);
        max_val = mm->add_instruction(
            migraphx::make_op("multibroadcast", {{"output_lens", input_lens}}), max_val);
        mm->add_instruction(migraphx::make_op("clip"), bias_add, min_val, max_val);
35
36
37
        return p;
    }
};