mindspore 2.6.0rc1__cp39-cp39-win_amd64.whl → 2.7.0rc1__cp39-cp39-win_amd64.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of mindspore might be problematic. Click here for more details.

Files changed (384) hide show
  1. mindspore/.commit_id +1 -1
  2. mindspore/__init__.py +1 -1
  3. mindspore/_c_dataengine.cp39-win_amd64.pyd +0 -0
  4. mindspore/_c_expression.cp39-win_amd64.pyd +0 -0
  5. mindspore/_c_mindrecord.cp39-win_amd64.pyd +0 -0
  6. mindspore/_checkparam.py +40 -9
  7. mindspore/{_deprecated → _extends/optimize}/__init__.py +9 -3
  8. mindspore/_extends/optimize/cell_utils.py +96 -0
  9. mindspore/_extends/parse/__init__.py +2 -2
  10. mindspore/_extends/parse/compile_config.py +44 -22
  11. mindspore/_extends/parse/deprecated/deprecated_tensor_method.py +1 -1
  12. mindspore/_extends/parse/parser.py +37 -62
  13. mindspore/_extends/parse/resources.py +39 -0
  14. mindspore/_extends/parse/standard_method.py +43 -13
  15. mindspore/_extends/parse/trope.py +8 -1
  16. mindspore/_extends/pijit/__init__.py +1 -2
  17. mindspore/amp.py +4 -4
  18. mindspore/avcodec-59.dll +0 -0
  19. mindspore/avdevice-59.dll +0 -0
  20. mindspore/avfilter-8.dll +0 -0
  21. mindspore/avformat-59.dll +0 -0
  22. mindspore/avutil-57.dll +0 -0
  23. mindspore/boost/adasum.py +1 -1
  24. mindspore/boost/boost_cell_wrapper.py +4 -4
  25. mindspore/common/__init__.py +27 -2
  26. mindspore/common/_grad_function.py +2 -1
  27. mindspore/common/_pijit_context.py +28 -7
  28. mindspore/common/_stub_tensor.py +1 -209
  29. mindspore/common/_tensor_cpp_method.py +1 -1
  30. mindspore/common/_tensor_docs.py +77 -16
  31. mindspore/common/api.py +238 -113
  32. mindspore/common/dtype.py +21 -11
  33. mindspore/common/dump.py +10 -15
  34. mindspore/common/generator.py +5 -3
  35. mindspore/common/hook_handle.py +11 -2
  36. mindspore/common/jit_config.py +1 -1
  37. mindspore/common/jit_trace.py +84 -105
  38. mindspore/common/parameter.py +26 -12
  39. mindspore/common/recompute.py +3 -3
  40. mindspore/common/sparse_tensor.py +0 -3
  41. mindspore/common/symbol.py +0 -1
  42. mindspore/common/tensor.py +81 -81
  43. mindspore/communication/_comm_helper.py +46 -4
  44. mindspore/communication/management.py +79 -7
  45. mindspore/context.py +58 -40
  46. mindspore/dataset/core/config.py +3 -3
  47. mindspore/dataset/engine/datasets.py +20 -7
  48. mindspore/dataset/engine/datasets_user_defined.py +33 -3
  49. mindspore/dataset/engine/iterators.py +2 -2
  50. mindspore/dataset/engine/obs/config_loader.py +2 -2
  51. mindspore/dataset/engine/obs/obs_mindrecord_dataset.py +8 -0
  52. mindspore/dataset/transforms/py_transforms.py +7 -3
  53. mindspore/dataset/transforms/transforms.py +7 -3
  54. mindspore/dataset/vision/validators.py +1 -0
  55. mindspore/device_context/ascend/device.py +1 -1
  56. mindspore/device_context/gpu/__init__.py +2 -2
  57. mindspore/device_context/gpu/device.py +1 -1
  58. mindspore/device_context/gpu/op_precision.py +4 -2
  59. mindspore/device_context/gpu/op_tuning.py +6 -3
  60. mindspore/device_manager.py +16 -9
  61. mindspore/dnnl.dll +0 -0
  62. mindspore/experimental/llm_boost/ascend_native/llama_boost_ascend_native.py +3 -7
  63. mindspore/experimental/llm_boost/atb/boost_base.py +2 -3
  64. mindspore/experimental/optim/adadelta.py +13 -20
  65. mindspore/experimental/optim/adagrad.py +15 -22
  66. mindspore/experimental/optim/adam.py +17 -24
  67. mindspore/experimental/optim/adamax.py +14 -22
  68. mindspore/experimental/optim/adamw.py +28 -34
  69. mindspore/experimental/optim/asgd.py +15 -25
  70. mindspore/experimental/optim/lr_scheduler.py +27 -45
  71. mindspore/experimental/optim/nadam.py +14 -24
  72. mindspore/experimental/optim/optimizer.py +13 -23
  73. mindspore/experimental/optim/radam.py +18 -24
  74. mindspore/experimental/optim/rmsprop.py +14 -25
  75. mindspore/experimental/optim/rprop.py +15 -26
  76. mindspore/experimental/optim/sgd.py +9 -19
  77. mindspore/hal/__init__.py +4 -4
  78. mindspore/hal/contiguous_tensors_handle.py +2 -2
  79. mindspore/hal/memory.py +27 -7
  80. mindspore/include/api/cell.h +37 -1
  81. mindspore/include/api/delegate.h +10 -0
  82. mindspore/include/api/model.h +3 -0
  83. mindspore/include/api/types.h +2 -2
  84. mindspore/include/c_api/model_c.h +0 -58
  85. mindspore/include/c_api/tensor_c.h +0 -26
  86. mindspore/include/dataset/vision_ascend.h +1 -1
  87. mindspore/jpeg62.dll +0 -0
  88. mindspore/mindrecord/tools/cifar10.py +60 -11
  89. mindspore/mindrecord/tools/cifar10_to_mr.py +5 -0
  90. mindspore/mindspore_backend_common.dll +0 -0
  91. mindspore/mindspore_backend_manager.dll +0 -0
  92. mindspore/mindspore_common.dll +0 -0
  93. mindspore/mindspore_core.dll +0 -0
  94. mindspore/mindspore_cpu_res_manager.dll +0 -0
  95. mindspore/mindspore_dump.dll +0 -0
  96. mindspore/mindspore_frontend.dll +0 -0
  97. mindspore/mindspore_glog.dll +0 -0
  98. mindspore/mindspore_memory_pool.dll +0 -0
  99. mindspore/mindspore_ms_backend.dll +0 -0
  100. mindspore/mindspore_ops.dll +0 -0
  101. mindspore/mindspore_ops_host.dll +0 -0
  102. mindspore/mindspore_ops_kernel_common.dll +0 -0
  103. mindspore/mindspore_profiler.dll +0 -0
  104. mindspore/mindspore_pyboost.dll +0 -0
  105. mindspore/mindspore_pynative.dll +0 -0
  106. mindspore/mindspore_res_manager.dll +0 -0
  107. mindspore/mindspore_runtime_pipeline.dll +0 -0
  108. mindspore/mint/__init__.py +6 -46
  109. mindspore/mint/distributed/__init__.py +1 -0
  110. mindspore/mint/distributed/distributed.py +212 -9
  111. mindspore/mint/nn/__init__.py +1 -1
  112. mindspore/mint/nn/functional.py +53 -6
  113. mindspore/mint/nn/layer/_functions.py +164 -294
  114. mindspore/mint/nn/layer/activation.py +8 -6
  115. mindspore/mint/nn/layer/conv.py +137 -101
  116. mindspore/mint/nn/layer/normalization.py +8 -22
  117. mindspore/mint/optim/adam.py +19 -18
  118. mindspore/mint/optim/adamw.py +14 -8
  119. mindspore/mint/optim/sgd.py +5 -5
  120. mindspore/nn/cell.py +328 -502
  121. mindspore/nn/grad/cell_grad.py +11 -12
  122. mindspore/nn/layer/activation.py +32 -34
  123. mindspore/nn/layer/basic.py +67 -64
  124. mindspore/nn/layer/channel_shuffle.py +4 -4
  125. mindspore/nn/layer/combined.py +4 -2
  126. mindspore/nn/layer/conv.py +117 -110
  127. mindspore/nn/layer/dense.py +9 -7
  128. mindspore/nn/layer/embedding.py +50 -52
  129. mindspore/nn/layer/image.py +37 -39
  130. mindspore/nn/layer/math.py +111 -112
  131. mindspore/nn/layer/normalization.py +56 -44
  132. mindspore/nn/layer/pooling.py +58 -63
  133. mindspore/nn/layer/rnn_cells.py +33 -33
  134. mindspore/nn/layer/rnns.py +56 -56
  135. mindspore/nn/layer/thor_layer.py +74 -73
  136. mindspore/nn/layer/transformer.py +11 -1
  137. mindspore/nn/learning_rate_schedule.py +20 -20
  138. mindspore/nn/loss/loss.py +79 -81
  139. mindspore/nn/optim/adam.py +3 -3
  140. mindspore/nn/optim/adasum.py +2 -2
  141. mindspore/nn/optim/asgd.py +2 -0
  142. mindspore/nn/optim/optimizer.py +1 -1
  143. mindspore/nn/optim/thor.py +2 -2
  144. mindspore/nn/probability/distribution/exponential.py +2 -1
  145. mindspore/nn/probability/distribution/poisson.py +2 -1
  146. mindspore/nn/sparse/sparse.py +3 -3
  147. mindspore/nn/wrap/cell_wrapper.py +34 -37
  148. mindspore/nn/wrap/grad_reducer.py +37 -37
  149. mindspore/nn/wrap/loss_scale.py +72 -74
  150. mindspore/numpy/array_creations.py +5 -5
  151. mindspore/numpy/fft.py +1 -1
  152. mindspore/numpy/math_ops.py +5 -5
  153. mindspore/opencv_core452.dll +0 -0
  154. mindspore/opencv_imgcodecs452.dll +0 -0
  155. mindspore/opencv_imgproc452.dll +0 -0
  156. mindspore/ops/_grad_experimental/grad_comm_ops.py +51 -13
  157. mindspore/ops/_grad_experimental/grad_debug_ops.py +14 -0
  158. mindspore/ops/_vmap/vmap_array_ops.py +31 -13
  159. mindspore/ops/_vmap/vmap_nn_ops.py +8 -16
  160. mindspore/ops/auto_generate/cpp_create_prim_instance_helper.py +42 -11
  161. mindspore/ops/auto_generate/gen_extend_func.py +23 -141
  162. mindspore/ops/auto_generate/gen_ops_def.py +727 -321
  163. mindspore/ops/auto_generate/gen_ops_prim.py +1721 -984
  164. mindspore/ops/auto_generate/pyboost_inner_prim.py +31 -1
  165. mindspore/ops/composite/__init__.py +10 -0
  166. mindspore/ops/composite/base.py +8 -4
  167. mindspore/ops/composite/multitype_ops/__init__.py +12 -1
  168. mindspore/ops/composite/multitype_ops/_compile_utils.py +133 -109
  169. mindspore/ops/composite/multitype_ops/add_impl.py +70 -2
  170. mindspore/ops/composite/multitype_ops/div_impl.py +49 -0
  171. mindspore/ops/composite/multitype_ops/floordiv_impl.py +29 -0
  172. mindspore/ops/composite/multitype_ops/getitem_impl.py +11 -0
  173. mindspore/ops/composite/multitype_ops/mod_impl.py +5 -3
  174. mindspore/ops/composite/multitype_ops/mul_impl.py +49 -0
  175. mindspore/ops/composite/multitype_ops/setitem_impl.py +57 -0
  176. mindspore/ops/composite/multitype_ops/sub_impl.py +34 -0
  177. mindspore/ops/composite/multitype_ops/zeros_like_impl.py +14 -0
  178. mindspore/ops/function/__init__.py +3 -1
  179. mindspore/ops/function/_add_attr_func.py +11 -6
  180. mindspore/ops/function/array_func.py +9 -96
  181. mindspore/ops/function/debug_func.py +4 -3
  182. mindspore/ops/function/grad/grad_func.py +1 -1
  183. mindspore/ops/function/math_func.py +33 -540
  184. mindspore/ops/function/nn_func.py +28 -74
  185. mindspore/ops/function/other_func.py +4 -1
  186. mindspore/ops/function/random_func.py +44 -5
  187. mindspore/ops/function/vmap_func.py +2 -1
  188. mindspore/ops/functional.py +2 -3
  189. mindspore/ops/functional_overload.py +571 -6
  190. mindspore/ops/op_info_register.py +21 -0
  191. mindspore/ops/operations/__init__.py +16 -11
  192. mindspore/ops/operations/_custom_ops_utils.py +689 -34
  193. mindspore/ops/operations/_inner_ops.py +3 -6
  194. mindspore/ops/operations/_sequence_ops.py +1 -1
  195. mindspore/ops/operations/array_ops.py +2 -2
  196. mindspore/ops/operations/comm_ops.py +185 -26
  197. mindspore/ops/operations/custom_ops.py +294 -174
  198. mindspore/ops/operations/debug_ops.py +59 -4
  199. mindspore/ops/operations/image_ops.py +13 -13
  200. mindspore/ops/operations/manually_defined/ops_def.py +15 -16
  201. mindspore/ops/operations/math_ops.py +3 -4
  202. mindspore/ops/operations/nn_ops.py +7 -39
  203. mindspore/ops/primitive.py +6 -10
  204. mindspore/ops/tensor_method.py +47 -8
  205. mindspore/ops_generate/api/cpp_create_prim_instance_helper_generator.py +1 -1
  206. mindspore/ops_generate/api/functional_map_cpp_generator.py +10 -9
  207. mindspore/ops_generate/api/functions_cc_generator.py +58 -10
  208. mindspore/ops_generate/api/tensor_func_reg_cpp_generator.py +1 -1
  209. mindspore/ops_generate/common/base_generator.py +14 -0
  210. mindspore/ops_generate/common/gen_constants.py +8 -3
  211. mindspore/ops_generate/common/gen_utils.py +0 -19
  212. mindspore/ops_generate/common/op_proto.py +11 -4
  213. mindspore/ops_generate/common/template.py +88 -11
  214. mindspore/ops_generate/gen_ops.py +1 -1
  215. mindspore/ops_generate/op_def/lite_ops_cpp_generator.py +4 -4
  216. mindspore/ops_generate/op_def/ops_def_cc_generator.py +0 -3
  217. mindspore/ops_generate/op_def/ops_name_h_generator.py +0 -3
  218. mindspore/ops_generate/op_def/ops_primitive_h_generator.py +0 -4
  219. mindspore/ops_generate/op_def_py/op_prim_py_generator.py +5 -2
  220. mindspore/ops_generate/pyboost/auto_grad_impl_cc_generator.py +49 -8
  221. mindspore/ops_generate/pyboost/auto_grad_reg_cc_generator.py +2 -2
  222. mindspore/ops_generate/pyboost/gen_pyboost_func.py +31 -0
  223. mindspore/ops_generate/pyboost/op_template_parser.py +98 -72
  224. mindspore/ops_generate/pyboost/pyboost_functions_cpp_generator.py +70 -273
  225. mindspore/ops_generate/pyboost/pyboost_functions_h_generator.py +14 -6
  226. mindspore/ops_generate/pyboost/pyboost_functions_impl_cpp_generator.py +316 -0
  227. mindspore/ops_generate/pyboost/pyboost_functions_py_generator.py +1 -1
  228. mindspore/ops_generate/pyboost/pyboost_grad_function_cpp_generator.py +5 -3
  229. mindspore/ops_generate/pyboost/pyboost_inner_prim_generator.py +1 -1
  230. mindspore/ops_generate/pyboost/pyboost_internal_functions_cpp_generator.py +76 -0
  231. mindspore/ops_generate/pyboost/pyboost_internal_functions_h_generator.py +76 -0
  232. mindspore/ops_generate/pyboost/pyboost_internal_kernel_info_adapter_generator.py +125 -0
  233. mindspore/ops_generate/pyboost/pyboost_native_grad_functions_generator.py +4 -3
  234. mindspore/ops_generate/pyboost/pyboost_op_cpp_code_generator.py +348 -61
  235. mindspore/ops_generate/pyboost/pyboost_overload_functions_cpp_generator.py +1 -1
  236. mindspore/ops_generate/pyboost/pyboost_utils.py +118 -9
  237. mindspore/ops_generate/tensor_py_cc_generator.py +1 -24
  238. mindspore/parallel/_auto_parallel_context.py +11 -8
  239. mindspore/parallel/_cell_wrapper.py +113 -45
  240. mindspore/parallel/_parallel_serialization.py +1 -1
  241. mindspore/parallel/_ps_context.py +4 -6
  242. mindspore/parallel/_tensor.py +167 -12
  243. mindspore/parallel/_transformer/moe.py +1 -1
  244. mindspore/parallel/_transformer/transformer.py +13 -8
  245. mindspore/parallel/auto_parallel.py +14 -7
  246. mindspore/parallel/checkpoint_convert.py +3 -3
  247. mindspore/parallel/checkpoint_transform.py +11 -7
  248. mindspore/parallel/cluster/process_entity/_api.py +84 -48
  249. mindspore/parallel/cluster/process_entity/_utils.py +95 -7
  250. mindspore/parallel/cluster/run.py +43 -4
  251. mindspore/parallel/function/__init__.py +8 -1
  252. mindspore/parallel/function/reshard_func.py +6 -7
  253. mindspore/parallel/nn/__init__.py +15 -2
  254. mindspore/parallel/nn/parallel_cell_wrapper.py +9 -10
  255. mindspore/parallel/nn/parallel_grad_reducer.py +7 -6
  256. mindspore/parallel/shard.py +3 -4
  257. mindspore/parallel/transform_safetensors.py +463 -174
  258. mindspore/profiler/__init__.py +2 -1
  259. mindspore/profiler/analysis/parser/timeline_assembly_factory/ascend_timeline_assembler.py +7 -7
  260. mindspore/profiler/analysis/parser/timeline_assembly_factory/base_timeline_assembler.py +3 -0
  261. mindspore/profiler/analysis/parser/timeline_assembly_factory/trace_view_container.py +12 -6
  262. mindspore/profiler/analysis/parser/timeline_creator/cpu_op_timeline_creator.py +3 -3
  263. mindspore/profiler/analysis/parser/timeline_creator/fwk_timeline_creator.py +3 -3
  264. mindspore/profiler/analysis/parser/timeline_creator/msprof_timeline_creator.py +4 -4
  265. mindspore/profiler/analysis/parser/timeline_creator/scope_layer_timeline_creator.py +3 -3
  266. mindspore/profiler/analysis/parser/timeline_event/fwk_event.py +4 -1
  267. mindspore/profiler/analysis/parser/timeline_event/timeline_event_pool.py +2 -1
  268. mindspore/profiler/analysis/task_manager.py +1 -1
  269. mindspore/profiler/analysis/viewer/ascend_communication_viewer.py +5 -1
  270. mindspore/profiler/analysis/viewer/ascend_integrate_viewer.py +2 -1
  271. mindspore/profiler/analysis/viewer/ascend_op_memory_viewer.py +42 -22
  272. mindspore/profiler/analysis/viewer/ascend_step_trace_time_viewer.py +3 -2
  273. mindspore/profiler/analysis/viewer/ms_minddata_viewer.py +9 -5
  274. mindspore/profiler/analysis/viewer/ms_operator_details_viewer.py +132 -0
  275. mindspore/profiler/common/constant.py +16 -0
  276. mindspore/profiler/common/profiler_context.py +25 -27
  277. mindspore/profiler/common/profiler_info.py +0 -16
  278. mindspore/profiler/common/profiler_op_analyse.py +235 -0
  279. mindspore/profiler/common/profiler_output_path.py +23 -8
  280. mindspore/profiler/common/profiler_parameters.py +128 -35
  281. mindspore/profiler/dynamic_profile/__init__.py +0 -0
  282. mindspore/profiler/dynamic_profile/dynamic_monitor_proxy.py +39 -0
  283. mindspore/profiler/dynamic_profile/dynamic_profiler_config_context.py +666 -0
  284. mindspore/profiler/dynamic_profile/dynamic_profiler_utils.py +62 -0
  285. mindspore/profiler/dynamic_profiler.py +305 -314
  286. mindspore/profiler/envprofiler.py +12 -7
  287. mindspore/profiler/experimental_config.py +96 -6
  288. mindspore/profiler/mstx.py +33 -12
  289. mindspore/profiler/platform/__init__.py +2 -3
  290. mindspore/profiler/platform/npu_profiler.py +29 -19
  291. mindspore/profiler/profiler.py +35 -19
  292. mindspore/profiler/profiler_action_controller.py +64 -76
  293. mindspore/profiler/schedule.py +10 -4
  294. mindspore/rewrite/common/config.py +1 -0
  295. mindspore/rewrite/common/namer.py +1 -0
  296. mindspore/rewrite/common/namespace.py +1 -0
  297. mindspore/rewrite/node/node.py +31 -11
  298. mindspore/rewrite/parsers/assign_parser.py +1 -1
  299. mindspore/rewrite/symbol_tree/symbol_tree.py +1 -1
  300. mindspore/run_check/_check_version.py +7 -10
  301. mindspore/runtime/__init__.py +5 -5
  302. mindspore/runtime/event.py +10 -4
  303. mindspore/runtime/executor.py +60 -45
  304. mindspore/runtime/memory.py +30 -32
  305. mindspore/runtime/thread_bind_core.py +298 -164
  306. mindspore/safeguard/rewrite_obfuscation.py +12 -13
  307. mindspore/swresample-4.dll +0 -0
  308. mindspore/swscale-6.dll +0 -0
  309. mindspore/tinyxml2.dll +0 -0
  310. mindspore/train/_utils.py +14 -4
  311. mindspore/train/amp.py +43 -20
  312. mindspore/train/callback/__init__.py +5 -5
  313. mindspore/train/callback/_checkpoint.py +3 -6
  314. mindspore/train/callback/_flops_collector.py +1 -1
  315. mindspore/train/callback/_landscape.py +0 -1
  316. mindspore/train/callback/_train_fault_tolerance.py +97 -16
  317. mindspore/train/data_sink.py +11 -2
  318. mindspore/train/dataset_helper.py +9 -0
  319. mindspore/train/model.py +135 -55
  320. mindspore/train/serialization.py +133 -111
  321. mindspore/train/summary/summary_record.py +13 -2
  322. mindspore/turbojpeg.dll +0 -0
  323. mindspore/utils/__init__.py +3 -2
  324. mindspore/utils/dryrun.py +0 -6
  325. mindspore/utils/runtime_execution_order_check.py +163 -77
  326. mindspore/utils/sdc_detect.py +68 -0
  327. mindspore/utils/utils.py +6 -9
  328. mindspore/version.py +1 -1
  329. {mindspore-2.6.0rc1.dist-info → mindspore-2.7.0rc1.dist-info}/METADATA +5 -4
  330. {mindspore-2.6.0rc1.dist-info → mindspore-2.7.0rc1.dist-info}/RECORD +333 -371
  331. mindspore/_deprecated/jit.py +0 -198
  332. mindspore/experimental/es/__init__.py +0 -22
  333. mindspore/experimental/es/embedding_service.py +0 -891
  334. mindspore/experimental/es/embedding_service_layer.py +0 -581
  335. mindspore/profiler/parser/__init__.py +0 -14
  336. mindspore/profiler/parser/aicpu_data_parser.py +0 -272
  337. mindspore/profiler/parser/ascend_analysis/__init__.py +0 -14
  338. mindspore/profiler/parser/ascend_analysis/constant.py +0 -71
  339. mindspore/profiler/parser/ascend_analysis/file_manager.py +0 -180
  340. mindspore/profiler/parser/ascend_analysis/function_event.py +0 -185
  341. mindspore/profiler/parser/ascend_analysis/fwk_cann_parser.py +0 -136
  342. mindspore/profiler/parser/ascend_analysis/fwk_file_parser.py +0 -131
  343. mindspore/profiler/parser/ascend_analysis/msprof_timeline_parser.py +0 -104
  344. mindspore/profiler/parser/ascend_analysis/path_manager.py +0 -313
  345. mindspore/profiler/parser/ascend_analysis/profiler_info_parser.py +0 -123
  346. mindspore/profiler/parser/ascend_analysis/tlv_decoder.py +0 -86
  347. mindspore/profiler/parser/ascend_analysis/trace_event_manager.py +0 -75
  348. mindspore/profiler/parser/ascend_cluster_generator.py +0 -116
  349. mindspore/profiler/parser/ascend_communicate_generator.py +0 -314
  350. mindspore/profiler/parser/ascend_flops_generator.py +0 -116
  351. mindspore/profiler/parser/ascend_fpbp_generator.py +0 -82
  352. mindspore/profiler/parser/ascend_hccl_generator.py +0 -271
  353. mindspore/profiler/parser/ascend_integrate_generator.py +0 -42
  354. mindspore/profiler/parser/ascend_memory_generator.py +0 -185
  355. mindspore/profiler/parser/ascend_msprof_exporter.py +0 -282
  356. mindspore/profiler/parser/ascend_msprof_generator.py +0 -187
  357. mindspore/profiler/parser/ascend_op_generator.py +0 -334
  358. mindspore/profiler/parser/ascend_steptrace_generator.py +0 -94
  359. mindspore/profiler/parser/ascend_timeline_generator.py +0 -545
  360. mindspore/profiler/parser/base_timeline_generator.py +0 -483
  361. mindspore/profiler/parser/container.py +0 -229
  362. mindspore/profiler/parser/cpu_gpu_timeline_generator.py +0 -697
  363. mindspore/profiler/parser/flops_parser.py +0 -531
  364. mindspore/profiler/parser/framework_enum.py +0 -111
  365. mindspore/profiler/parser/framework_parser.py +0 -464
  366. mindspore/profiler/parser/framework_struct.py +0 -61
  367. mindspore/profiler/parser/gpu_analysis/__init__.py +0 -14
  368. mindspore/profiler/parser/gpu_analysis/function_event.py +0 -44
  369. mindspore/profiler/parser/gpu_analysis/fwk_file_parser.py +0 -89
  370. mindspore/profiler/parser/gpu_analysis/profiler_info_parser.py +0 -72
  371. mindspore/profiler/parser/hccl_parser.py +0 -573
  372. mindspore/profiler/parser/hwts_log_parser.py +0 -122
  373. mindspore/profiler/parser/integrator.py +0 -526
  374. mindspore/profiler/parser/memory_usage_parser.py +0 -277
  375. mindspore/profiler/parser/minddata_analyzer.py +0 -800
  376. mindspore/profiler/parser/minddata_parser.py +0 -186
  377. mindspore/profiler/parser/minddata_pipeline_parser.py +0 -299
  378. mindspore/profiler/parser/op_intermediate_parser.py +0 -149
  379. mindspore/profiler/parser/optime_parser.py +0 -250
  380. mindspore/profiler/parser/profiler_info.py +0 -213
  381. mindspore/profiler/parser/step_trace_parser.py +0 -666
  382. {mindspore-2.6.0rc1.dist-info → mindspore-2.7.0rc1.dist-info}/WHEEL +0 -0
  383. {mindspore-2.6.0rc1.dist-info → mindspore-2.7.0rc1.dist-info}/entry_points.txt +0 -0
  384. {mindspore-2.6.0rc1.dist-info → mindspore-2.7.0rc1.dist-info}/top_level.txt +0 -0
