You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

test_onnx_parser.cc 8.5 kB

3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226
  1. /**
  2. * Copyright 2019-2020 Huawei Technologies Co., Ltd
  3. *
  4. * Licensed under the Apache License, Version 2.0 (the "License");
  5. * you may not use this file except in compliance with the License.
  6. * You may obtain a copy of the License at
  7. *
  8. * http://www.apache.org/licenses/LICENSE-2.0
  9. *
  10. * Unless required by applicable law or agreed to in writing, software
  11. * distributed under the License is distributed on an "AS IS" BASIS,
  12. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13. * See the License for the specific language governing permissions and
  14. * limitations under the License.
  15. */
  16. #include <gtest/gtest.h>
  17. #include <iostream>
  18. #include "parser/common/op_parser_factory.h"
  19. #include "graph/operator_reg.h"
  20. #include "register/op_registry.h"
  21. #include "parser/common/op_registration_tbe.h"
  22. #include "external/parser/onnx_parser.h"
  23. #include "st/parser_st_utils.h"
  24. #include "external/ge/ge_api_types.h"
  25. #include "tests/depends/ops_stub/ops_stub.h"
  26. #include "framework/omg/parser/parser_factory.h"
  27. #include "parser/onnx/onnx_util.h"
  28. #define private public
  29. #include "parser/onnx/onnx_parser.h"
  30. #undef private
  31. namespace ge {
  32. class STestOnnxParser : public testing::Test {
  33. protected:
  34. void SetUp() {
  35. ParerSTestsUtils::ClearParserInnerCtx();
  36. RegisterCustomOp();
  37. }
  38. void TearDown() {}
  39. public:
  40. void RegisterCustomOp();
  41. };
  42. static Status ParseParams(const google::protobuf::Message* op_src, ge::Operator& op_dest) {
  43. return SUCCESS;
  44. }
  45. static Status ParseParamByOpFunc(const ge::Operator &op_src, ge::Operator& op_dest) {
  46. return SUCCESS;
  47. }
  48. Status ParseSubgraphPostFnIf(const std::string& subgraph_name, const ge::Graph& graph) {
  49. domi::AutoMappingSubgraphIOIndexFunc auto_mapping_subgraph_index_func =
  50. domi::FrameworkRegistry::Instance().GetAutoMappingSubgraphIOIndexFunc(domi::ONNX);
  51. if (auto_mapping_subgraph_index_func == nullptr) {
  52. std::cout<<"auto mapping if subgraph func is nullptr!"<<std::endl;
  53. return FAILED;
  54. }
  55. return auto_mapping_subgraph_index_func(graph,
  56. [&](int data_index, int &parent_index) -> Status {
  57. parent_index = data_index + 1;
  58. return SUCCESS;
  59. },
  60. [&](int output_index, int &parent_index) -> Status {
  61. parent_index = output_index;
  62. return SUCCESS;
  63. });
  64. }
  65. void STestOnnxParser::RegisterCustomOp() {
  66. REGISTER_CUSTOM_OP("Conv2D")
  67. .FrameworkType(domi::ONNX)
  68. .OriginOpType("ai.onnx::11::Conv")
  69. .ParseParamsFn(ParseParams);
  70. // register if op info to GE
  71. REGISTER_CUSTOM_OP("If")
  72. .FrameworkType(domi::ONNX)
  73. .OriginOpType({"ai.onnx::9::If",
  74. "ai.onnx::10::If",
  75. "ai.onnx::11::If",
  76. "ai.onnx::12::If",
  77. "ai.onnx::13::If"})
  78. .ParseParamsFn(ParseParams)
  79. .ParseParamsByOperatorFn(ParseParamByOpFunc)
  80. .ParseSubgraphPostFn(ParseSubgraphPostFnIf);
  81. REGISTER_CUSTOM_OP("Add")
  82. .FrameworkType(domi::ONNX)
  83. .OriginOpType("ai.onnx::11::Add")
  84. .ParseParamsFn(ParseParams);
  85. REGISTER_CUSTOM_OP("Identity")
  86. .FrameworkType(domi::ONNX)
  87. .OriginOpType("ai.onnx::11::Identity")
  88. .ParseParamsFn(ParseParams);
  89. std::vector<OpRegistrationData> reg_datas = domi::OpRegistry::Instance()->registrationDatas;
  90. for (auto reg_data : reg_datas) {
  91. domi::OpRegTbeParserFactory::Instance()->Finalize(reg_data);
  92. domi::OpRegistry::Instance()->Register(reg_data);
  93. }
  94. domi::OpRegistry::Instance()->registrationDatas.clear();
  95. }
  96. ge::onnx::GraphProto CreateOnnxGraph() {
  97. ge::onnx::GraphProto onnx_graph;
  98. (void)onnx_graph.add_input();
  99. (void)onnx_graph.add_output();
  100. ::ge::onnx::NodeProto* node_const1 = onnx_graph.add_node();
  101. ::ge::onnx::NodeProto* node_const2 = onnx_graph.add_node();
  102. ::ge::onnx::NodeProto* node_add = onnx_graph.add_node();
  103. node_const1->set_op_type(kOpTypeConstant);
  104. node_const2->set_op_type(kOpTypeConstant);
  105. node_add->set_op_type("Add");
  106. ::ge::onnx::AttributeProto* attr = node_const1->add_attribute();
  107. attr->set_name(ge::kAttrNameValue);
  108. ::ge::onnx::TensorProto* tensor_proto = attr->mutable_t();
  109. tensor_proto->set_data_location(ge::onnx::TensorProto_DataLocation_EXTERNAL);
  110. attr = node_const1->add_attribute();
  111. attr = node_const2->add_attribute();
  112. attr->set_name(ge::kAttrNameValue);
  113. tensor_proto = attr->mutable_t();
  114. tensor_proto->set_data_location(ge::onnx::TensorProto_DataLocation_DEFAULT);
  115. return onnx_graph;
  116. }
  117. TEST_F(STestOnnxParser, onnx_parser_user_output_with_default) {
  118. std::string case_dir = __FILE__;
  119. case_dir = case_dir.substr(0, case_dir.find_last_of("/"));
  120. std::string model_file = case_dir + "/origin_models/onnx_conv2d.onnx";
  121. std::map<ge::AscendString, ge::AscendString> parser_params;
  122. ge::Graph graph;
  123. auto ret = ge::aclgrphParseONNX(model_file.c_str(), parser_params, graph);
  124. ASSERT_EQ(ret, GRAPH_SUCCESS);
  125. ge::ComputeGraphPtr compute_graph = ge::GraphUtils::GetComputeGraph(graph);
  126. auto output_nodes_info = compute_graph->GetGraphOutNodesInfo();
  127. ASSERT_EQ(output_nodes_info.size(), 1);
  128. EXPECT_EQ((output_nodes_info.at(0).first->GetName()), "Conv_0");
  129. EXPECT_EQ((output_nodes_info.at(0).second), 0);
  130. auto &net_out_name = ge::GetParserContext().net_out_nodes;
  131. ASSERT_EQ(net_out_name.size(), 1);
  132. EXPECT_EQ(net_out_name.at(0), "Conv_0:0:y");
  133. }
  134. TEST_F(STestOnnxParser, onnx_parser_if_node) {
  135. std::string case_dir = __FILE__;
  136. case_dir = case_dir.substr(0, case_dir.find_last_of("/"));
  137. std::string model_file = case_dir + "/origin_models/onnx_if.onnx";
  138. std::map<ge::AscendString, ge::AscendString> parser_params;
  139. ge::Graph graph;
  140. auto ret = ge::aclgrphParseONNX(model_file.c_str(), parser_params, graph);
  141. EXPECT_EQ(ret, GRAPH_SUCCESS);
  142. }
  143. TEST_F(STestOnnxParser, onnx_parser_expand_one_to_many) {
  144. std::string case_dir = __FILE__;
  145. case_dir = case_dir.substr(0, case_dir.find_last_of("/"));
  146. std::string model_file = case_dir + "/origin_models/onnx_clip_v9.onnx";
  147. std::map<ge::AscendString, ge::AscendString> parser_params;
  148. ge::Graph graph;
  149. auto ret = ge::aclgrphParseONNX(model_file.c_str(), parser_params, graph);
  150. EXPECT_EQ(ret, GRAPH_SUCCESS);
  151. MemBuffer *buffer = ParerSTestsUtils::MemBufferFromFile(model_file.c_str());
  152. ret = ge::aclgrphParseONNXFromMem(reinterpret_cast<char *>(buffer->data), buffer->size, parser_params, graph);
  153. EXPECT_EQ(ret, GRAPH_SUCCESS);
  154. }
  155. TEST_F(STestOnnxParser, onnx_parser_to_json) {
  156. std::string case_dir = __FILE__;
  157. case_dir = case_dir.substr(0, case_dir.find_last_of("/"));
  158. std::string model_file = case_dir + "/origin_models/onnx_clip_v9.onnx";
  159. std::map<ge::AscendString, ge::AscendString> parser_params;
  160. OnnxModelParser onnx_parser;
  161. const char *json_file = "tmp.json";
  162. auto ret = onnx_parser.ToJson(model_file.c_str(), json_file);
  163. EXPECT_EQ(ret, SUCCESS);
  164. const char *json_null = nullptr;
  165. ret = onnx_parser.ToJson(model_file.c_str(), json_null);
  166. EXPECT_EQ(ret, FAILED);
  167. const char *model_null = nullptr;
  168. ret = onnx_parser.ToJson(model_null, json_null);
  169. EXPECT_EQ(ret, FAILED);
  170. }
  171. TEST_F(STestOnnxParser, onnx_parser_const_data_type) {
  172. std::string case_dir = __FILE__;
  173. case_dir = case_dir.substr(0, case_dir.find_last_of("/"));
  174. std::string model_file = case_dir + "/origin_models/onnx_const_type.onnx";
  175. std::map<ge::AscendString, ge::AscendString> parser_params;
  176. ge::Graph graph;
  177. auto ret = ge::aclgrphParseONNX(model_file.c_str(), parser_params, graph);
  178. EXPECT_EQ(ret, GRAPH_SUCCESS);
  179. }
  180. TEST_F(STestOnnxParser, onnx_parser_if_node_with_const_input) {
  181. std::string case_dir = __FILE__;
  182. case_dir = case_dir.substr(0, case_dir.find_last_of("/"));
  183. std::string model_file = case_dir + "/origin_models/onnx_if_const_intput.onnx";
  184. std::map<ge::AscendString, ge::AscendString> parser_params;
  185. ge::Graph graph;
  186. auto ret = ge::aclgrphParseONNX(model_file.c_str(), parser_params, graph);
  187. EXPECT_EQ(ret, GRAPH_SUCCESS);
  188. }
  189. TEST_F(STestOnnxParser, onnx_test_ModelParseToGraph)
  190. {
  191. OnnxModelParser modelParser;
  192. ge::onnx::ModelProto model_proto;
  193. auto onnx_graph = model_proto.mutable_graph();
  194. *onnx_graph = CreateOnnxGraph();
  195. ge::Graph graph;
  196. Status ret = modelParser.ModelParseToGraph(model_proto, graph);
  197. EXPECT_EQ(ret, FAILED);
  198. }
  199. } // namespace ge