test_triadd_broadcast.cpp 918 Bytes
Newer Older
1
2
3
4
5
6
7
8
9
10
11
12

#include "verify_program.hpp"
#include <migraphx/program.hpp>
#include <migraphx/generate.hpp>
#include <migraphx/operators.hpp>
#include <migraphx/instruction.hpp>

struct test_triadd_broadcast : verify_program<test_triadd_broadcast>
{
    migraphx::program create_program() const
    {
        migraphx::program p;
13
        auto* mm = p.get_main_module();
14
        migraphx::shape s{migraphx::shape::float_type, {3}};
15
16
17
18
19
20
        auto x   = mm->add_parameter("x", {migraphx::shape::float_type, {2, 2, 3}});
        auto y   = mm->add_parameter("y", {migraphx::shape::float_type, {2, 2}});
        auto z   = mm->add_parameter("z", {migraphx::shape::float_type, {2, 2, 3}});
        auto by  = mm->add_instruction(migraphx::op::broadcast{0, x->get_shape().lens()}, y);
        auto sum = mm->add_instruction(migraphx::op::add{}, x, by);
        mm->add_instruction(migraphx::op::add{}, sum, z);
21
22
23
        return p;
    }
};