@@ -1,282 +0,0 @@
1
- # Copyright 2023 Huawei Technologies Co., Ltd
2
- #
3
- # Licensed under the Apache License, Version 2.0 (the "License");
4
- # you may not use this file except in compliance with the License.
5
- # You may obtain a copy of the License at
6
- #
7
- # http://www.apache.org/licenses/LICENSE-2.0
8
- #
9
- # Unless required by applicable law or agreed to in writing, software
10
- # distributed under the License is distributed on an "AS IS" BASIS,
11
- # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
- # See the License for the specific language governing permissions and
13
- # limitations under the License.
14
- # ============================================================================
15
- """msprof PROF data export api file"""
16
- import os
17
- import glob
18
- import shutil
19
- import json
20
- from json import JSONDecodeError
21
- from collections import defaultdict
22
- from subprocess import CalledProcessError, TimeoutExpired
23
- from subprocess import Popen, PIPE
24
- import csv
25
- from mindspore import log as logger
26
- from mindspore.profiler.common.util import get_newest_file
27
- from mindspore.profiler.common.util import timeit
28
-
29
-
30
- class AscendMsprofExporter:
31
- """
32
- msprof exporter. export cann edge profiling data.
33
-
34
- args:
35
- source_path: the root path of PROF_* files
36
-
37
- files under prof_root_dir is like:
38
- profiler/PROF_*/device_{id}/data/xxx
39
- profiler/PROF_*/host/data/xxx
40
- ...
41
-
42
- usage:
43
- >> ms_exporter = AscendMsprofExporter("path/to/profiler/data")
44
- >> ms_exporter.export(start_time)
45
- """
46
- DRV_VERSION = 467473
47
- _hiai_msprof_tail = "Ascend/latest/tools/profiler/bin"
48
- _msprof_cmd = "msprof"
49
- _ascend_mark = "Ascend"
50
- _step_trace_mark = "step_trace"
51
- _op_summary_mark = "op_summary"
52
- _op_statistic_mark = "op_statistic"
53
-
54
- def __init__(self, mindstudio_profiler_output, time_out=3600):
55
- self._time_out = time_out
56
- self.mindstudio_profiler_output = mindstudio_profiler_output # mindstudio_profiler_output dir
57
- # PROF* dir
58
- self.prof_root_dir = os.path.realpath(os.path.join(self.mindstudio_profiler_output, os.path.pardir))
59
-
60
- AscendMsprofExporter.check_msprof_env()
61
-
62
- @classmethod
63
- def check_msprof_env(cls):
64
- """Check the existence of msprof binary tool"""
65
-
66
- def _check_msprof(temp_path: str):
67
- if not os.path.isdir(temp_path):
68
- return False
69
- sub_files = os.listdir(temp_path)
70
- if cls._msprof_cmd in sub_files:
71
- return True
72
- return False
73
-
74
- outs, _ = cls.run_cmd(["which", cls._msprof_cmd])
75
- if outs != "":
76
- return
77
- logger.warning("[Profiler]The msprof command was not found. Searching from environment variables...")
78
-
79
- msprof_path = None
80
- envs = os.environ
81
- if envs.get("ASCEND_TOOLKIT_HOME"):
82
- temp_path = os.path.join(envs.get("ASCEND_TOOLKIT_HOME"), "bin")
83
- if _check_msprof(temp_path):
84
- msprof_path = temp_path
85
-
86
- if not msprof_path and envs.get("PATH"):
87
- path_list = envs.get("PATH").split(":")
88
- for path in path_list:
89
- if cls._ascend_mark in path:
90
- prefix = path.split(cls._ascend_mark)[0]
91
- temp_path = os.path.join(prefix, cls._hiai_msprof_tail)
92
- if _check_msprof(temp_path):
93
- msprof_path = temp_path
94
- break
95
- if msprof_path:
96
- envs["PATH"] = msprof_path + ":" + envs.get("PATH", "")
97
- else:
98
- raise FileNotFoundError("The msprof command was not found!")
99
-
100
- logger.info("The msprof command has been added to the path!")
101
-
102
- @classmethod
103
- def get_msprof_script_path(cls, script_path=""):
104
- """Check the existence of msprof script"""
105
- if not script_path:
106
- return ""
107
- outs, _ = AscendMsprofExporter.run_cmd(["which", cls._msprof_cmd])
108
- if not outs:
109
- return ""
110
- msprof_path = os.path.realpath(outs.strip())
111
- sup_path = msprof_path.split("tools")[0]
112
- script_path = os.path.join(sup_path, script_path)
113
- if not os.path.exists(script_path):
114
- return ""
115
- return script_path
116
-
117
- @classmethod
118
- def get_msprof_info_path(cls):
119
- """Check the existence of get_msprof_info.py script"""
120
- return cls.get_msprof_script_path("tools/profiler/profiler_tool/analysis/interface/get_msprof_info.py")
121
-
122
- @classmethod
123
- def get_msprof_py_script_path(cls):
124
- """Check the existence of msprof.py script"""
125
- return cls.get_msprof_script_path("tools/profiler/profiler_tool/analysis/msprof/msprof.py")
126
-
127
- @classmethod
128
- def run_cmd(cls, cmd, timeout=300):
129
- """run shell command"""
130
- try:
131
- with Popen(cmd, stdout=PIPE, stderr=PIPE, text=True) as proc:
132
- outs, errs = proc.communicate(timeout=timeout)
133
- except (FileNotFoundError, PermissionError, CalledProcessError) as exc:
134
- raise RuntimeError(exc) from exc
135
- except TimeoutExpired as err:
136
- proc.kill()
137
- msg = "The possible cause is that too much data is collected " \
138
- "and the export time is too long."
139
- logger.error(msg)
140
- raise TimeoutError(msg) from err
141
- logger.info(outs)
142
- return outs, errs
143
-
144
- def get_drv_version(self):
145
- """Get the drv_version for choosing the export mode."""
146
- try:
147
- script_path = AscendMsprofExporter.get_msprof_info_path()
148
- if not script_path:
149
- logger.warning("Can`t find get_msprof_info.py path, use single-export mode instead.")
150
- return False
151
- logger.info("get_msprof_info.py path is : %s", script_path)
152
- host_dir = os.path.join(self.prof_root_dir, 'host')
153
- cmd = ['python', script_path, '-dir', host_dir]
154
- outs, _ = AscendMsprofExporter.run_cmd(cmd)
155
- if not outs:
156
- logger.warning('Check the drvVersion can`t find the result, use single-export mode instead.')
157
- return False
158
- result = json.loads(outs)
159
- logger.info('get drv_version result is : %s', result)
160
- status = result.get('status', 1)
161
- if status == 1:
162
- return False
163
- drv_version = result.get('data', {}).get('version_info', {}).get('drv_version', 0)
164
- if drv_version >= self.DRV_VERSION:
165
- return True
166
- return False
167
- except (RuntimeError, JSONDecodeError, AttributeError, TimeoutError) as err:
168
- logger.warning('Get the drvVersion error, use single-export mode instead. detail : %s', err)
169
- return False
170
-
171
- @timeit("CANN export done")
172
- def export(self, model_iteration_dict=None):
173
- """start_time is the time to collect PROF data"""
174
-
175
- flag = self.get_drv_version()
176
- if not flag or model_iteration_dict:
177
- flag = False
178
- if not model_iteration_dict:
179
- model_iteration_dict = self._generate_step_trace()
180
-
181
- if model_iteration_dict:
182
- for model_id, iter_list in model_iteration_dict.items():
183
- self._run_msprof_export_cmd(self.prof_root_dir, model_id, iter_list)
184
- else:
185
- msprof_export_cmd = self._msprof_command_generator(self.prof_root_dir)
186
- AscendMsprofExporter.run_cmd(msprof_export_cmd, self._time_out)
187
-
188
- self._check_export_files()
189
-
190
- msprof_analyze_cmd = [self._msprof_cmd, "--analyze=on", "--rule=communication,communication_matrix",
191
- "--output={}".format(self.prof_root_dir)]
192
- AscendMsprofExporter.run_cmd(msprof_analyze_cmd, self._time_out)
193
-
194
- return flag
195
-
196
- def _run_msprof_export_cmd(self, prof_root_dir, model_id, iter_list):
197
- """run msprof.py export cmd"""
198
- script_path = AscendMsprofExporter.get_msprof_py_script_path()
199
- if not script_path:
200
- raise FileNotFoundError("Can not find msprof.py path, please check the cann environment.")
201
- export_cmd = ['python', script_path]
202
- iter_param = []
203
- if isinstance(model_id, int) and model_id >= 0:
204
- iter_param.extend(["--model-id", str(model_id)])
205
- if iter_list and isinstance(iter_list, list):
206
- iter_list.sort()
207
- iter_param.extend(["--iteration-id", str(iter_list[0]), "--iteration-count", str(len(iter_list))])
208
- for export_type in ("timeline", "summary"):
209
- cmd = export_cmd + ["export", export_type, "-dir", prof_root_dir] + iter_param
210
- AscendMsprofExporter.run_cmd(cmd, self._time_out)
211
-
212
- def _msprof_command_generator_old(self, output, model_id=None, iter_id=None):
213
- """msprof export helper"""
214
- export_cmd = [self._msprof_cmd, "--export=on", "--output={}".format(output)]
215
- if isinstance(model_id, int) and model_id >= 0:
216
- export_cmd.append("--model-id={}".format(model_id))
217
- if isinstance(iter_id, int) and iter_id >= 0:
218
- export_cmd.append("--iteration-id={}".format(iter_id))
219
- return export_cmd
220
-
221
- def _msprof_command_generator(self, output):
222
- """msprof export helper"""
223
- return [self._msprof_cmd, "--export=on", "--output={}".format(output)]
224
-
225
- def _generate_step_trace(self):
226
- """"generate model_id iteration_id dict"""
227
-
228
- AscendMsprofExporter.run_cmd(self._msprof_command_generator_old(self.prof_root_dir), self._time_out)
229
-
230
- if not os.path.isdir(self.mindstudio_profiler_output):
231
- msg = "Path {} is not a existing directory. Make sure there is " \
232
- "valid profiling data directory!".format(self.mindstudio_profiler_output)
233
- raise FileNotFoundError(msg)
234
-
235
- step_trace_name = fr'{self.mindstudio_profiler_output}/step_trace_*.csv'
236
- step_trace_file = get_newest_file(glob.glob(step_trace_name))
237
-
238
- if not step_trace_file:
239
- logger.info("Do not found step trace csv file in {} .".format(self.mindstudio_profiler_output))
240
- return None
241
-
242
- step_trace = defaultdict(list)
243
- with os.fdopen(os.open(step_trace_file[0], os.O_RDONLY, 0o600), newline='', mode='r') as csvfile:
244
- reader = csv.reader(csvfile, delimiter=',', quotechar='"')
245
- for index, value in enumerate(next(reader)):
246
- if value == 'Model ID':
247
- model_id = index
248
- if value == 'Iteration ID':
249
- iteration_id = index
250
- for row in reader:
251
- step_trace[int(row[model_id])].append(int(row[iteration_id]))
252
-
253
- shutil.rmtree(self.mindstudio_profiler_output)
254
-
255
- return step_trace
256
-
257
- def _check_export_files(self):
258
- """Check the existence of op_summary & op_statistic files."""
259
- if not os.path.isdir(self.mindstudio_profiler_output):
260
- raise RuntimeError("Path {} is not a existing directory.".format(self.mindstudio_profiler_output))
261
- op_summary = set()
262
- op_statistic = set()
263
- msprof_json = set()
264
-
265
- for f in os.listdir(self.mindstudio_profiler_output):
266
- if f.endswith('.csv'):
267
- if f.startswith(self._op_summary_mark):
268
- op_summary.add(f)
269
- elif f.startswith(self._op_statistic_mark):
270
- op_statistic.add(f)
271
-
272
- elif f.endswith('.json') and f.startswith('msprof'):
273
- msprof_json.add(f)
274
-
275
- if not op_summary:
276
- logger.warning("The op_summary csv file was not found, perhaps the original data was not collected.")
277
- if not op_statistic:
278
- logger.warning("The op_statistics csv file was not found, perhaps the original data was not collected.")
279
- if not msprof_json:
280
- logger.warning("The msprof json file was not found, perhaps the original data was not collected.")
281
-
282
- logger.info("Finish checking files.")
@@ -1,187 +0,0 @@
1
- # Copyright 2023 Huawei Technologies Co., Ltd
2
- #
3
- # Licensed under the Apache License, Version 2.0 (the "License");
4
- # you may not use this file except in compliance with the License.
5
- # You may obtain a copy of the License at
6
- #
7
- # http://www.apache.org/licenses/LICENSE-2.0
8
- #
9
- # Unless required by applicable law or agreed to in writing, software
10
- # distributed under the License is distributed on an "AS IS" BASIS,
11
- # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
- # See the License for the specific language governing permissions and
13
- # limitations under the License.
14
- # ============================================================================
15
- """msprof data generate model"""
16
- import csv
17
- import glob
18
- import numpy as np
19
- from mindspore.profiler.common.util import get_newest_file
20
-
21
-
22
- class AscendMsprofDataGenerator:
23
- """Generate ascend data from files."""
24
-
25
- _mindspore_model_id = 4294967295
26
-
27
- def __init__(self, mindstudio_profiler_output):
28
- self.mindstudio_profiler_output = mindstudio_profiler_output
29
- self.op_summary = None
30
- self.op_statistic = None
31
- self.steptrace = []
32
- self.steptrace_model = []
33
-
34
- self.op_summary_type = [
35
- ('Model ID', float),
36
- ('Task ID', int),
37
- ('Stream ID', int),
38
- ('Op Name', object),
39
- ('Op Type', object),
40
- ('Task Type', object),
41
- ('Task Start Time', object),
42
- ('Task Duration', float),
43
- ('Task Wait Time', float),
44
- ('Input Shapes', object),
45
- ('Input Data Types', object),
46
- ('Input Formats', object),
47
- ('Output Shapes', object),
48
- ('Output Data Types', object),
49
- ('Output Formats', object),
50
- ('Task Start Time(us)', object)
51
- ]
52
-
53
- self.op_statistic_type = [
54
- ('Op Type', object),
55
- ('Count', int),
56
- ('Total Time', float),
57
- ]
58
-
59
- self.steptrace_type = [
60
- ('Iteration ID', int),
61
- ('FP Start', float),
62
- ('BP End', float),
63
- ('Iteration End', float),
64
- ('Iteration Time', float),
65
- ('FP to BP Time', float),
66
- ('Iteration Refresh', float),
67
- ('Data Aug Bound', float),
68
- ('Model ID', float),
69
- ]
70
-
71
- def parse(self):
72
- """read msprof data generate DataFrame data"""
73
- self._read_op_summary()
74
-
75
- self._read_op_statistic()
76
-
77
- self._read_steptrace()
78
-
79
- self.steptrace_model = self.steptrace[self.steptrace['Model ID'] == self._mindspore_model_id]
80
-
81
- self.steptrace = self.steptrace[self.steptrace['Model ID'] != self._mindspore_model_id]
82
-
83
- result = (self.op_summary, self.op_statistic, self.steptrace, self.steptrace_model)
84
-
85
- return result
86
-
87
- def _read_op_summary(self):
88
- """read op summary to memory"""
89
- op_summary = []
90
- op_summary_name = fr'{self.mindstudio_profiler_output}/op_summary_*.csv'
91
- op_summary_files = glob.glob(op_summary_name)
92
- if not op_summary_files:
93
- return
94
- op_summary_file = get_newest_file(op_summary_files)[0]
95
- with open(op_summary_file, newline='') as csvfile:
96
- reader = csv.DictReader(csvfile, delimiter=',', quotechar='"')
97
- for row in reader:
98
- vector_fops = row.get('vector_fops', None)
99
- cube_fops = row.get('cube_fops', None)
100
- aiv_vector_fops = row.get('aiv_vector_fops', None)
101
- aic_cube_fops = row.get('aic_cube_fops', None)
102
-
103
- new_row = [row.get('Model ID'), row.get('Task ID'), row.get('Stream ID'), row.get('Op Name'),
104
- row.get('OP Type'), row.get('Task Type'), row.get('Task Start Time(us)'),
105
- row.get('Task Duration(us)'), row.get('Task Wait Time(us)'), row.get('Input Shapes'),
106
- row.get('Input Data Types'), row.get('Input Formats'), row.get('Output Shapes'),
107
- row.get('Output Data Types'), row.get('Output Formats'), '0.000']
108
- if vector_fops is not None and cube_fops is not None:
109
- new_row.append(vector_fops)
110
- new_row.append(cube_fops)
111
- elif aiv_vector_fops is not None and aic_cube_fops is not None:
112
- new_row.append(aiv_vector_fops)
113
- new_row.append(aic_cube_fops)
114
- op_summary.append(tuple(['0' if d == 'N/A' else d for d in new_row]))
115
-
116
- if op_summary and len(op_summary[0]) > len(self.op_summary_type):
117
- self.op_summary_type.extend([
118
- ('vector_fops', float),
119
- ('cube_fops', float)
120
- ])
121
-
122
- op_summary_dt = np.dtype(self.op_summary_type)
123
-
124
- self.op_summary = np.array(op_summary, dtype=op_summary_dt)
125
- high_acc_time = self.op_summary['Task Start Time'].copy()
126
- self.op_summary['Task Start Time(us)'] = high_acc_time
127
- self.op_summary['Task Start Time'] = self.op_summary['Task Start Time'].astype(float) * 1e-3
128
- self.op_summary['Task Duration'] = self.op_summary['Task Duration'] * 1e-3
129
- self.op_summary['Task Wait Time'] = self.op_summary['Task Wait Time'] * 1e-3
130
-
131
- def _read_op_statistic(self):
132
- """read op statistic to memory"""
133
- op_statistic = []
134
- op_statistic_name = fr'{self.mindstudio_profiler_output}/op_statistic_*.csv'
135
- op_statistic_files = glob.glob(op_statistic_name)
136
- if not op_statistic_files:
137
- return
138
- op_statistic_file = get_newest_file(op_statistic_files)[0]
139
- with open(op_statistic_file, newline='') as csvfile:
140
- reader = csv.DictReader(csvfile, delimiter=',', quotechar='"')
141
- for row in reader:
142
- new_row = (
143
- row.get('OP Type'),
144
- row.get('Count'),
145
- row.get('Total Time(us)'),
146
- )
147
- new_row = tuple(['0' if d == 'N/A' else d for d in new_row])
148
- op_statistic.append(new_row)
149
- if not op_statistic:
150
- return
151
- op_statistic_dt = np.dtype(self.op_statistic_type)
152
- self.op_statistic = np.array(op_statistic, dtype=op_statistic_dt)
153
- self.op_statistic['Total Time'] *= 1e-3
154
-
155
- def _read_steptrace(self):
156
- """read steptrace to memory"""
157
- step_trace = []
158
- step_trace_name = fr'{self.mindstudio_profiler_output}/step_trace_*.csv'
159
- step_trace_file_list = get_newest_file(glob.glob(step_trace_name))
160
- for step_trace_file in step_trace_file_list:
161
- with open(step_trace_file, newline='') as csvfile:
162
- reader = csv.DictReader(csvfile, delimiter=',', quotechar='"')
163
- for row in reader:
164
- new_row = [
165
- row.get('Iteration ID'),
166
- row.get('FP Start(us)'),
167
- row.get('BP End(us)'),
168
- row.get('Iteration End(us)'),
169
- row.get('Iteration Time(us)'),
170
- row.get('FP to BP Time(us)'),
171
- row.get('Iteration Refresh(us)'),
172
- row.get('Data Aug Bound(us)'),
173
- row.get('Model ID'),
174
- ]
175
- step_trace.append(tuple(['0' if i == 'N/A' else i for i in new_row]))
176
- break
177
-
178
- steptrace_dt = np.dtype(self.steptrace_type)
179
-
180
- self.steptrace = np.array(step_trace, dtype=steptrace_dt)
181
- self.steptrace['FP Start'] = self.steptrace['FP Start'] * 1e-3
182
- self.steptrace['BP End'] = self.steptrace['BP End'] * 1e-3
183
- self.steptrace['Iteration End'] = self.steptrace['Iteration End'] * 1e-3
184
- self.steptrace['Iteration Time'] = self.steptrace['Iteration Time'] * 1e-3
185
- self.steptrace['FP to BP Time'] = self.steptrace['FP to BP Time'] * 1e-3
186
- self.steptrace['Iteration Refresh'] = self.steptrace['Iteration Refresh'] * 1e-3
187
- self.steptrace['Data Aug Bound'] = self.steptrace['Data Aug Bound'] * 1e-3