#include #include #include #include #include namespace migraphx { inline namespace MIGRAPHX_INLINE_NS { namespace tf { struct parse_onehot : op_parser { std::vector operators() const { return {{"OneHot"}}; } instruction_ref parse(const op_desc& /*opd*/, const tf_parser& /*parser*/, tf_parser::node_info info, std::vector args) const { size_t depth = static_cast(args[1]->eval().at()); int64_t axis = -1; float on_value = args[2]->eval().at(); float off_value = args[3]->eval().at(); std::vector depth_input(depth * depth, off_value); for(int i = 0; i < depth; i++) { depth_input[depth * i + i] = on_value; } if(contains(info.attributes, "axis")) axis = info.attributes.at("axis").i(); if(axis == -1) { shape s{shape::float_type, {depth, depth}}; auto l0 = info.add_literal({s, depth_input}); return info.add_instruction(make_op("gather", {{"axis", 0}}), {l0, args[0]}); } MIGRAPHX_THROW("MIGraphX does not support axis != -1"); } }; } // namespace tf } // namespace MIGRAPHX_INLINE_NS } // namespace migraphx