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.

ge_attr_define.cc 45 kB

5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
5 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086
  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 <graph/debug/ge_attr_define.h>
  17. namespace ge {
  18. // Public attribute
  19. const std::string ATTR_NAME_IS_UNKNOWN_SHAPE = "_is_unknown_shape";
  20. const std::string ATTR_NAME_DYNAMIC_SHAPE_PARTITIONED = "_dynamic_shape_partitioned";
  21. const std::string ATTR_NAME_UNKNOWN_SHAPE_TYPE = "_unknown_shape_type";
  22. const std::string ATTR_NAME_NAME = "name";
  23. const std::string ATTR_NAME_TYPE = "type";
  24. const std::string ATTR_NAME_WEIGHT_NAME = "weight_name";
  25. const std::string ATTR_NAME_IS_QUANTIZE_FACTOR = "quantize_factor";
  26. const std::string ATTR_NAME_ALPHA = "alpha";
  27. const std::string ATTR_NAME_BETA = "beta";
  28. const std::string ATTR_NAME_PADMODE = "pad_mode";
  29. const std::string ATTR_NAME_PADMODES = "padding";
  30. const std::string ATTR_NAME_MODE = "mode";
  31. const std::string ATTR_NAME_FILTER = "filter";
  32. const std::string ATTR_NAME_BIAS = "bias";
  33. const std::string ATTR_NAME_BIAS_TERM = "bias_term";
  34. const std::string ATTR_NAME_HAS_BIAS_VALUE = "has_bias_value";
  35. const std::string ATTR_NAME_PAD = "pad";
  36. const std::string ATTR_NAME_PADS = "pad";
  37. const std::string ATTR_NAME_PAD_SIZE = "pad size";
  38. const std::string ATTR_NAME_PAD_MODE = "pad mode";
  39. const std::string ATTR_NAME_SCALE = "scale";
  40. const std::string ATTR_NAME_WINDOWS = "windows";
  41. const std::string ATTR_NAME_GLOBAL_POOLING = "global_pooling";
  42. const std::string ATTR_NAME_CEIL_MODE = "ceil_mode";
  43. const std::string ATTR_NAME_RELUMODE = "relu_mode";
  44. const std::string ATTR_NAME_STRIDE_SIZE = "stride size";
  45. const std::string ATTR_NAME_RELU_FLAG = "relu_flag";
  46. const std::string ATTR_NAME_ALGO = "algo";
  47. const std::string ATTR_NAME_FORMAT = "format";
  48. const std::string ATTR_NAME_STORAGE_FORMAT = "storage_format";
  49. const std::string ATTR_NAME_STORAGE_SHAPE = "storage_shape";
  50. const std::string ATTR_NAME_FILTER_FORMAT = "filter_format";
  51. const std::string ATTR_NAME_LRN_K = "lrn_k";
  52. const std::string ATTR_NAME_LRN_NORM_REGION = "lrn_normregion";
  53. const std::string ATTR_NAME_LRN_LOCAL_SIZE = "lrn_localsize";
  54. const std::string ATTR_NAME_LRN_ALPHA = "lrn_alpha";
  55. const std::string ATTR_NAME_LRN_BETA = "lrn_beta";
  56. const std::string ATTR_NAME_AXIS = "axis";
  57. const std::string ATTR_NAME_BROADCAST = "broadcast";
  58. const std::string ATTR_NAME_OUTPUT = "output";
  59. const std::string ATTR_NAME_OUTPUT_NUM = "output_num";
  60. const std::string ATTR_NAME_TIDX = "t_idx";
  61. const std::string ATTR_NAME_TPADDINGS = "t_paddings";
  62. const std::string ATTR_IMG_H = "img_h";
  63. const std::string ATTR_IMG_W = "img_w";
  64. const std::string ATTR_NET_H = "net_h";
  65. const std::string ATTR_NET_W = "net_w";
  66. const std::string ATTR_NAME_TMULTIPLES = "t_multiples";
  67. const std::string ATTR_NAME_MULTIPLES = "multiples";
  68. const std::string ATTR_NAME_T = "T";
  69. const std::string ATTR_NAME_N = "N";
  70. const std::string ATTR_NAME_TSHAPE = "Tshape";
  71. const std::string ATTR_NAME_NAN_OPT = "nan_opt";
  72. const std::string ATTR_NAME_AIPP = "aipp";
  73. const std::string NEW_AIPP_CONV_OP = "new_conv_op_for_aipp";
  74. const std::string ATTR_NAME_AIPP_INPUTS = "_aipp_inputs";
  75. const std::string ATTR_NAME_AIPP_OUTPUTS = "_aipp_outputs";
  76. const std::string ATTR_NAME_INPUT_DIMS = "input_dims";
  77. const std::string ATTR_DYNAMIC_AIPP_INPUT_DIMS = "_dynamic_aipp_input_dims";
  78. const std::string ATTR_DATA_RELATED_AIPP_MODE = "_data_related_aipp_mode";
  79. const std::string ATTR_DATA_AIPP_DATA_NAME_MAP = "_data_aipp_data_name_map";
  80. const std::string ATTR_NAME_GRAPH_HAS_BEEN_ADDED = "_graph_has_been_added";
  81. const std::string ATTR_NAME_SESSION_GRAPH_ID = "_session_graph_id";
  82. const std::string ATTR_NAME_PARENT_GRAPH_NAME = "_parent_graph_name";
  83. const std::string ATTR_NAME_MULTISHAPE_BATCHLIST = "multi_shape_batchlist";
  84. const std::string ATTR_NAME_MULTISHAPE_BATCHLIST_SIZE = "multi_shape_batchlist_size";
  85. const std::string ATTR_MODEL_BATCH_NUM = "batch_num";
  86. const std::string ATTR_NAME_INPUT_FORMAT = "input_format";
  87. const std::string ATTR_NAME_OUTPUT_FORMAT = "output_format";
  88. const std::string ATTR_NAME_FRAMEWORK_NODE_DEF = "node_def";
  89. const std::string ATTR_NAME_FRAMEWORK_OP_DEF = "op_def";
  90. const std::string ATTR_NAME_FRAMEWORK_FWK_TYPE = "framework_type";
  91. const std::string ATTR_NAME_FRAMEWORK_FUNC_DEF = "func_def";
  92. const std::string ATTR_NAME_FRAMEWORK_ORIGINAL_TYPE = "original_type";
  93. const std::string ATTR_NAME_INPUT_TENSOR_DESC = "input_tensor_desc";
  94. const std::string ATTR_NAME_OUTPUT_TENSOR_DESC = "output_tensor_desc";
  95. const std::string ATTR_NAME_INFERRED_FORMAT = "inferred_format";
  96. const std::string ATTR_NAME_PRED_PERMUTE_DELETED = "pred_permute_deleted";
  97. const std::string ATTR_NAME_IGNORE_PRED_FORMAT = "ignore_pred_format";
  98. const std::string ATTR_NAME_WEIGHTS = "value";
  99. const std::string ATTR_NAME_WEIGHTS_DATA = "weights_data";
  100. const std::string ATTR_NAME_BROACAST_REAL_DIM_CNT = "broacast_real_dim_cnt";
  101. const std::string ATTR_NAME_DIM_ALIGN = "dim_align";
  102. const std::string ATTR_NAME_STREAM_LABEL = "_stream_label";
  103. const std::string ATTR_NAME_CONTINUOUS_STREAM_LABEL = "_continuous_stream_label";
  104. const std::string ATTR_NAME_STREAM_CYCLE_EVENT_FLAG = "need_stream_cycle_event";
  105. const std::string ATTR_NAME_RTSWITCH_RECV_EVENT_ID = "rtswitch_event_id";
  106. const std::string ATTR_NAME_AUTOMIC_ADD_START = "automic_add_addr_start";
  107. const std::string ATTR_NAME_AUTOMIC_ADD_MEM_SIZE = "automic_add_mem_size";
  108. const std::string ATTR_NAME_DYNAMIC_OUTPUT_DIMS = "_dynamic_output_dims";
  109. const std::string ATTR_NAME_INPUT_ORIGIN_SIZE = "input_origin_size";
  110. // Identify node connecting to input and output
  111. const std::string ATTR_NAME_NODE_CONNECT_INPUT = "_is_connected_to_data";
  112. const std::string ATTR_NAME_NODE_CONNECT_OUTPUT = "_is_connected_to_netoutput";
  113. // To be deleted
  114. const std::string ATTR_TO_BE_DELETED = "to_be_deleted";
  115. const std::string PERMUTE_RESHAPE_FUSION = "permute_reshape_fusion";
  116. const std::string PERMUTE_RESHAPE_FUSION_CONV_PROPOSAL = "fusion_conv_proposal";
  117. const std::string PERMUTE_RESHAPE_FUSION_CONV_DECODEBBOX = "fusion_conv_decodebbox";
  118. const std::string PERMUTE_RESHAPE_FUSION_BOX_TYPE_NUM = "box_type_num";
  119. const std::string SSD_MBOX_LOC_FUSION = "permute_flatten_fusion";
  120. const std::string SSD_MBOX_CONF_FUSION = "permute_flatten_reshape_flatten_fusion";
  121. const std::string SSD_MBOX_OCR_FUSION = "permute_flatten_ocr_fusion";
  122. const std::string SSD_MBOX_FUSION_BOX_TYPE_NUM = "ssd_mbox_fusion_box_type_num";
  123. const std::string SSD_RESHAPE_SLICE_CONCAT_FUSION = "reshape_slice_concat_fusion";
  124. // Refinedet
  125. const std::string REFINEDET_MBOX_LOC_FUSION = "permute_flatten_fusion";
  126. const std::string REFINEDET_MBOX_CONF_FUSION = "permute_flatten_reshape_flatten_fusion";
  127. const std::string REFINEDET_MBOX_FUSION_BOX_TYPE_NUM = "ssd_mbox_fusion_box_type_num";
  128. const std::string REFINEDET_RESHAPE_SLICE_CONCAT_FUSION = "reshape_slice_concat_fusion";
  129. const std::string SSD_PRIORBOX_CONCAT = "ssd_mbox_conf_priorbox_concat_flag";
  130. // _Arg
  131. const std::string ATTR_NAME_INDEX = "index";
  132. // _RetVal
  133. const std::string RETVAL_ATTR_NAME_INDEX = "retval_index";
  134. // Data
  135. const std::string DATA_ATTR_NAME_DATA_TYPE = "data_type";
  136. // Send
  137. const std::string SEND_ATTR_EVENT_ID = "event_id";
  138. // Recv
  139. const std::string RECV_ATTR_EVENT_ID = "event_id";
  140. // convolution
  141. const std::string ATTR_NAME_COEF = "coef";
  142. const std::string ATTR_NAME_STRIDE = "stride";
  143. const std::string ATTR_NAME_STRIDES = "stride";
  144. const std::string ATTR_NAME_DILATION = "dilation";
  145. const std::string ATTR_NAME_DILATIONS = "dilation";
  146. const std::string CONV_ATTR_NAME_MODE = "mode";
  147. const std::string CONV_ATTR_NAME_ALGO = "algo";
  148. const std::string CONV_ATTR_NAME_GROUP = "group";
  149. const std::string CONV_ATTR_NAME_PAD_MODE = "pad_mode";
  150. const std::string CONV_ATTR_NAME_PAD = "pad";
  151. const std::string CONV_ATTR_NAME_STRIDE = "stride";
  152. const std::string CONV_ATTR_NAME_DILATION = "dilation";
  153. const std::string CONV_ATTR_NAME_NUM_OUTPUT = "num_output";
  154. const std::string CONV_ATTR_NAME_KERNEL = "kernel";
  155. const std::string CONV_ATTR_NAME_FILTER = "filter";
  156. const std::string CONV_ATTR_NAME_BIAS = "bias";
  157. const std::string CONV_ATTR_NAME_RELU_FLAG = "relu_flag";
  158. const std::string CONV_ATTR_NAME_ADJ = "adj";
  159. const std::string CONV_ATTR_NAME_TARGET_SHAPE = "target_shape";
  160. const std::string CONV_ATTR_NAME_BEFORE_PAD = "before_pad";
  161. const std::string CONV_ATTR_NAME_HAS_BIAS = "has_bias";
  162. const std::string NEED_INFER = "isNeedInfer";
  163. // Pooling
  164. const std::string POOLING_ATTR_MODE = "mode";
  165. const std::string POOLING_ATTR_NAN_OPT = "nan_opt";
  166. const std::string POOLING_ATTR_PAD_MODE = "pad_mode";
  167. const std::string POOLING_ATTR_GLOBAL_POOLING = "global_pooling";
  168. const std::string POOLING_ATTR_WINDOW = "window";
  169. const std::string POOLING_ATTR_PAD = "pad";
  170. const std::string POOLING_ATTR_STRIDE = "stride";
  171. const std::string POOLING_ATTR_CEIL_MODE = "ceil_mode";
  172. const std::string POOLING_ATTR_DATA_MODE = "data_mode";
  173. const std::string POOLING_ATTR_BEFORE_PAD = "before_pad";
  174. const std::string POOLING_ATTR_NAME_ALGO = "algo";
  175. // Eltwise
  176. const std::string ELTWISE_ATTR_MODE = "mode";
  177. const std::string ELTWISE_ATTR_COEFF = "coeff";
  178. const std::string ELTWISE_ATTR_WEIGHT = "weight";
  179. const std::string ELTWISE_ATTR_RELU_FLAG = "relu_flag";
  180. const std::string ELTWISE_ATTR_ALPHA = "alpha";
  181. const std::string ELTWISE_ATTR_BETA = "beta";
  182. // BatchNorm
  183. const std::string BATCHNORM_ATTR_MODE = "mode";
  184. const std::string BATCHNORM_ATTR_EPSILON = "epsilon";
  185. const std::string BATCHNORM_ATTR_USE_GLOBAL_STATS = "use_global_stats";
  186. const std::string BATCHNORM_ATTR_MOVING_AVERAGE_FRACTION = "moving_average_fraction";
  187. const std::string BATCHNORM_ATTR_ESTIMATED_MEAN = "estimated_mean";
  188. const std::string BATCHNORM_ATTR_ESTIMATED_VARIANCE = "estimated_variance";
  189. const std::string BATCHNORM_ATTR_SCALE = "scale";
  190. const std::string BATCHNORM_ATTR_BIAS = "bias";
  191. const std::string BATCHNORM_ATTR_DATA_FORMAT = "data_format";
  192. const std::string BATCHNORM_ATTR_IS_TRAINING = "is_training";
  193. const std::string BATCHNORM_ATTR_IS_TRAINING_FUSION = "is_training_fusion";
  194. // huberloss
  195. const std::string HUBER_LOSS_ATTR_DELTA = "delta";
  196. // SSDRealDivTileMul
  197. const std::string SSD_REAL_DIV_TILE_MUL_ATTR_TILE_PARA = "tilepara";
  198. // SSDSumMulRealDivMean
  199. const std::string SSD_SUM_MUL_REALDIV_MEAN_ATTR_REDUCTION_INDICES = "reduction_indices";
  200. const std::string SSD_SUM_MUL_REALDIV_MEAN_ATTR_AXIS = "axis";
  201. const std::string SSD_SUM_MUL_REALDIV_MEAN_ATTR_MEAN_PARA = "mean_para";
  202. const std::string SSD_SUM_MUL_REALDIV_MEAN_ATTR_HAS_SUM = "has_sum";
  203. // ConcatFive2Four
  204. // ConcatFour2Five
  205. const std::string SSD_BOX_TYPE_NUM = "box_type_num";
  206. const std::string SSD_CLASS_NUM = "class_num";
  207. const std::string TRANS_FOR_LOSS_MODE = "trans_for_loss_mode";
  208. const std::string SSD_FEATURE_MAP_SIZE = "feature_map_size";
  209. const std::string SSD_FEATURE_MAP_HIGH = "feature_map_high";
  210. const std::string SSD_FEATURE_MAP_WIDTH = "feature_map_width";
  211. // Scale
  212. const std::string SCALE_ATTR_SCALE = "scale";
  213. const std::string SCALE_ATTR_BIAS = "bias";
  214. // FullConnection
  215. const std::string FULL_CONNECTION_ATTR_FILTER = "filter";
  216. const std::string FULL_CONNECTION_ATTR_BIAS = "bias";
  217. const std::string FULL_CONNECTION_ATTR_NUM_OUTPUT = "num_output";
  218. const std::string FULL_CONNECTION_ATTR_RELU_FLAG = "relu_flag";
  219. const std::string FULL_ATTR_NAME_ALGO = "algo";
  220. // SoftmaxOpParams
  221. const std::string SOFTMAX_ATTR_ALGO = "algo";
  222. const std::string SOFTMAX_ATTR_MODE = "mode";
  223. // SparseSoftmaxCrossEntropy
  224. const std::string SPARSE_SOFTMAX_CROSS_ENTROPY_ATTR_MODE = "cross_entropy_mode";
  225. const std::string SPARSE_SOFTMAX_CROSS_ENTROPY_IS_GRAD = "cross_entropy_is_grad";
  226. // Attr labelSmoothing
  227. const std::string SOFTMAX_CROSS_ENTROPY_LABELSMOOTHING = "labelSmoothing";
  228. // ApplyMomentum
  229. const std::string APPLYMENTUM_ATTR_IS_GRAPH_FUSION = "applymomentum_is_graph_fusion";
  230. // Activation
  231. const std::string ACTIVATION_ATTR_MODE = "mode";
  232. const std::string ACTIVATION_ATTR_COEF = "coef";
  233. // Concat
  234. const std::string CONCAT_ATTR_NAME_AXIS = "axis";
  235. // Const
  236. const std::string CONST_ATTR_NAME_DATA_TRANSTYPE = "data_transtype";
  237. const std::string CONST_ATTR_NAME_OUTPUT_FORMAT = "output_format";
  238. const std::string CONST_ATTR_NAME_OUTPUT_TYPE = "output_type";
  239. // Roipooling
  240. const std::string ROIPOOLING_ATTR_NAME_POOLED_H = "pooled_h";
  241. const std::string ROIPOOLING_ATTR_NAME_POOLED_W = "pooled_w";
  242. const std::string ROIPOOLING_ATTR_NAME_SPATIAL_SCALE = "spatial_scale";
  243. const std::string ROIPOOLING_ATTR_NAME_RIO_POOLING_MODE = "rio_pooling_mode";
  244. const std::string ROIPOOLING_ATTR_NAME_POOLING_MODE = "pooling_mode";
  245. const std::string ROIPOOLING_ATTR_NAME_SAMPLING_RATIO = "sampling_ratio";
  246. // DetectionOutput
  247. const std::string DETECTIONOUTPUT_ATTR_NUM_CLASSES = "num_classes";
  248. const std::string DETECTIONOUTPUT_ATTR_OCR_NUM_CLASSES = "ocr_num_classes";
  249. const std::string DETECTIONOUTPUT_ATTR_NMS_THRESHOLD = "nms_threshold";
  250. const std::string DETECTIONOUTPUT_ATTR_TOP_K = "top_k";
  251. const std::string DETECTIONOUTPUT_ATTR_CONFIDENCE_THRESHOLD = "confidence_threshold";
  252. const std::string DETECTIONOUTPUT_ATTR_IMG_H = "img_h";
  253. const std::string DETECTIONOUTPUT_ATTR_IMG_W = "img_w";
  254. const std::string DETECTIONOUTPUT_ATTR_BATCH_SIZE = "batch_size";
  255. // Ssd DetectionOutput
  256. const std::string DETECTIONOUTPUT_ATTR_ETA = "eta";
  257. const std::string DETECTIONOUTPUT_ATTR_SHARED_LOCATION = "shared_location";
  258. const std::string DETECTIONOUTPUT_ATTR_BACKGROUND_LABEL_ID = "background_label_id";
  259. const std::string DETECTIONOUTPUT_ATTR_CODE_TYPE = "code_type";
  260. const std::string DETECTIONOUTPUT_ATTR_VARIANCE_ENCODED_IN_TARGET = "variance_encoded_in_target";
  261. const std::string DETECTIONOUTPUT_ATTR_KEEP_TOP_K = "keep_top_k";
  262. // Refinedet DetectionOutput
  263. const std::string DETECTIONOUTPUT_ATTR_OBJECTNESS_SCORE = "objectness_score";
  264. // yolo DetectionOutput
  265. const std::string DETECTIONOUTPUT_ATTR_ClASSES = "classes";
  266. const std::string DETECTIONOUTPUT_ATTR_BIASES = "biases";
  267. const std::string DETECTIONOUTPUT_ATTR_RELATIVE = "relative";
  268. const std::string DETECTIONOUTPUT_ATTR_OBJECTNESS_THRESHOLD = "objectness_threshold";
  269. const std::string DETECTIONOUTPUT_ATTR_CLASS_THRESHOLD = "class_threshold";
  270. const std::string DETECTIONOUTPUT_ATTR_POST_TOP_K = "post_top_k";
  271. const std::string DETECTIONOUTPUT_ATTR_IOU_THRESHOLD_DECAY = "iou_threshold_decay";
  272. const std::string DETECTIONOUTPUT_ATTR_COOR_SCALE_FACTOR = "coor_scale_factor";
  273. const std::string DETECTIONOUTPUT_ATTR_YOLO_VERSION = "yolo_version";
  274. // DetectionPostprocess
  275. const std::string POSTPROCESS_ATTR_NAME_CLS_NUM = "cls_num";
  276. const std::string POSTPROCESS_ATTR_NAME_CONF_THRESH = "conf_thresh";
  277. const std::string POSTPROCESS_ATTR_NAME_NMS_THRESH = "nms_thresh";
  278. const std::string POSTPROCESS_ATTR_POST_NMS_TOPN = "post_nms_topn";
  279. const std::string POSTPROCESS_ATTR_NAME_BBOX_REG_WEIGHT = "bbox_reg_weights";
  280. // Spatialtransfrom
  281. const std::string SPTIALTF_ATTR_NAME_OUTPUT_H = "output_h";
  282. const std::string SPTIALTF_ATTR_NAME_OUTPUT_W = "output_w";
  283. const std::string SPTIALTF_ATTR_NAME_BORDER_VALUE = "border_value";
  284. const std::string SPTIALTF_ATTR_NAME_AFFINE_TRANSFORM = "affine_transform";
  285. // Proposa
  286. const std::string PROPOSAL_ATTR_NAME_FEAT_STRIDE = "feat_stride";
  287. const std::string PROPOSAL_ATTR_NAME_BASE_SIZE = "base_size";
  288. const std::string PROPOSAL_ATTR_NAME_MIN_SIZE = "min_size";
  289. const std::string PROPOSAL_ATTR_NAME_RATIO = "ratio";
  290. const std::string PROPOSAL_ATTR_NAME_SCALE = "scale";
  291. const std::string PROPOSAL_ATTR_NAME_PRE_NMS_TOPN = "pre_nms_topn";
  292. const std::string PROPOSAL_ATTR_NAME_POST_NMS_TOPN = "post_nms_topn";
  293. const std::string PROPOSAL_ATTR_NAME_NMS_THRESH = "nms_thresh";
  294. const std::string PROPOSAL_ATTR_NAME_TOP_SIZE = "top_size";
  295. const std::string PROPOSAL_ATTR_IMG_H = "img_h";
  296. const std::string PROPOSAL_ATTR_IMG_W = "img_w";
  297. // Softmax
  298. const std::string SOFTMAX_ATTR_AXIS = "axis";
  299. // Permute
  300. const std::string PERMUTE_ATTR_ORDER = "order";
  301. const std::string PERMUTE_ATTR_PERM = "perm";
  302. // SSD Normalize
  303. const std::string SSDNORMALIZE_ATTR_ACCROSS_SPATIAL = "across_spatial";
  304. const std::string SSDNORMALIZE_ATTR_CHANNEL_SHARED = "channel_shared";
  305. const std::string SSDNORMALIZE_ATTR_EPS = "eps";
  306. // Flatten
  307. const std::string FLATTEN_ATTR_AXIS = "axis";
  308. const std::string FLATTEN_ATTR_END_AXIS = "end_axis";
  309. // SsdPRIORBOX
  310. const std::string SSD_PRIOR_BOX_ATTR_FLIP = "flip";
  311. const std::string SSD_PRIOR_BOX_ATTR_CLIP = "clip";
  312. const std::string SSD_PRIOR_BOX_ATTR_IMG_H = "img_h";
  313. const std::string SSD_PRIOR_BOX_ATTR_IMG_W = "img_w";
  314. const std::string SSD_PRIOR_BOX_ATTR_STEP_H = "step_h";
  315. const std::string SSD_PRIOR_BOX_ATTR_STEP_W = "step_w";
  316. const std::string SSD_PRIOR_BOX_ATTR_OFFSET = "offset";
  317. const std::string SSD_PRIOR_BOX_ATTR_MIN_SIZE = "min_size";
  318. const std::string SSD_PRIOR_BOX_ATTR_MAX_SIZE = "max_size";
  319. const std::string SSD_PRIOR_BOX_ATTR_MIN_SIZE_NUM = "min_size_num";
  320. const std::string SSD_PRIOR_BOX_ATTR_MAX_SIZE_NUM = "max_size_num";
  321. const std::string SSD_PRIOR_BOX_ATTR_ASPECT_RATIO = "aspect_ratio";
  322. const std::string SSD_PRIOR_BOX_ATTR_ASPECT_RATIO_NUM = "aspect_ratio_num";
  323. const std::string SSD_PRIOR_BOX_ATTR_VARIANCE = "variance";
  324. const std::string SSD_PRIOR_BOX_ATTR_VARIANCE_NUM = "variance_num";
  325. // RefinedetDetectionOutput
  326. const std::string REFINEDET_PRIOR_BOX_ATTR_VARIANCE_NUM = "variance_num";
  327. const std::string REFINEDET_PRIOR_BOX_ATTR_VARIANCE = "variance";
  328. // PRelu
  329. const std::string PRELU_ATTR_CHANNEL_SHARED = "channel_shared";
  330. // Psroi pooling
  331. const std::string PSROIPOOLING_ATTR_SPATIAL_SCALE = "spatial_scale";
  332. const std::string PSROIPOOLING_ATTR_OUTPUT_DIM = "output_dim";
  333. const std::string PSROIPOOLING_ATTR_GROUP_SIZE = "group_size";
  334. // Power
  335. const std::string POWER_ATTR_NAME_POWER = "power";
  336. const std::string POWER_ATTR_NAME_SCALE = "scale";
  337. const std::string POWER_ATTR_NAME_SHIFT = "shift";
  338. // log
  339. const std::string LOG_ATTR_NAME_SCALE = "scale";
  340. const std::string LOG_ATTR_NAME_SHIFT = "shift";
  341. const std::string LOG_ATTR_NAME_BASE = "base";
  342. // Pack
  343. const std::string PACK_ATTR_NAME_NUM = "N";
  344. // Unpack
  345. const std::string UNPACK_ATTR_NAME_NUM = "num";
  346. const std::string DYNAMIC_STITCH_ATTR_NAME_NUM = "DynamicStitchN_";
  347. // Gathernd
  348. const std::string GATHERND_ATTR_NAME_TINDICES = "Tindices";
  349. const std::string GATHERND_ATTR_NAME_TPARAMS = "Tparams";
  350. // Argmax
  351. const std::string ARGMAX_ATTR_NAME_TOPK = "topk";
  352. const std::string ARGMAX_ATTR_NAME_REDUCESIZE = "reduce_size";
  353. const std::string ARGMAX_ATTR_NAME_REDUCESTRIDE = "reduce_stride";
  354. const std::string ARGMAX_ATTR_NAME_OUTMAX = "outmaxval";
  355. const std::string ARGMAX_ATTR_NAME_AXIS = "axis";
  356. const std::string ARGMAX_ATTR_NAME_AXISTYPE = "axis_type";
  357. const std::string ARGMAX_ATTR_NAME_KEEPDIMS = "keep_dims";
  358. // upsample
  359. const std::string UPSAMPLE_ATTR_NAME_SCALE_H = "scale_h";
  360. const std::string UPSAMPLE_ATTR_NAME_SCALE_W = "scale_w";
  361. // Relu
  362. const std::string ATTR_NAME_NEGATIVE_SLOPE = "negative_slope";
  363. // FreeSpaceExtract
  364. const std::string FREESPACEEXTRACT_ATTR_NAME_ORG_HEIGHT = "org_height";
  365. // Split
  366. const std::string SPLIT_ATTR_NAME_SLICE_POINT = "slice_point";
  367. const std::string SPLIT_ATTR_NAME_SIZE_SPLIT = "size_split";
  368. const std::string SPLIT_ATTR_NAME_NUM_SPLIT = "num_split";
  369. // Tvm
  370. const std::string TVM_ATTR_NAME_MAGIC = "tvm_magic";
  371. const std::string TVM_ATTR_NAME_BLOCKDIM = "tvm_blockdim";
  372. const std::string TVM_ATTR_NAME_METADATA = "tvm_metadata";
  373. const std::string TVM_ATTR_NAME_WORKSPACE_TYPE = "tvm_workspace_type";
  374. // Squeeze
  375. const std::string SQUEEZE_ATTR_AXIS = "axis";
  376. const std::string SQUEEZE_ATTR_DIMS = "squeeze_dims";
  377. const std::string SQUEEZE_OP_NAME = "Squeeze";
  378. // Stride slice
  379. const std::string STRIDE_SLICE_ATTR_BEGIN_MASK = "begin_mask";
  380. const std::string STRIDE_SLICE_ATTR_END_MASK = "end_mask";
  381. const std::string STRIDE_SLICE_ATTR_ELLIPSIS_MASK = "ellipsis_mask";
  382. const std::string STRIDE_SLICE_ATTR_NEW_AXIS_MASK = "new_axis_mask";
  383. const std::string STRIDE_SLICE_ATTR_SHRINK_AXIS_MASK = "shrink_axis_mask";
  384. // Slice
  385. const std::string SLICE_ATTR_NAME_BEGINS = "begins";
  386. const std::string SLICE_ATTR_NAME_SIZES = "sizes";
  387. // Roialign
  388. const std::string ROIALIGN_ATTR_SPATIAL_SCALE = "spatial_scale";
  389. const std::string ROIALIGN_ATTR_SAMPLING_RATIO = "sampling_ratio";
  390. const std::string ROIALIGN_ATTR_NAME_POOLED_H = "pooled_h";
  391. const std::string ROIALIGN_ATTR_NAME_POOLED_W = "pooled_w";
  392. // Generate_rpn_proposal
  393. const std::string GENERATE_RPN_PROPOSAL_ATTR_PRE_NMS_TOPK = "pre_nms_topk";
  394. const std::string GENERATE_RPN_PROPOSAL_ATTR_POST_NMS_TOPK = "post_nms_topk";
  395. const std::string GENERATE_RPN_PROPOSAL_ATTR_RPN_MINI_SIZE = "rpn_mini_size";
  396. const std::string GENERATE_RPN_PROPOSAL_ATTR_RPN_PROPOSAL_NMS_THRESH = "rpn_proposal_nms_thresh";
  397. const std::string GENERATE_RPN_PROPOSAL_ATTR_RPN_PROPOSAL_FILTER_THRESH = "rpn_proposal_filter_thresh";
  398. // Decode_bbox
  399. const std::string DECODE_BBOX_ATTR_DECODECLIP = "decodeClip";
  400. // Cast
  401. const std::string CAST_ATTR_DSTT = "DstT";
  402. const std::string CAST_ATTR_SRCT = "SrcT";
  403. const std::string CAST_ATTR_DST_TYPE = "dst_type";
  404. const std::string CAST_ATTR_TRUNCATE = "truncate";
  405. // Fastrcnnn predications
  406. const std::string FASTRCNN_PREDICTIONS_ATTR_TOPK = "fsr_topk";
  407. const std::string FASTRCNN_PREDICTIONS_ATTR_SCORE_THRESHOLD = "fsr_score_thres";
  408. const std::string FASTRCNN_PREDICTIONS_ATTR_NMS_THRESHOLD = "fsr_nms_thres";
  409. const std::string FASTRCNN_PREDICTIONS_ATTR_NUM_CLASSES = "fsr_num_classes";
  410. // REORG
  411. const std::string REORG_ATTR_STRIDE = "stride";
  412. const std::string REORG_ATTR_REVERSE = "reverse";
  413. // MERGE
  414. const std::string MERGE_DEAD_INDEX = "merge_dead_index";
  415. const std::string MERGE_PRENODE_FLAG = "merge_prenode_flag";
  416. const std::string TO_BE_OUTPUT = "to_be_output";
  417. // ENTER
  418. const std::string ENTER_ATTR_FRAME_NAME = "frame_name";
  419. const std::string ENTER_ATTR_CONSTANT_FLAG = "is_constant";
  420. // Concatv2
  421. const std::string CONCAT_V2_ATTR_TIDX = "Tidx";
  422. const std::string CONCAT_V2_ATTR_N = "N";
  423. // SUM
  424. const std::string SUM_ATTR_TIDX = "Tidx";
  425. const std::string SUM_ATTR_AXIS = "axis";
  426. const std::string SUM_ATTR_KEEP_DIMS = "keep_dims";
  427. // ResizeBilinear
  428. const std::string RESIZE_BILINEAR_ATTR_MODE = "mode";
  429. const std::string RESIZE_BILINEAR_ATTR_ALIGN_CORNERS = "align_corners";
  430. const std::string RESIZE_BILINEAR_ATTR_HEIGHT = "height";
  431. const std::string RESIZE_BILINEAR_ATTR_WIDTH = "width";
  432. const std::string RESIZE_BILINEAR_ATTR_ZOOM_FACTOR = "zoom_factor";
  433. const std::string RESIZE_BILINEAR_ATTR_SHRINK_FACTOR = "shrink_factor";
  434. const std::string RESIZE_BILINEAR_ATTR_PAD_BEGIN = "pad_begin";
  435. const std::string RESIZE_BILINEAR_ATTR_PAD_END = "pad_end";
  436. const std::string RESIZE_BILINEAR_ATTR_ALPHA = "alpha";
  437. const std::string RESIZE_BILINEAR_ATTR_BETA = "beta";
  438. // RetinaNet
  439. const std::string RETINANET_FILTER_BACKGROUND_TRUE = "retina_conv_filter_background";
  440. const std::string RETINANET_ANCHOR_FUSION = "retina_anchor_fusion";
  441. // MatMul
  442. const std::string MATMUL_TRANSPOSE_X = "transposeX";
  443. const std::string MATMUL_TRANSPOSE_W = "transposeW";
  444. const std::string MATMUL_HAS_BIAS = "has_bias";
  445. const std::string MATMUL_ATTR_IS_TRAINING = "matmul_is_training";
  446. // Flatten
  447. const std::string FLATTEN_START_AXIS = "start_axis";
  448. const std::string FLATTEN_END_AXIS = "end_axis";
  449. // Reshape
  450. const std::string RESHAPE_ATTR_AXIS = "axis";
  451. const std::string RESHAPE_ATTR_NUM_AXES = "num_axes";
  452. const std::string RESHAPE_ATTR_FORMAT = "format";
  453. const std::string RESHAPE_ATTR_SHAPE = "shape";
  454. const std::string RESHAPE_ATTR_ALPHA = "alpha";
  455. const std::string RESHAPE_ATTR_BETA = "beta";
  456. // Frameoworkop
  457. const std::string T_IN_DATATYPE = "t_in_datatype";
  458. const std::string T_OUT_DATATYPE = "t_out_datatype";
  459. const std::string ATTR_NAME_OUT_N = "out_n";
  460. const std::string ATTR_NAME_OUT_C = "out_c";
  461. const std::string ATTR_NAME_OUT_H = "out_h";
  462. const std::string ATTR_NAME_OUT_W = "out_w";
  463. const std::string ATTR_PAD_DEPTH_CONV = "pad_depth_conv";
  464. const std::string ATTR_PAD_CONV = "pad_conv";
  465. const std::string ATTR_NAME_BEFORE_PAD = "before_pad";
  466. const std::string ANN_MEAN_KEEPDIMS = "AnnMeanKeepDims";
  467. const std::string PAD_ATTR_PADDINGDS = "paddings";
  468. const std::string PAD_ATTR_CONSTANT_VALUE = "padvalue";
  469. // ConvGradFilter
  470. const std::string CONV_GRAD_FILTER_OUTPUT_SHAPE = "conv_grad_filter_output_shape";
  471. // ConvGradInput
  472. const std::string CONV_GRAD_INPUT_OUTPUT_SHAPE = "conv_grad_input_output_shape";
  473. // Rnn
  474. const std::string RNN_MODE_STATIC = "rnn_static";
  475. const std::string MUTI_RNN = "multi_rnn";
  476. const std::string CNN_RNN = "cnn_rnn";
  477. const std::string RNN_MODE_ = "rnn_";
  478. const std::string CELL_MODE = "mode";
  479. const std::string LSTM_CELL = "lstm_cell";
  480. const std::string GRU_CELL = "gru_cell";
  481. const std::string RNN_HT = "ht";
  482. const std::string RNN_XT_HT = "xt_ht";
  483. const std::string RNN_BATCH_SIZE = "batch_size";
  484. const std::string LSTM_CELL_CLIP = "lstm_cell_clip";
  485. const std::string LSTM_PROJ_CLIP = "lstm_proj_clip";
  486. const std::string LSTM_ACTIVATE = "lstm_activate";
  487. const std::string LSTM_OUT_MAP = "lstm_out_map";
  488. const std::string LSTM_OUT_MODE = "lstm_out_mode";
  489. const std::string LSTM_STATE_OUT_MODE = "lstm_state_out_mode";
  490. const std::string LSTM_TIME_MAJOR = "lstm_time_major";
  491. const std::string LSTM_IS_INPUT_PRE_PROCESS = "lstm_is_input_pre_process";
  492. // Upsample
  493. const std::string UPSAMPLE_ATTR_NAME_SCALE = "scale";
  494. // PadV2
  495. const std::string PADV2_ATTR_NAME_MODE = "mode";
  496. const std::string PADV2_ATTR_NAME_PADS = "paddings";
  497. const std::string PADV2_ATTR_NAME_T = "T";
  498. const std::string PADV2_ATTR_NAME_PAD_FORMAT = "pad_format";
  499. const std::string PADV2_ATTR_NAME_CONST_VALUE = "const_value";
  500. // MirrorPad
  501. const std::string MIRRORPAD_ATTR_NAME_MODE = "mode";
  502. const std::string MIRRORPAD_ATTR_NAME_PADS = "paddings";
  503. const std::string MIRRORPAD_ATTR_NAME_PAD_FORMAT = "pad_format";
  504. const std::string MIRRORPAD_ATTR_NAME_CONST_VALUE = "const_value";
  505. // Filler
  506. const std::string FILLER_TYPE = "filler_type";
  507. const std::string FILLER_VALUE = "filler_value";
  508. // Shufflechannel
  509. const std::string SHUFFLE_CHANNEL_GROUP = "group";
  510. // TopKV2
  511. const std::string TOPKV2_ATTR_K = "k";
  512. // Calibaration
  513. const std::string STRIDE_H_INDEX = "STRIDE_H_INDEX";
  514. const std::string STRIDE_W_INDEX = "STRIDE_W_INDEX";
  515. const std::string PAD_TOP_INDEX = "PAD_TOP_INDEX";
  516. const std::string PAD_BOTTOM_INDEX = "PAD_BOTTOM_INDEX";
  517. const std::string PAD_RIGHT_INDEX = "PAD_RIGHT_INDEX";
  518. const std::string PAD_LEFT_INDEX = "PAD_LEFT_INDEX";
  519. const std::string QUANTIZE_ALGO_ATTR = "quantize_algo";
  520. const std::string SCALE_TYPE_ATTR = "scale_type";
  521. const std::string QUANTIZE_SCALE_MODE = "quantize_scale_mode";
  522. const std::string QUANTIZE_SCALE_VALUE = "quantize_scale_value";
  523. const std::string QUANTIZE_SCALE_OFFSET = "quantize_scale_offset";
  524. const std::string QUANTIZE_OFFSET_DATA_VALUE = "quantize_offset_data_value";
  525. const std::string QUANTIZE_OFFSET_DATA_OFFSET = "quantize_offset_data_offset";
  526. const std::string QUANTIZE_OFFSET_WEIGHT_VALUE = "quantize_offset_weight_value";
  527. const std::string QUANTIZE_OFFSET_WEIGHT_OFFSET = "quantize_offset_weight_offset";
  528. const std::string QUANTIZE_OFFSET_PAD_VALUE = "quantize_offset_pad_value";
  529. const std::string QUANTIZE_OFFSET_PAD_OFFSET = "quantize_offset_pad_offset";
  530. const std::string DEQUANTIZE_SCALE_MODE = "dequantize_scale_mode";
  531. const std::string DEQUANTIZE_SCALE_VALUE = "dequantize_scale_value";
  532. const std::string DEQUANTIZE_SCALE_OFFSET = "dequantize_scale_offset";
  533. const std::string DEQUANTIZE_OFFSET_DATA_TYPE = "dequantize_offset_data_value";
  534. const std::string DEQUANTIZE_OFFSET_DATA_OFFSET = "dequantize_offset_data_offset";
  535. const std::string DEQUANTIZE_OFFSET_WEIGHT_VALUE = "dequantize_offset_weight_value";
  536. const std::string DEQUANTIZE_OFFSET_WEIGHT_OFFSET = "dequantize_offset_weight_offset";
  537. const std::string DEQUANTIZE_OFFSET_PAD_VALUE = "dequantize_offset_pad_value";
  538. const std::string DEQUANTIZE_OFFSET_PAD_OFFSET = "dequantize_offset_pad_offset";
  539. const std::string REQUANTIZE_SCALE_MODE = "requantize_scale_mode";
  540. const std::string REQUANTIZE_SCALE_VALUE = "requantize_scale_value";
  541. const std::string REQUANTIZE_SCALE_OFFSET = "requantize_scale_offset";
  542. const std::string REQUANTIZE_OFFSET_DATA_VALUE = "requantize_offset_data_value";
  543. const std::string REQUANTIZE_OFFSET_DATA_OFFSET = "requantize_offset_data_offset";
  544. const std::string REQUANTIZE_OFFSET_WEIGHT_VALUE = "requantize_offset_weight_value";
  545. const std::string REQUANTIZE_OFFSET_WEIGHT_OFFSET = "requantize_offset_weight_offset";
  546. const std::string REQUANTIZE_OFFSET_PAD_VALUE = "requantize_offset_pad_value";
  547. const std::string REQUANTIZE_OFFSET_PAD_OFFSET = "requantize_offset_pad_offset";
  548. const std::string ATTR_NAME_IS_CONST = "attr_name_is_const";
  549. const std::string ATTR_NAME_GROUP = "group";
  550. const std::string ATTR_NAME_DILATION_SIZE = "dilation_size";
  551. const std::string ATTR_NAME_EPSILON = "epsilon";
  552. const std::string ATTR_NAME_POOLING_MODE = "mode";
  553. const std::string ATTR_NAME_CLASS_NUM = "class_num";
  554. // model
  555. const std::string ATTR_MODEL_TARGET_TYPE = "target_type";
  556. const std::string ATTR_MODEL_STREAM_NUM = "stream_num";
  557. const std::string ATTR_MODEL_EVENT_NUM = "event_num";
  558. const std::string ATTR_MODEL_HUGE_STREAM_LIST = "huge_stream_list";
  559. const std::string ATTR_MODEL_LABEL_NUM = "label_num";
  560. const std::string ATTR_MODEL_MEMORY_SIZE = "memory_size";
  561. const std::string ATTR_MODEL_ZERO_COPY_MEMORY_SIZE = "zero_copy_memory_size";
  562. const std::string ATTR_MODEL_OUT_NODES_NAME = "attr_model_out_nodes_name";
  563. const std::string ATTR_MODEL_WEIGHT_SIZE = "weight_size";
  564. const std::string ATTR_MODEL_TASK_GEN_BASE_ADDR = "task_gen_base_addr";
  565. const std::string ATTR_MODEL_TASK_GEN_WEIGHT_ADDR = "task_gen_weight_addr";
  566. const std::string ATTR_MODEL_TASK_GEN_VAR_ADDR = "task_gen_variable_addr";
  567. const std::string ATTR_MODEL_VAR_SIZE = "variable_size";
  568. const std::string ATTR_MODEL_TASK_INDEX_OP_NAME = "task_index_op_name";
  569. const std::string ATTR_MODEL_CORE_TYPE = "core_type";
  570. const std::string ATTR_MODEL_ATC_VERSION = "atc_version";
  571. const std::string ATTR_MODEL_OPP_VERSION = "opp_version";
  572. // Public attribute
  573. const std::string ATTR_NAME_IMPLY_TYPE = "imply_type";
  574. const std::string ATTR_NAME_BYTE_SIZE = "op_byte_size";
  575. const std::string ATTR_NAME_FUSION_INFERENCE_ID = "fusion_inference_id";
  576. const std::string ATTR_NAME_FUSION_OPDEF = "fusion_opdef";
  577. const std::string ATTR_NAME_IO_OP = "io_op";
  578. const std::string ATTR_NAME_FUSION_SCOPE = "fusion_scope";
  579. const std::string ATTR_NAME_OPATTR = "opattr";
  580. const std::string ATTR_NAME_RELUFLAG = "relu_flag";
  581. const std::string ATTR_NAME_SEQLEN_INDEX = "seqlen_index";
  582. const std::string ATTR_NAME_X_INDEX = "x_index";
  583. const std::string ATTR_NAME_CONT_INDEX = "cont_index";
  584. const std::string ATTR_NAME_XSTATIC_INDEX = "xstatic_index";
  585. const std::string TARGET_TYPE_MINI = "MINI";
  586. const std::string TARGET_TYPE_TINY = "TINY";
  587. const std::string TARGET_TYPE_LITE = "LITE";
  588. // l2_normalize
  589. const std::string L2_NORMALIZE_ATTR_AXIS = "axis";
  590. const std::string L2_NORMALIZE_ATTR_EPS = "eps";
  591. const std::string POOL_PARAMA_ATTR_WINDOW = "window";
  592. const std::string POOL_PARAMA_ATTR_CEIL_MODE = "ceil_mode";
  593. const std::string POOL_PARAMA_ATTR_DATA_MODE = "data_mode";
  594. const std::string POOL_PARAMA_ATTR_GLOBAL_POOLING = "global_pooling";
  595. const std::string POOL_PARAMA_ATTR_NAN_OP = "nan_opt";
  596. const std::string POOL_PARAMA_ATTR_PAD_MOD = "pad_mode";
  597. // HCOM
  598. const std::string HCOM_ATTR_ROOT_RANK = "root_rank";
  599. const std::string HCOM_ATTR_RANK_SIZE = "rank_size";
  600. const std::string HCOM_ATTR_REDUCE_TYPE = "reduction";
  601. const std::string HCOM_ATTR_GROUP = "group";
  602. const std::string HCOM_ATTR_SR_TAG = "sr_tag";
  603. const std::string HCOM_ATTR_SRC_RANK = "src_rank";
  604. const std::string HCOM_ATTR_DEST_RANK = "dest_rank";
  605. const std::string HCOM_ATTR_FUSION = "fusion";
  606. const std::string HCOM_ATTR_SHAPE = "shape";
  607. const std::string HCOM_ATTR_DATA_TYPE = "dtype";
  608. // SpaceToDepth/DepthToSpace
  609. const std::string ATTR_NAME_BLOCK_SIZE = "block_size";
  610. // SparseSoftmaxCrossEntropyWithLogits
  611. const std::string SPARSE_SOFT_MAX_ATTR_TLABLES = "Tlabels";
  612. // MaxPoolGradWithArgmax
  613. const std::string MAX_POOL_GRAD_OUTPUT_SHAPE = "max_pool_grad_output_shape";
  614. // AvgPoolGrad
  615. const std::string AVG_POOL_GRAD_OUTPUT_SHAPE = "avg_pool_grad_output_shape";
  616. // Pad
  617. const std::string ATTR_PAD_FORMAT = "attr_pad_format";
  618. // Varible
  619. const std::string VAR_ATTR_FORMAT = "_var_format";
  620. const std::string VAR_ATTR_NAME = "var_name";
  621. const std::string VAR_ATTR_FRACTALZ_FORMAT = "FZ";
  622. const std::string VAR_ATTR_4D_FORMAT = "4D";
  623. const std::string VAR_ATTR_5D_FORMAT = "5D";
  624. const std::string VAR_ATTR_DATA_TYPE = "data_format";
  625. const std::string VAR_ATTR_VAR_IN_NAME = "var_in_name";
  626. const std::string VAR_ATTR_VAR_IN_INDEX = "var_in_index";
  627. const std::string VAR_ATTR_VAR_OUT_INDEX = "var_out_index";
  628. const std::string VAR_ATTR_SHAPE = "shape";
  629. const std::string HALF_VAR_NAME_END = "_fp16";
  630. const std::string VAR_ATTR_INITED = "var_is_inited";
  631. const std::string VAR_ATTR_CONTAINER = "container";
  632. const std::string VAR_ATTR_SHARED_NAME = "shared_name";
  633. const std::string VAR_ATTR_DTYPE = "dtype";
  634. const std::string VAR_ATTR_SRC_VAR_NAME = "_src_var_name";
  635. const std::string VAR_ATTR_VAR_IS_SAVE = "_var_is_save";
  636. const std::string VAR_ATTR_VAR_IS_RESTORE = "_var_is_restore";
  637. const std::string VAR_ATTR_VAR_IS_BROADCAST = "_var_is_broadcast";
  638. const std::string REF_VAR_SRC_VAR_NAME = "ref_var_src_var_name";
  639. const std::string REF_VAR_PRE_PEER_OUT_INDEX = "ref_var_pre_peer_out_index";
  640. // Assign
  641. const std::string ASSIGN_VALIDATE_SHAPE = "validate_shape";
  642. const std::string ASSIGN_VAR_NAME = "_assign_var_name";
  643. // space2bacth batch2space
  644. const std::string BATCH_SPACE_ATTR_BLOCK = "block";
  645. const std::string BATCH_SPACE_ATTR_PADDING = "padding";
  646. // depth_to_space space_to_depth
  647. const std::string DEPTH_SPACE_ATTR_BLOCK_SIZE = "block_size";
  648. // FakeQuantWithMinMaxVars
  649. const std::string FakeQuantWithMinMaxVars_ATTR_MAX = "max";
  650. const std::string FakeQuantWithMinMaxVars_ATTR_MIN = "min";
  651. // mobilenet_ssd_conv_fusion
  652. const std::string SSD_BOXPREDICTOR_BOXES_FUSION = "ssd_boxpredictor_boxes_fusion";
  653. const std::string SSD_BOXPREDICTOR_SCORES_FUSION = "ssd_boxpredictor_scores_fusion";
  654. const std::string SSD_BOXPREDICTOR_FUSION_BOX_TYPE_NUM = "ssd_boxpredictor_fusion_box_type_num";
  655. // lsh project
  656. const std::string LSH_PROJ_TYPE = "lsh_project_type";
  657. // log time stamp
  658. const std::string LOG_TIME_STAMP_LOGID = "logid";
  659. const std::string LOG_TIME_STAMP_NOTIFY = "notify";
  660. // ShapeN
  661. const std::string SHAPEN_ATTR_N = "N";
  662. const std::string SHAPEN_ATTR_IN_TYPE = "in_type";
  663. const std::string SHAPEN_ATTR_OUT_TYPE = "dtype";
  664. // GatherV2 attr def
  665. const std::string GATHERV2_ATTR_NAME_TAXIS = "Taxis";
  666. const std::string GATHERV2_ATTR_NAME_TINDICES = "Tindices";
  667. const std::string GATHERV2_ATTR_NAME_TPARAMS = "Tparams";
  668. // Reshape attr def
  669. const std::string RESHAPE_ATTR_NAME_INPUT_DESC = "input_desc_reshape";
  670. const std::string RESHAPE_ATTR_NAME_OUTPUT_DESC = "output_desc_reshape";
  671. // axis attr def
  672. const std::string ATTR_NAME_AXIS_ORG_OP = "axis_org_op";
  673. const std::string ATTR_NAME_LINK_WITH_SPARE = "link_with_sparse";
  674. const std::string ATTR_NAME_NET_OUTPUT_FORMAT = "net_output_format";
  675. const std::string ATTR_NAME_NET_OUTPUT_DATATYPE = "net_output_datatype";
  676. // For constant folding
  677. const std::string ATTR_NO_NEED_CONSTANT_FOLDING = "no_need_constant_folding";
  678. const std::string ATTR_NAME_CONTINUOUS_INPUT = "continuous_input";
  679. const std::string ATTR_NAME_CONTINUOUS_INPUT_ALLOC = "continuous_input_alloc";
  680. const std::string ATTR_NAME_CONTINUOUS_OUTPUT = "continuous_output";
  681. const std::string ATTR_NAME_REFERENCE = "reference";
  682. const std::string ATTR_NAME_NOTASK = "_no_task";
  683. const std::string ATTR_NAME_OUTPUT_REUSE_INPUT = "_output_reuse_input";
  684. const std::string ATTR_NAME_REUSE_INPUT_ON_DIM_INDEX = "_reuse_input_on_dim_index";
  685. const std::string ATTR_NAME_NOPADDING_CONTINUOUS_INPUT = "_no_padding_continuous_input";
  686. const std::string ATTR_NAME_NOPADDING_CONTINUOUS_OUTPUT = "_no_padding_continuous_output";
  687. const std::string ATTR_NAME_ATOMIC_INDEX = "atomic_index";
  688. // Used for mark the active label list stream of activated node
  689. const std::string ATTR_NAME_ACTIVE_LABEL_LIST = "_active_label_list";
  690. // Used for l2cache, true: the memory of all inputs is used for the last time.
  691. const std::string ATTR_NAME_IS_END_OF_INPUTMEM_LIFECYCLE = "is_end_of_inputmem_lifecycle";
  692. // Multi batch
  693. const std::string ATTR_NAME_PRED_VALUE = "_pred_value";
  694. const std::string ATTR_NAME_BATCH_NUM = "_batch_num";
  695. const std::string ATTR_NAME_BATCH_LABEL = "_batch_label";
  696. const std::string ATTR_NAME_COMBINED_BATCH = "_combined_batch";
  697. // Control flow
  698. const std::string ATTR_NAME_STREAM_SWITCH_COND = "switch_condition";
  699. const std::string ATTR_NAME_TRUE_BRANCH_STREAM = "true_branch_stream";
  700. const std::string ATTR_NAME_ACTIVE_STREAM_LIST = "active_stream_list";
  701. const std::string ATTR_NAME_SWITCHN_PRED_VALUE = "switch_pred_value";
  702. const std::string ATTR_NAME_ITERATORS_PER_LOOP = "iterations_per_loop";
  703. const std::string ATTR_NAME_FLOW_CTRL_NODE_FLAG = "is_flow_ctrl_node";
  704. const std::string ATTR_NAME_SUBGRAPH_FIRST_ACTIVE = "subgraph_first_active";
  705. const std::string ATTR_NAME_COMBINED_DYNAMIC_DIMS = "combined_dynamic_dims";
  706. const std::string ATTR_NAME_SWITCH_BRANCH_NODE_LABEL = "_switch_branch_node_label";
  707. const std::string ATTR_NAME_SWITCH_TRUE_BRANCH_FLAG = "_switch_true_branch_flag";
  708. const std::string ATTR_NAME_SWITCH_DATA_TYPE = "_switch_data_type";
  709. const std::string ATTR_NAME_ORIG_NODE_NAME = "_original_node_name";
  710. const std::string ATTR_NAME_CYCLIC_DEPENDENCE_FLAG = "_cyclic_dependence_flag";
  711. const std::string ATTR_NAME_NEXT_ITERATION = "_next_iteration_node";
  712. // Function Op
  713. const std::string ATTR_NAME_PARENT_NODE_INDEX = "_parent_node_index";
  714. // Used for mark the active node is for loop, type:bool
  715. const std::string ATTR_NAME_IS_LOOP_ACTIVE = "is_loop_active";
  716. const std::string ATTR_NAME_MEMORY_TYPE_INPUT = "memory_type_input";
  717. const std::string ATTR_NAME_MEMORY_TYPE_OUTPUT = "memory_type_output";
  718. const std::string ATTR_NAME_MEMORY_TYPE_WORKSPACE = "memory_type_workspace";
  719. const std::string ATTR_NAME_MEMORY_TYPE_RANGE = "_memory_type_range";
  720. const std::string MODEL_ATTR_SESSION_ID = "session_id";
  721. // lx fusion
  722. const std::string ATTR_NAME_L1_FUSION_GROUP_ID = "_l1_fusion_group_id";
  723. const std::string ATTR_NAME_FUSION_GROUP_KEY = "_fusion_group_key";
  724. const std::string ATTR_NAME_L1_FUSION_GROUP_KEY = "_l1_fusion_group_key";
  725. const std::string ATTR_NAME_FUSION_VIRTUAL_OP = "_fusion_virtual_op";
  726. const std::string ATTR_NAME_FUSION_GROUP_TYPE = "_fusion_group_type";
  727. const std::string ATTR_NAME_INPUT_MEM_TYPE_LIST = "_input_memory_type";
  728. const std::string ATTR_NAME_OUTPUT_MEM_TYPE_LIST = "_output_memory_type";
  729. const std::string ATTR_NAME_L1_FUSION_EXTEND_PTR = "_l1_fusion_extend_content";
  730. const std::string ATTR_NAME_GET_TENSOR_ACTUAL_SIZE = "_tensor_actual_size";
  731. const std::string ATTR_NAME_OUTPUT_OFFSET_FOR_L1_FUSION = "_output_offset_for_l1_fuison";
  732. const std::string ATTR_NAME_SWITCH_FOR_L1_FUSION = "_enable_l1_fusion";
  733. const std::string ATTR_N_BATCH_SPILT = "_is_n_batch_split";
  734. const std::string ATTR_NO_TASK_AND_DUMP_NEEDED = "_no_task_and_dump_needed";
  735. const std::string ATTR_DATA_DUMP_REF = "_datadump_ref";
  736. const std::string ATTR_NAME_OUTPUT_OFFSET_FOR_BUFFER_FUSION = "_output_offset_for_buffer_fusion";
  737. const std::string ATTR_NAME_L2_FUSION_GROUP_ID = "_l2_fusion_group_id";
  738. const std::string ATTR_NAME_SWITCH_FOR_L2_FUSION = "_enable_l2_fusion";
  739. const std::string ATTR_NAME_OP_INPUT_L1_FLAG = "_op_input_l1_flag";
  740. const std::string ATTR_NAME_OP_INPUT_L1_ADDR = "_op_input_l1_addr";
  741. const std::string ATTR_NAME_OP_INPUT_L1_VALID_SIZE = "_op_input_l1_valid_size";
  742. const std::string ATTR_NAME_ENGINE_NAME_FOR_LX = "_lxfusion_engine_name";
  743. const std::string ATTR_NAME_KKERNEL_LIB_NAME_FOR_LX = "_lxfusion_op_kernel_lib_name";
  744. const std::string ATTR_NAME_NEED_LX_FUSION = "_lx_fusion";
  745. const std::string ATTR_NAME_OPTIMIZE_GROUP = "_optimize_group";
  746. const std::string ATTR_NAME_OP_COMPILE_STRATEGY = "_op_compile_strategy";
  747. const std::string ATTR_NAME_TBE_KERNEL_NAME = "_tbe_kernel_name";
  748. const std::string ATTR_NAME_TBE_KERNEL_BUFFER = "_tbe_kernel_buffer";
  749. // Op debug attrs
  750. const std::string ATTR_OP_DEBUG_FLAG = "_op_debug_flag";
  751. const std::string ATTR_OP_DEBUG_MODE = "_op_debug_mode";
  752. // Atomic addr clean attrs
  753. const std::string ATOMIC_ATTR_INPUT_INDEX = "atomic_input_index";
  754. const std::string ATOMIC_ATTR_OUTPUT_INDEX = "atomic_output_index";
  755. const std::string ATOMIC_ATTR_IS_FUSION_NODE = "is_fusion_node";
  756. const std::string EXT_ATTR_ATOMIC_WORKSPACE_INFO = "sub_node_workspace_info";
  757. const std::string EXT_ATTR_ATOMIC_WORKSPACE_OFFSET = "sub_node_workspace_offset";
  758. const std::string ATOMIC_ATTR_IS_ATOMIC_NODE = "is_atomic_node";
  759. // Source/dst format for Op FormatTransfer
  760. const std::string FORMAT_TRANSFER_SRC_FORMAT = "src_format";
  761. const std::string FORMAT_TRANSFER_DST_FORMAT = "dst_format";
  762. // For compile op by ge call
  763. const std::string ATTR_NEED_COMPILE = "_node_need_compile";
  764. const std::string ATTR_INSERT_BY_MBATCH = "mbatch-inserted-node";
  765. const std::string ATTR_MBATCH_ORIGIN_INPUT_DIMS = "_mbatch_origin_input_dims";
  766. const std::string ATTR_DYNAMIC_TYPE = "mbatch_dynamic_type";
  767. const std::string ATTR_USER_DESIGNEATE_SHAPE_ORDER = "user_designate_shape_order";
  768. // For inserted op
  769. const std::string ATTR_INSERTED_BY_GE = "_inserted_by_ge";
  770. // For compress weight
  771. const std::string ATTR_NAME_COMPRESS_WEIGHT = "_is_compress_weight";
  772. // For data dump
  773. const std::string ATTR_NAME_DATA_DUMP_ORIGIN_OP_NAMES = "_datadump_original_op_names";
  774. const std::string ATTR_NAME_DATA_DUMP_IS_MULTIOP = "_datadump_is_multiop";
  775. const std::string ATTR_NAME_DATA_DUMP_SUB_SPLITER_INDEX = "_datadump_sub_spliter_index";
  776. const std::string ATTR_NAME_DATA_DUMP_GROUP_OP_NAME = "_datadump_group_op_name";
  777. const std::string ATTR_NAME_DATA_DUMP_ORIGIN_NAME = "_datadump_origin_name";
  778. const std::string ATTR_NAME_DATA_DUMP_ORIGIN_OUTPUT_INDEX = "_datadump_origin_output_index";
  779. const std::string ATTR_NAME_DATA_DUMP_ORIGIN_FORMAT = "_datadump_origin_format";
  780. const std::string ATTR_NAME_DATA_DUMP_ORIGIN_DATA_TYPE = "_datadump_origin_data_type";
  781. // functional ops attr
  782. const std::string ATTR_NAME_IF_THEN_BRANCH = "then_branch";
  783. const std::string ATTR_NAME_IF_ELSE_BRANCH = "else_branch";
  784. const std::string ATTR_NAME_WHILE_COND = "cond";
  785. const std::string ATTR_NAME_WHILE_BODY = "body";
  786. // used for label switch
  787. const std::string ATTR_NAME_LABEL_SWITCH_INDEX = "_label_switch_index";
  788. const std::string ATTR_NAME_LABEL_SWITCH_LIST = "_label_switch_list";
  789. const std::string ATTR_NAME_SUBGRAPH_END_NODE = "_subgraph_end_node";
  790. const std::string ATTR_NAME_INPUT_DATATYPE = "input_datatype";
  791. const std::string ATTR_NAME_OUTPUT_DATATYPE = "output_datatype";
  792. // used for LX tiling
  793. const std::string ATTR_NAME_OP_L1_SPACE = "_l1_space";
  794. const std::string ATTR_NAME_FUSION_TYPE_LIST = "_fusion_type_list";
  795. const std::string ATTR_NAME_VALID_INPUT_SHAPE_LIST_LIST = "_valid_input_shape_list_list";
  796. const std::string ATTR_NAME_VALID_OUTPUT_SHAPE_LIST_LIST = "_valid_output_shape_list_list";
  797. const std::string ATTR_NAME_SLICE_INPUT_OFFSET_LIST_LIST = "_input_offset_list_list";
  798. const std::string ATTR_NAME_SLICE_OUTPUT_OFFSET_LIST_LIST = "_output_offset_list_list";
  799. // for unregistered op
  800. const std::string ATTR_NAME_UNREGST_OPPATH = "_unregst_oppath";
  801. const std::string ATTR_NAME_UNREGST_ATTRLIST = "_unregst_attrlist";
  802. // used for Horovod
  803. const std::string ATTR_INTER_EVENT_IDENTIFY = "event_id";
  804. const std::string ATTR_HOROVOD_ATTR_REDUCE_TYPE = "reduce_op";
  805. // used for allreduce tailing optimization
  806. const std::string ATTR_NAME_HCCL_FUSED_GROUP = "_hccl_fused_group";
  807. const std::string ATTR_NAME_HCCL_FUSED_FLAG = "_hccl_fused_node";
  808. // dynamic shape attr
  809. const std::string ATTR_DYNAMIC_SHAPE_FIXED_ADDR = "_alloc_fixed_addr";
  810. const std::string ATTR_DYNAMIC_SHAPE_FIXED_ADDR_INDEX = "_alloc_fixed_addr_index";
  811. // op dynamic input
  812. const std::string ATTR_NAME_DYNAMIC_INPUT_START = "_dynamic_input_index_start";
  813. const std::string ATTR_NAME_DYNAMIC_INPUT_END = "_dynamic_input_index_end";
  814. // atc user def dtype&format
  815. const std::string ATTR_ATC_USER_DEFINE_DATATYPE = "_user_defined_data_type";
  816. const std::string ATTR_ATC_USER_DEFINE_FORMAT = "_user_defined_format";
  817. // for fusion op plugin
  818. const std::string ATTR_NAME_FUSIONOP_ORIGINAL_TYPE = "_fusionop_original_type";
  819. // graph partition for aicpu
  820. const std::string ATTR_NAME_PLD_FRONT_NODE_ENGINE_NAME = "pld_front_node_engine_name";
  821. const std::string ATTR_NAME_END_REAR_NODE_ENGINE_NAME = "end_rear_node_engine_name";
  822. // input and output memory type
  823. const std::string ATTR_VARIABLE_PLACEMENT = "_variable_placement";
  824. const std::string ATTR_INPUT_MEMORY_TYPE = "_input_memory_type";
  825. const std::string ATTR_OUTPUT_MEMORY_TYPE = "_output_memory_type";
  826. // input_output_offset
  827. const std::string ATTR_ZERO_COPY_BASIC_OFFSET = "_zero_copy_basic_offset";
  828. const std::string ATTR_ZERO_COPY_RELATIVE_OFFSET = "_zero_copy_relative_offset";
  829. } // namespace ge

图引擎模块(GE)是MindSpore的一个子模块,其代码由C++实现,位于前端模块ME和底层硬件之间,起到承接作用。图引擎模块以ME下发的图作为输入,然后进行一系列的深度图优化操作,最后输出一张可以在底层硬件上高效运行的图。GE针对昇腾AI处理器的硬件结构特点,做了特定的优化工作,以此来充分发挥出昇腾AI处理器的强大算力。在进行模型训练/推理时,GE会被自动调用而用户并不感知。GE主要由GE API和GE Core两部分组成,详细的架构图如下所示