parse_biasadd.cpp 1020 Bytes
Newer Older
kahmed10's avatar
kahmed10 committed
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
#include <migraphx/tf/op_parser.hpp>
#include <migraphx/ranges.hpp>
#include <migraphx/instruction.hpp>
#include <migraphx/make_op.hpp>

namespace migraphx {
inline namespace MIGRAPHX_INLINE_NS {
namespace tf {

struct parse_biasadd : op_parser<parse_biasadd>
{
    bool transpose() const { return true; }
    std::vector<op_desc> operators() const { return {{"BiasAdd"}}; }

    instruction_ref parse(const op_desc& /*opd*/,
                          const tf_parser& /*parser*/,
                          const tf_parser::node_info& info,
                          std::vector<instruction_ref> args) const
    {
        uint64_t axis = 1; // assume output of previous layer is in NCHW (broadcast on channel)

        auto l0 = info.add_instruction(
23
24
            make_op("broadcast", {{"axis", axis}, {"out_lens", args[0]->get_shape().lens()}}),
            args[1]);
kahmed10's avatar
kahmed10 committed
25
26
27
28
29
30
31
        return info.add_instruction(make_op("add"), args[0], l0);
    }
};

} // namespace tf
} // namespace MIGRAPHX_INLINE_NS
} // namespace migraphx