注册实现算子一对多子图映射的函数,即将算子映射为多个算子。
1 | OpRegistrationData &ParseOpToGraphFn(const ParseOpToGraphFunc &parse_op_to_graph_fn)
|
参数 |
输入/输出 |
说明 |
---|---|---|
parse_op_to_graph_fn |
输入 |
实现算子一对多映射,进行子图构造的函数。 |
实现一对多子图映射时,插件注册时首先需要将原始框架中的算子映射成昇腾AI处理器中的PartitionedCall算子,并在ParseParamsByOperatorFn函数中使用“SetAttr”接口设置original_type。
实现样例请参见调用示例。
用户自定义并实现ParseOpToGraphFunc函数,通过IR模型构建方式完成一对多子图的构造,构图详细介绍请参考《Ascend Graph开发指南》。
回调函数原型定义如下:
1 | Status ParseOpToGraphFunc(const ge::Operator &op, ge::Graph &graph)
|
参数 |
输入/输出 |
说明 |
---|---|---|
op |
输入 |
PartitionedCall算子数据结构,Operator类对象。 |
graph |
输出 |
构造的子图。 |
以将Add算子转换成Addn+Abs为例。
实现Add算子到PartitionedCall算子的映射函数示例如下所示:
1 2 3 4 5 | Status ParseParams(const ge::Operator &op_src, ge::Operator& op_dest)
{
...
op_dest.SetAttr("original_type", "ai.onnx::11::Add");
}
|
一对多子图构造函数实现示例如下所示:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 | static Status ParseOpToGraph(const Operator &op, Graph &graph) {
auto data_0 = op::Data().set_attr_index(0);
auto data_1 = op::Data().set_attr_index(1);
auto addn = op::AddN("addn_sum").create_dynamic_input_x(2)
.set_dynamic_input_x(0, data_0)
.set_dynamic_input_x(1, data_1)
.set_attr_N(2);
auto abs = op::Abs("abs_sum").set_input_x(addn);
std::vector<Operator> inputs{data_0, data_1};
std::vector<std::pair<Operator, std::vector<size_t>>> output_indexs;
output_indexs.emplace_back(abs, vector<std::size_t>{0});
graph.SetInputs(inputs).SetOutputs(output_indexs);
return domi::SUCCESS;
}
|
进行注册:
1 2 3 4 5 6 | REGISTER_CUSTOM_OP("PartitionedCall")
.FrameworkType(xx)
.OriginOpType(xx)
.ParseParamsByOperatorFn(ParseParams)
.ParseOpToGraphFn(ParseOpToGraph)
.ImplyType(ImplyType::TVM);
|
图1为将Add算子进行一对多子图映射后的示例。