mindspore 2.6.0__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 (380) 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 +36 -61
  13. mindspore/_extends/parse/resources.py +39 -0
  14. mindspore/_extends/parse/standard_method.py +32 -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 +76 -15
  31. mindspore/common/api.py +193 -112
  32. mindspore/common/dtype.py +21 -11
  33. mindspore/common/dump.py +10 -15
  34. mindspore/common/generator.py +2 -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 +48 -83
  43. mindspore/communication/_comm_helper.py +46 -4
  44. mindspore/communication/management.py +79 -7
  45. mindspore/context.py +38 -23
  46. mindspore/dataset/core/config.py +3 -3
  47. mindspore/dataset/engine/datasets.py +20 -7
  48. mindspore/dataset/engine/datasets_user_defined.py +32 -2
  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 -5
  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 +1 -0
  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 +4 -44
  109. mindspore/mint/distributed/__init__.py +1 -0
  110. mindspore/mint/distributed/distributed.py +208 -5
  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 +122 -98
  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 +325 -499
  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 +86 -85
  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 +1 -1
  140. mindspore/nn/optim/adasum.py +2 -2
  141. mindspore/nn/optim/optimizer.py +1 -1
  142. mindspore/nn/optim/thor.py +2 -2
  143. mindspore/nn/probability/distribution/exponential.py +2 -1
  144. mindspore/nn/probability/distribution/poisson.py +2 -1
  145. mindspore/nn/sparse/sparse.py +3 -3
  146. mindspore/nn/wrap/cell_wrapper.py +34 -37
  147. mindspore/nn/wrap/grad_reducer.py +37 -37
  148. mindspore/nn/wrap/loss_scale.py +72 -74
  149. mindspore/numpy/array_creations.py +5 -5
  150. mindspore/numpy/fft.py +1 -1
  151. mindspore/numpy/math_ops.py +1 -1
  152. mindspore/opencv_core452.dll +0 -0
  153. mindspore/opencv_imgcodecs452.dll +0 -0
  154. mindspore/opencv_imgproc452.dll +0 -0
  155. mindspore/ops/_grad_experimental/grad_comm_ops.py +51 -13
  156. mindspore/ops/_grad_experimental/grad_debug_ops.py +14 -0
  157. mindspore/ops/_vmap/vmap_array_ops.py +6 -13
  158. mindspore/ops/_vmap/vmap_nn_ops.py +8 -16
  159. mindspore/ops/auto_generate/cpp_create_prim_instance_helper.py +17 -8
  160. mindspore/ops/auto_generate/gen_extend_func.py +1 -51
  161. mindspore/ops/auto_generate/gen_ops_def.py +463 -257
  162. mindspore/ops/auto_generate/gen_ops_prim.py +1127 -885
  163. mindspore/ops/auto_generate/pyboost_inner_prim.py +31 -1
  164. mindspore/ops/composite/__init__.py +10 -0
  165. mindspore/ops/composite/base.py +8 -4
  166. mindspore/ops/composite/multitype_ops/__init__.py +12 -1
  167. mindspore/ops/composite/multitype_ops/_compile_utils.py +132 -108
  168. mindspore/ops/composite/multitype_ops/add_impl.py +70 -2
  169. mindspore/ops/composite/multitype_ops/div_impl.py +49 -0
  170. mindspore/ops/composite/multitype_ops/floordiv_impl.py +29 -0
  171. mindspore/ops/composite/multitype_ops/getitem_impl.py +11 -0
  172. mindspore/ops/composite/multitype_ops/mod_impl.py +5 -3
  173. mindspore/ops/composite/multitype_ops/mul_impl.py +49 -0
  174. mindspore/ops/composite/multitype_ops/setitem_impl.py +57 -0
  175. mindspore/ops/composite/multitype_ops/sub_impl.py +34 -0
  176. mindspore/ops/composite/multitype_ops/zeros_like_impl.py +14 -0
  177. mindspore/ops/function/__init__.py +3 -1
  178. mindspore/ops/function/_add_attr_func.py +11 -6
  179. mindspore/ops/function/array_func.py +7 -94
  180. mindspore/ops/function/debug_func.py +4 -3
  181. mindspore/ops/function/grad/grad_func.py +1 -1
  182. mindspore/ops/function/math_func.py +21 -367
  183. mindspore/ops/function/nn_func.py +26 -41
  184. mindspore/ops/function/other_func.py +4 -1
  185. mindspore/ops/function/random_func.py +31 -4
  186. mindspore/ops/functional.py +0 -2
  187. mindspore/ops/functional_overload.py +463 -6
  188. mindspore/ops/op_info_register.py +21 -0
  189. mindspore/ops/operations/__init__.py +5 -2
  190. mindspore/ops/operations/_custom_ops_utils.py +675 -8
  191. mindspore/ops/operations/_inner_ops.py +3 -6
  192. mindspore/ops/operations/_sequence_ops.py +1 -1
  193. mindspore/ops/operations/comm_ops.py +185 -26
  194. mindspore/ops/operations/custom_ops.py +235 -172
  195. mindspore/ops/operations/debug_ops.py +55 -4
  196. mindspore/ops/operations/image_ops.py +13 -13
  197. mindspore/ops/operations/manually_defined/ops_def.py +15 -16
  198. mindspore/ops/operations/math_ops.py +3 -4
  199. mindspore/ops/operations/nn_ops.py +5 -6
  200. mindspore/ops/primitive.py +6 -10
  201. mindspore/ops/tensor_method.py +36 -4
  202. mindspore/ops_generate/api/cpp_create_prim_instance_helper_generator.py +1 -1
  203. mindspore/ops_generate/api/functional_map_cpp_generator.py +10 -9
  204. mindspore/ops_generate/api/functions_cc_generator.py +58 -10
  205. mindspore/ops_generate/api/tensor_func_reg_cpp_generator.py +1 -1
  206. mindspore/ops_generate/common/base_generator.py +14 -0
  207. mindspore/ops_generate/common/gen_constants.py +7 -2
  208. mindspore/ops_generate/common/gen_utils.py +0 -19
  209. mindspore/ops_generate/common/op_proto.py +11 -4
  210. mindspore/ops_generate/common/template.py +88 -11
  211. mindspore/ops_generate/gen_ops.py +1 -1
  212. mindspore/ops_generate/op_def/lite_ops_cpp_generator.py +4 -4
  213. mindspore/ops_generate/op_def/ops_name_h_generator.py +0 -3
  214. mindspore/ops_generate/op_def/ops_primitive_h_generator.py +0 -4
  215. mindspore/ops_generate/op_def_py/op_prim_py_generator.py +5 -2
  216. mindspore/ops_generate/pyboost/auto_grad_impl_cc_generator.py +49 -8
  217. mindspore/ops_generate/pyboost/auto_grad_reg_cc_generator.py +2 -2
  218. mindspore/ops_generate/pyboost/gen_pyboost_func.py +31 -0
  219. mindspore/ops_generate/pyboost/op_template_parser.py +98 -72
  220. mindspore/ops_generate/pyboost/pyboost_functions_cpp_generator.py +70 -273
  221. mindspore/ops_generate/pyboost/pyboost_functions_h_generator.py +14 -6
  222. mindspore/ops_generate/pyboost/pyboost_functions_impl_cpp_generator.py +316 -0
  223. mindspore/ops_generate/pyboost/pyboost_functions_py_generator.py +1 -1
  224. mindspore/ops_generate/pyboost/pyboost_grad_function_cpp_generator.py +5 -3
  225. mindspore/ops_generate/pyboost/pyboost_inner_prim_generator.py +1 -1
  226. mindspore/ops_generate/pyboost/pyboost_internal_functions_cpp_generator.py +76 -0
  227. mindspore/ops_generate/pyboost/pyboost_internal_functions_h_generator.py +76 -0
  228. mindspore/ops_generate/pyboost/pyboost_internal_kernel_info_adapter_generator.py +125 -0
  229. mindspore/ops_generate/pyboost/pyboost_native_grad_functions_generator.py +4 -3
  230. mindspore/ops_generate/pyboost/pyboost_op_cpp_code_generator.py +348 -61
  231. mindspore/ops_generate/pyboost/pyboost_overload_functions_cpp_generator.py +1 -1
  232. mindspore/ops_generate/pyboost/pyboost_utils.py +118 -9
  233. mindspore/ops_generate/tensor_py_cc_generator.py +1 -24
  234. mindspore/parallel/_auto_parallel_context.py +4 -2
  235. mindspore/parallel/_cell_wrapper.py +106 -40
  236. mindspore/parallel/_parallel_serialization.py +1 -1
  237. mindspore/parallel/_ps_context.py +4 -6
  238. mindspore/parallel/_tensor.py +167 -12
  239. mindspore/parallel/_transformer/moe.py +1 -1
  240. mindspore/parallel/_transformer/transformer.py +13 -8
  241. mindspore/parallel/auto_parallel.py +12 -5
  242. mindspore/parallel/checkpoint_convert.py +3 -3
  243. mindspore/parallel/checkpoint_transform.py +3 -1
  244. mindspore/parallel/cluster/process_entity/_api.py +84 -48
  245. mindspore/parallel/cluster/process_entity/_utils.py +95 -7
  246. mindspore/parallel/cluster/run.py +43 -4
  247. mindspore/parallel/function/__init__.py +8 -1
  248. mindspore/parallel/function/reshard_func.py +1 -1
  249. mindspore/parallel/nn/__init__.py +15 -2
  250. mindspore/parallel/nn/parallel_cell_wrapper.py +9 -10
  251. mindspore/parallel/nn/parallel_grad_reducer.py +7 -6
  252. mindspore/parallel/shard.py +2 -2
  253. mindspore/parallel/transform_safetensors.py +462 -174
  254. mindspore/profiler/__init__.py +2 -1
  255. mindspore/profiler/analysis/parser/timeline_assembly_factory/ascend_timeline_assembler.py +7 -7
  256. mindspore/profiler/analysis/parser/timeline_assembly_factory/base_timeline_assembler.py +3 -0
  257. mindspore/profiler/analysis/parser/timeline_assembly_factory/trace_view_container.py +3 -0
  258. mindspore/profiler/analysis/parser/timeline_creator/cpu_op_timeline_creator.py +3 -3
  259. mindspore/profiler/analysis/parser/timeline_creator/fwk_timeline_creator.py +3 -3
  260. mindspore/profiler/analysis/parser/timeline_creator/msprof_timeline_creator.py +4 -4
  261. mindspore/profiler/analysis/parser/timeline_creator/scope_layer_timeline_creator.py +3 -3
  262. mindspore/profiler/analysis/parser/timeline_event/fwk_event.py +4 -1
  263. mindspore/profiler/analysis/parser/timeline_event/timeline_event_pool.py +2 -1
  264. mindspore/profiler/analysis/task_manager.py +1 -1
  265. mindspore/profiler/analysis/viewer/ascend_communication_viewer.py +5 -1
  266. mindspore/profiler/analysis/viewer/ascend_integrate_viewer.py +2 -1
  267. mindspore/profiler/analysis/viewer/ascend_op_memory_viewer.py +42 -22
  268. mindspore/profiler/analysis/viewer/ascend_step_trace_time_viewer.py +3 -2
  269. mindspore/profiler/analysis/viewer/ms_minddata_viewer.py +9 -5
  270. mindspore/profiler/analysis/viewer/ms_operator_details_viewer.py +132 -0
  271. mindspore/profiler/common/constant.py +16 -0
  272. mindspore/profiler/common/profiler_context.py +25 -27
  273. mindspore/profiler/common/profiler_info.py +0 -16
  274. mindspore/profiler/common/profiler_op_analyse.py +235 -0
  275. mindspore/profiler/common/profiler_output_path.py +23 -8
  276. mindspore/profiler/common/profiler_parameters.py +128 -35
  277. mindspore/profiler/dynamic_profile/__init__.py +0 -0
  278. mindspore/profiler/dynamic_profile/dynamic_monitor_proxy.py +39 -0
  279. mindspore/profiler/dynamic_profile/dynamic_profiler_config_context.py +666 -0
  280. mindspore/profiler/dynamic_profile/dynamic_profiler_utils.py +62 -0
  281. mindspore/profiler/dynamic_profiler.py +305 -314
  282. mindspore/profiler/envprofiler.py +12 -7
  283. mindspore/profiler/experimental_config.py +96 -6
  284. mindspore/profiler/mstx.py +33 -12
  285. mindspore/profiler/platform/__init__.py +2 -3
  286. mindspore/profiler/platform/npu_profiler.py +29 -19
  287. mindspore/profiler/profiler.py +35 -19
  288. mindspore/profiler/profiler_action_controller.py +64 -76
  289. mindspore/profiler/schedule.py +10 -4
  290. mindspore/rewrite/common/config.py +1 -0
  291. mindspore/rewrite/common/namer.py +1 -0
  292. mindspore/rewrite/common/namespace.py +1 -0
  293. mindspore/rewrite/node/node.py +31 -11
  294. mindspore/rewrite/parsers/assign_parser.py +1 -1
  295. mindspore/rewrite/symbol_tree/symbol_tree.py +1 -1
  296. mindspore/run_check/_check_version.py +7 -10
  297. mindspore/runtime/__init__.py +5 -5
  298. mindspore/runtime/event.py +10 -4
  299. mindspore/runtime/executor.py +60 -45
  300. mindspore/runtime/memory.py +21 -30
  301. mindspore/runtime/thread_bind_core.py +298 -164
  302. mindspore/safeguard/rewrite_obfuscation.py +12 -13
  303. mindspore/swresample-4.dll +0 -0
  304. mindspore/swscale-6.dll +0 -0
  305. mindspore/tinyxml2.dll +0 -0
  306. mindspore/train/_utils.py +6 -2
  307. mindspore/train/amp.py +43 -20
  308. mindspore/train/callback/__init__.py +5 -5
  309. mindspore/train/callback/_checkpoint.py +3 -6
  310. mindspore/train/callback/_flops_collector.py +1 -1
  311. mindspore/train/callback/_landscape.py +0 -1
  312. mindspore/train/callback/_train_fault_tolerance.py +71 -13
  313. mindspore/train/data_sink.py +11 -2
  314. mindspore/train/dataset_helper.py +9 -0
  315. mindspore/train/model.py +51 -33
  316. mindspore/train/serialization.py +133 -111
  317. mindspore/train/summary/summary_record.py +13 -2
  318. mindspore/turbojpeg.dll +0 -0
  319. mindspore/utils/__init__.py +3 -2
  320. mindspore/utils/dryrun.py +0 -6
  321. mindspore/utils/runtime_execution_order_check.py +162 -78
  322. mindspore/utils/sdc_detect.py +68 -0
  323. mindspore/utils/utils.py +6 -9
  324. mindspore/version.py +1 -1
  325. {mindspore-2.6.0.dist-info → mindspore-2.7.0rc1.dist-info}/METADATA +5 -4
  326. {mindspore-2.6.0.dist-info → mindspore-2.7.0rc1.dist-info}/RECORD +329 -367
  327. mindspore/_deprecated/jit.py +0 -198
  328. mindspore/experimental/es/__init__.py +0 -22
  329. mindspore/experimental/es/embedding_service.py +0 -891
  330. mindspore/experimental/es/embedding_service_layer.py +0 -581
  331. mindspore/profiler/parser/__init__.py +0 -14
  332. mindspore/profiler/parser/aicpu_data_parser.py +0 -272
  333. mindspore/profiler/parser/ascend_analysis/__init__.py +0 -14
  334. mindspore/profiler/parser/ascend_analysis/constant.py +0 -71
  335. mindspore/profiler/parser/ascend_analysis/file_manager.py +0 -180
  336. mindspore/profiler/parser/ascend_analysis/function_event.py +0 -185
  337. mindspore/profiler/parser/ascend_analysis/fwk_cann_parser.py +0 -136
  338. mindspore/profiler/parser/ascend_analysis/fwk_file_parser.py +0 -131
  339. mindspore/profiler/parser/ascend_analysis/msprof_timeline_parser.py +0 -104
  340. mindspore/profiler/parser/ascend_analysis/path_manager.py +0 -313
  341. mindspore/profiler/parser/ascend_analysis/profiler_info_parser.py +0 -123
  342. mindspore/profiler/parser/ascend_analysis/tlv_decoder.py +0 -86
  343. mindspore/profiler/parser/ascend_analysis/trace_event_manager.py +0 -75
  344. mindspore/profiler/parser/ascend_cluster_generator.py +0 -116
  345. mindspore/profiler/parser/ascend_communicate_generator.py +0 -314
  346. mindspore/profiler/parser/ascend_flops_generator.py +0 -116
  347. mindspore/profiler/parser/ascend_fpbp_generator.py +0 -82
  348. mindspore/profiler/parser/ascend_hccl_generator.py +0 -271
  349. mindspore/profiler/parser/ascend_integrate_generator.py +0 -42
  350. mindspore/profiler/parser/ascend_memory_generator.py +0 -185
  351. mindspore/profiler/parser/ascend_msprof_exporter.py +0 -282
  352. mindspore/profiler/parser/ascend_msprof_generator.py +0 -187
  353. mindspore/profiler/parser/ascend_op_generator.py +0 -334
  354. mindspore/profiler/parser/ascend_steptrace_generator.py +0 -94
  355. mindspore/profiler/parser/ascend_timeline_generator.py +0 -545
  356. mindspore/profiler/parser/base_timeline_generator.py +0 -483
  357. mindspore/profiler/parser/container.py +0 -229
  358. mindspore/profiler/parser/cpu_gpu_timeline_generator.py +0 -697
  359. mindspore/profiler/parser/flops_parser.py +0 -531
  360. mindspore/profiler/parser/framework_enum.py +0 -111
  361. mindspore/profiler/parser/framework_parser.py +0 -464
  362. mindspore/profiler/parser/framework_struct.py +0 -61
  363. mindspore/profiler/parser/gpu_analysis/__init__.py +0 -14
  364. mindspore/profiler/parser/gpu_analysis/function_event.py +0 -44
  365. mindspore/profiler/parser/gpu_analysis/fwk_file_parser.py +0 -89
  366. mindspore/profiler/parser/gpu_analysis/profiler_info_parser.py +0 -72
  367. mindspore/profiler/parser/hccl_parser.py +0 -573
  368. mindspore/profiler/parser/hwts_log_parser.py +0 -122
  369. mindspore/profiler/parser/integrator.py +0 -526
  370. mindspore/profiler/parser/memory_usage_parser.py +0 -277
  371. mindspore/profiler/parser/minddata_analyzer.py +0 -800
  372. mindspore/profiler/parser/minddata_parser.py +0 -186
  373. mindspore/profiler/parser/minddata_pipeline_parser.py +0 -299
  374. mindspore/profiler/parser/op_intermediate_parser.py +0 -149
  375. mindspore/profiler/parser/optime_parser.py +0 -250
  376. mindspore/profiler/parser/profiler_info.py +0 -213
  377. mindspore/profiler/parser/step_trace_parser.py +0 -666
  378. {mindspore-2.6.0.dist-info → mindspore-2.7.0rc1.dist-info}/WHEEL +0 -0
  379. {mindspore-2.6.0.dist-info → mindspore-2.7.0rc1.dist-info}/entry_points.txt +0 -0
  380. {mindspore-2.6.0.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