test_conv_bn_add.cpp 2.33 KB
Newer Older
1
2
3
4

#include "verify_program.hpp"
#include <migraphx/program.hpp>
#include <migraphx/generate.hpp>
Paul's avatar
Paul committed
5
#include <migraphx/op/common.hpp>
6
7
8
9
10
11
12
13
14

// struct test_conv_bn_add : verify_program<test_conv_bn_add>
// {
//     static migraphx::instruction_ref add_bn(migraphx::program& p,
//                                             migraphx::instruction_ref x,
//                                             std::size_t channels,
//                                             std::size_t seed = 1)
//     {
//         migraphx::shape vars{migraphx::shape::float_type, {channels}};
15
16
17
18
19
20
//         auto scale    = mm->add_literal(migraphx::abs(migraphx::generate_literal(vars, 1 +
//         seed))); auto bias     = mm->add_literal(migraphx::abs(migraphx::generate_literal(vars, 2
//         + seed))); auto mean     = mm->add_literal(migraphx::abs(migraphx::generate_literal(vars,
//         3 + seed))); auto variance =
//         mm->add_literal(migraphx::abs(migraphx::generate_literal(vars, 4 + seed))); return
//         mm->add_instruction(
21
22
23
24
25
26
27
28
//             migraphx::op::batch_norm_inference{}, x, scale, bias, mean, variance);
//     }

//     migraphx::program create_program() const
//     {
//         migraphx::program p;
//         std::size_t ichannels = 64;
//         std::size_t ochannels = 256;
29
30
//         auto x     = mm->add_parameter("x", {migraphx::shape::float_type, {1, ichannels, 56,
//         56}}); auto w     = mm->add_literal(migraphx::generate_literal(
31
//             {migraphx::shape::float_type, {ochannels, ichannels, 1, 1}}, 1));
32
33
//         auto y     = mm->add_parameter("y", {migraphx::shape::float_type, {1, ichannels, 56,
//         56}}); auto v     = mm->add_literal(migraphx::generate_literal(
34
//             {migraphx::shape::float_type, {ochannels, ichannels, 1, 1}}, 2));
35
36
//         auto relu1 = mm->add_instruction(migraphx::op::relu{}, x);
//         auto conv1 = mm->add_instruction(migraphx::op::convolution{}, relu1, w);
37
//         auto bn1   = add_bn(p, conv1, ochannels, 1);
38
39
//         auto relu2 = mm->add_instruction(migraphx::op::relu{}, y);
//         auto conv2 = mm->add_instruction(migraphx::op::convolution{}, relu2, v);
40
//         auto bn2   = add_bn(p, conv2, ochannels, 1);
41
42
//         auto sum   = mm->add_instruction(migraphx::op::add{}, bn1, bn2);
//         mm->add_instruction(migraphx::op::relu{}, sum);
43
44
45
//         return p;
//     }
// };