mindspore 2.6.0rc1__cp311-cp311-win_amd64.whl → 2.7.0__cp311-cp311-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.
- mindspore/.commit_id +1 -1
- mindspore/Microsoft.VisualStudio.Telemetry.dll +0 -0
- mindspore/Newtonsoft.Json.dll +0 -0
- mindspore/__init__.py +2 -2
- mindspore/_c_dataengine.cp311-win_amd64.pyd +0 -0
- mindspore/_c_expression.cp311-win_amd64.pyd +0 -0
- mindspore/_c_mindrecord.cp311-win_amd64.pyd +0 -0
- mindspore/_checkparam.py +42 -11
- mindspore/_extends/builtin_operations.py +3 -3
- mindspore/{_deprecated → _extends/optimize}/__init__.py +9 -3
- mindspore/_extends/optimize/cell_utils.py +96 -0
- mindspore/_extends/parallel_compile/akg_compiler/custom.py +1109 -0
- mindspore/_extends/parallel_compile/akg_compiler/gen_custom_op_files.py +1 -1
- mindspore/_extends/parse/__init__.py +3 -3
- mindspore/_extends/parse/compile_config.py +44 -22
- mindspore/_extends/parse/deprecated/deprecated_tensor_method.py +1 -2
- mindspore/_extends/parse/parser.py +65 -84
- mindspore/_extends/parse/resources.py +39 -0
- mindspore/_extends/parse/standard_method.py +58 -14
- mindspore/_extends/parse/trope.py +8 -1
- mindspore/_extends/pijit/__init__.py +1 -2
- mindspore/_extends/pijit/pijit_func_white_list.py +2 -5
- mindspore/amp.py +4 -22
- mindspore/atlprov.dll +0 -0
- mindspore/avcodec-59.dll +0 -0
- mindspore/avdevice-59.dll +0 -0
- mindspore/avfilter-8.dll +0 -0
- mindspore/avformat-59.dll +0 -0
- mindspore/avutil-57.dll +0 -0
- mindspore/boost/adasum.py +1 -1
- mindspore/boost/boost_cell_wrapper.py +4 -4
- mindspore/c1.dll +0 -0
- mindspore/c1xx.dll +0 -0
- mindspore/c2.dll +0 -0
- mindspore/common/__init__.py +43 -12
- mindspore/common/_grad_function.py +2 -1
- mindspore/common/_pijit_context.py +28 -7
- mindspore/common/_stub_tensor.py +1 -209
- mindspore/common/_tensor_cpp_method.py +1 -1
- mindspore/common/_tensor_docs.py +178 -53
- mindspore/common/_utils.py +9 -1
- mindspore/common/api.py +377 -203
- mindspore/common/dtype.py +108 -57
- mindspore/common/dump.py +11 -16
- mindspore/common/dynamic_shape/__init__.py +0 -0
- mindspore/common/{auto_dynamic_shape.py → dynamic_shape/auto_dynamic_shape.py} +17 -23
- mindspore/common/dynamic_shape/enable_dynamic.py +197 -0
- mindspore/common/file_system.py +59 -9
- mindspore/common/generator.py +5 -3
- mindspore/common/hook_handle.py +33 -5
- mindspore/common/jit_config.py +1 -1
- mindspore/common/jit_trace.py +84 -105
- mindspore/common/np_dtype.py +3 -3
- mindspore/common/parameter.py +27 -29
- mindspore/common/recompute.py +5 -7
- mindspore/common/sparse_tensor.py +0 -3
- mindspore/common/symbol.py +0 -1
- mindspore/common/tensor.py +117 -131
- mindspore/communication/_comm_helper.py +46 -4
- mindspore/communication/management.py +79 -7
- mindspore/context.py +67 -55
- mindspore/dataset/__init__.py +1 -1
- mindspore/dataset/audio/transforms.py +1 -1
- mindspore/dataset/core/config.py +38 -4
- mindspore/dataset/engine/datasets.py +350 -322
- mindspore/dataset/engine/datasets_user_defined.py +70 -24
- mindspore/dataset/engine/iterators.py +2 -2
- mindspore/dataset/engine/obs/config_loader.py +2 -2
- mindspore/dataset/engine/obs/obs_mindrecord_dataset.py +8 -0
- mindspore/dataset/transforms/c_transforms.py +2 -2
- mindspore/dataset/transforms/py_transforms.py +7 -3
- mindspore/dataset/transforms/transforms.py +10 -6
- mindspore/dataset/vision/__init__.py +1 -1
- mindspore/dataset/vision/py_transforms.py +8 -8
- mindspore/dataset/vision/transforms.py +17 -5
- mindspore/dataset/vision/utils.py +632 -21
- mindspore/dataset/vision/validators.py +1 -0
- mindspore/device_context/ascend/device.py +1 -1
- mindspore/device_context/ascend/op_tuning.py +35 -1
- mindspore/device_context/gpu/__init__.py +2 -2
- mindspore/device_context/gpu/device.py +1 -1
- mindspore/device_context/gpu/op_precision.py +4 -2
- mindspore/device_context/gpu/op_tuning.py +6 -3
- mindspore/device_manager.py +16 -9
- mindspore/dnnl.dll +0 -0
- mindspore/dpcmi.dll +0 -0
- mindspore/experimental/llm_boost/ascend_native/llama_boost_ascend_native.py +3 -4
- mindspore/experimental/llm_boost/atb/boost_base.py +2 -3
- mindspore/experimental/optim/adadelta.py +13 -20
- mindspore/experimental/optim/adagrad.py +15 -22
- mindspore/experimental/optim/adam.py +17 -24
- mindspore/experimental/optim/adamax.py +14 -22
- mindspore/experimental/optim/adamw.py +28 -34
- mindspore/experimental/optim/asgd.py +15 -25
- mindspore/experimental/optim/lr_scheduler.py +27 -45
- mindspore/experimental/optim/nadam.py +14 -24
- mindspore/experimental/optim/optimizer.py +13 -23
- mindspore/experimental/optim/radam.py +18 -24
- mindspore/experimental/optim/rmsprop.py +14 -25
- mindspore/experimental/optim/rprop.py +15 -26
- mindspore/experimental/optim/sgd.py +9 -19
- mindspore/hal/__init__.py +4 -4
- mindspore/hal/contiguous_tensors_handle.py +2 -2
- mindspore/hal/memory.py +27 -7
- mindspore/include/api/cell.h +65 -5
- mindspore/include/api/cfg.h +24 -7
- mindspore/include/api/context.h +1 -0
- mindspore/include/api/delegate.h +10 -2
- mindspore/include/api/dual_abi_helper.h +100 -19
- mindspore/include/api/graph.h +14 -1
- mindspore/include/api/kernel.h +16 -3
- mindspore/include/api/kernel_api.h +9 -1
- mindspore/include/api/metrics/accuracy.h +9 -0
- mindspore/include/api/model.h +8 -1
- mindspore/include/api/model_group.h +4 -0
- mindspore/include/api/model_parallel_runner.h +2 -0
- mindspore/include/api/status.h +48 -10
- mindspore/include/api/types.h +8 -3
- mindspore/include/c_api/model_c.h +0 -58
- mindspore/include/c_api/tensor_c.h +0 -26
- mindspore/include/dataset/constants.h +9 -0
- mindspore/include/dataset/vision_ascend.h +1 -1
- mindspore/jpeg62.dll +0 -0
- mindspore/mindrecord/tools/cifar10.py +61 -11
- mindspore/mindrecord/tools/cifar10_to_mr.py +5 -0
- mindspore/mindspore_backend_common.dll +0 -0
- mindspore/mindspore_backend_manager.dll +0 -0
- mindspore/mindspore_common.dll +0 -0
- mindspore/mindspore_core.dll +0 -0
- mindspore/mindspore_cpu_res_manager.dll +0 -0
- mindspore/mindspore_dump.dll +0 -0
- mindspore/mindspore_frontend.dll +0 -0
- mindspore/mindspore_glog.dll +0 -0
- mindspore/mindspore_memory_pool.dll +0 -0
- mindspore/mindspore_ms_backend.dll +0 -0
- mindspore/mindspore_ops.dll +0 -0
- mindspore/mindspore_ops_host.dll +0 -0
- mindspore/mindspore_ops_kernel_common.dll +0 -0
- mindspore/mindspore_profiler.dll +0 -0
- mindspore/mindspore_pyboost.dll +0 -0
- mindspore/mindspore_pynative.dll +0 -0
- mindspore/mindspore_res_manager.dll +0 -0
- mindspore/mindspore_runtime_pipeline.dll +0 -0
- mindspore/mint/__init__.py +6 -46
- mindspore/mint/distributed/__init__.py +5 -0
- mindspore/mint/distributed/distributed.py +429 -23
- mindspore/mint/nn/__init__.py +1 -1
- mindspore/mint/nn/functional.py +53 -6
- mindspore/mint/nn/layer/_functions.py +163 -294
- mindspore/mint/nn/layer/activation.py +8 -6
- mindspore/mint/nn/layer/conv.py +140 -104
- mindspore/mint/nn/layer/normalization.py +11 -25
- mindspore/mint/optim/adam.py +19 -18
- mindspore/mint/optim/adamw.py +14 -8
- mindspore/mint/optim/sgd.py +5 -5
- mindspore/msobj140.dll +0 -0
- mindspore/mspdb140.dll +0 -0
- mindspore/mspdbcore.dll +0 -0
- mindspore/mspdbst.dll +0 -0
- mindspore/mspft140.dll +0 -0
- mindspore/msvcdis140.dll +0 -0
- mindspore/msvcp140_1.dll +0 -0
- mindspore/msvcp140_2.dll +0 -0
- mindspore/msvcp140_atomic_wait.dll +0 -0
- mindspore/msvcp140_codecvt_ids.dll +0 -0
- mindspore/nn/cell.py +491 -623
- mindspore/nn/grad/cell_grad.py +11 -12
- mindspore/nn/layer/activation.py +36 -36
- mindspore/nn/layer/basic.py +74 -77
- mindspore/nn/layer/channel_shuffle.py +4 -4
- mindspore/nn/layer/combined.py +4 -2
- mindspore/nn/layer/conv.py +117 -110
- mindspore/nn/layer/dense.py +9 -7
- mindspore/nn/layer/embedding.py +50 -52
- mindspore/nn/layer/image.py +38 -40
- mindspore/nn/layer/math.py +111 -112
- mindspore/nn/layer/normalization.py +56 -44
- mindspore/nn/layer/pooling.py +58 -63
- mindspore/nn/layer/rnn_cells.py +33 -33
- mindspore/nn/layer/rnns.py +56 -56
- mindspore/nn/layer/thor_layer.py +74 -73
- mindspore/nn/layer/transformer.py +11 -1
- mindspore/nn/learning_rate_schedule.py +20 -20
- mindspore/nn/loss/loss.py +79 -81
- mindspore/nn/optim/adam.py +4 -6
- mindspore/nn/optim/adasum.py +2 -2
- mindspore/nn/optim/asgd.py +2 -0
- mindspore/nn/optim/lamb.py +1 -3
- mindspore/nn/optim/optimizer.py +1 -1
- mindspore/nn/optim/tft_wrapper.py +2 -3
- mindspore/nn/optim/thor.py +2 -2
- mindspore/nn/probability/distribution/_utils/utils.py +2 -2
- mindspore/nn/probability/distribution/exponential.py +2 -1
- mindspore/nn/probability/distribution/poisson.py +2 -1
- mindspore/nn/sparse/sparse.py +3 -3
- mindspore/nn/wrap/cell_wrapper.py +73 -42
- mindspore/nn/wrap/grad_reducer.py +37 -52
- mindspore/nn/wrap/loss_scale.py +72 -74
- mindspore/numpy/array_creations.py +7 -7
- mindspore/numpy/fft.py +1 -1
- mindspore/numpy/math_ops.py +5 -5
- mindspore/numpy/utils_const.py +1 -1
- mindspore/opencv_core452.dll +0 -0
- mindspore/opencv_imgcodecs452.dll +0 -0
- mindspore/opencv_imgproc452.dll +0 -0
- mindspore/ops/_grad_experimental/grad_comm_ops.py +51 -13
- mindspore/ops/_grad_experimental/grad_debug_ops.py +14 -0
- mindspore/ops/_grad_experimental/grad_inner_ops.py +0 -9
- mindspore/ops/_op_impl/cpu/__init__.py +1 -0
- mindspore/{experimental/es/__init__.py → ops/_op_impl/cpu/joinedstr_op.py} +12 -6
- mindspore/ops/_vmap/vmap_array_ops.py +31 -13
- mindspore/ops/_vmap/vmap_nn_ops.py +8 -16
- mindspore/ops/auto_generate/cpp_create_prim_instance_helper.py +54 -13
- mindspore/ops/auto_generate/gen_extend_func.py +27 -145
- mindspore/ops/auto_generate/gen_ops_def.py +1027 -347
- mindspore/ops/auto_generate/gen_ops_prim.py +2341 -1117
- mindspore/ops/auto_generate/pyboost_inner_prim.py +31 -1
- mindspore/ops/composite/__init__.py +10 -0
- mindspore/ops/composite/base.py +9 -5
- mindspore/ops/composite/multitype_ops/__init__.py +12 -1
- mindspore/ops/composite/multitype_ops/_compile_utils.py +133 -109
- mindspore/ops/composite/multitype_ops/_constexpr_utils.py +1 -1
- mindspore/ops/composite/multitype_ops/add_impl.py +70 -2
- mindspore/ops/composite/multitype_ops/div_impl.py +49 -0
- mindspore/ops/composite/multitype_ops/floordiv_impl.py +29 -0
- mindspore/ops/composite/multitype_ops/getitem_impl.py +11 -0
- mindspore/ops/composite/multitype_ops/mod_impl.py +5 -3
- mindspore/ops/composite/multitype_ops/mul_impl.py +49 -0
- mindspore/ops/composite/multitype_ops/setitem_impl.py +57 -0
- mindspore/ops/composite/multitype_ops/sub_impl.py +34 -0
- mindspore/ops/composite/multitype_ops/zeros_like_impl.py +14 -0
- mindspore/ops/function/__init__.py +4 -1
- mindspore/ops/function/_add_attr_func.py +11 -6
- mindspore/ops/function/array_func.py +19 -102
- mindspore/ops/function/debug_func.py +8 -5
- mindspore/ops/function/grad/grad_func.py +5 -13
- mindspore/ops/function/math_func.py +77 -572
- mindspore/ops/function/nn_func.py +46 -94
- mindspore/ops/function/other_func.py +4 -1
- mindspore/ops/function/random_func.py +44 -5
- mindspore/ops/function/vmap_func.py +2 -1
- mindspore/ops/functional.py +4 -4
- mindspore/ops/functional_overload.py +594 -18
- mindspore/ops/op_info_register.py +21 -0
- mindspore/ops/operations/__init__.py +16 -11
- mindspore/ops/operations/_custom_ops_utils.py +689 -34
- mindspore/ops/operations/_inner_ops.py +14 -18
- mindspore/ops/operations/_sequence_ops.py +1 -1
- mindspore/ops/operations/array_ops.py +5 -51
- mindspore/ops/operations/comm_ops.py +186 -41
- mindspore/ops/operations/custom_ops.py +303 -177
- mindspore/ops/operations/debug_ops.py +59 -4
- mindspore/ops/operations/image_ops.py +13 -13
- mindspore/ops/operations/manually_defined/ops_def.py +27 -28
- mindspore/ops/operations/math_ops.py +8 -9
- mindspore/ops/operations/nn_ops.py +8 -40
- mindspore/ops/primitive.py +9 -20
- mindspore/ops/tensor_method.py +63 -15
- mindspore/ops_generate/api/cpp_create_prim_instance_helper_generator.py +1 -1
- mindspore/ops_generate/api/functional_map_cpp_generator.py +10 -9
- mindspore/ops_generate/api/functions_cc_generator.py +58 -10
- mindspore/ops_generate/api/tensor_func_reg_cpp_generator.py +1 -1
- mindspore/ops_generate/common/base_generator.py +14 -0
- mindspore/ops_generate/common/gen_constants.py +8 -3
- mindspore/ops_generate/common/gen_utils.py +0 -19
- mindspore/ops_generate/common/op_proto.py +11 -4
- mindspore/ops_generate/common/template.py +88 -11
- mindspore/ops_generate/gen_ops.py +1 -1
- mindspore/ops_generate/op_def/lite_ops_cpp_generator.py +4 -4
- mindspore/ops_generate/op_def/ops_def_cc_generator.py +0 -3
- mindspore/ops_generate/op_def/ops_name_h_generator.py +0 -3
- mindspore/ops_generate/op_def/ops_primitive_h_generator.py +0 -4
- mindspore/ops_generate/op_def_py/op_prim_py_generator.py +5 -2
- mindspore/ops_generate/pyboost/auto_grad_impl_cc_generator.py +49 -8
- mindspore/ops_generate/pyboost/auto_grad_reg_cc_generator.py +2 -2
- mindspore/ops_generate/pyboost/gen_pyboost_func.py +31 -16
- mindspore/ops_generate/pyboost/op_template_parser.py +98 -72
- mindspore/ops_generate/pyboost/pyboost_functions_cpp_generator.py +70 -273
- mindspore/ops_generate/pyboost/pyboost_functions_h_generator.py +14 -6
- mindspore/ops_generate/pyboost/pyboost_functions_impl_cpp_generator.py +316 -0
- mindspore/ops_generate/pyboost/pyboost_functions_py_generator.py +1 -1
- mindspore/ops_generate/pyboost/pyboost_grad_function_cpp_generator.py +5 -3
- mindspore/ops_generate/pyboost/pyboost_inner_prim_generator.py +1 -1
- mindspore/ops_generate/pyboost/pyboost_internal_functions_cpp_generator.py +76 -0
- mindspore/ops_generate/pyboost/pyboost_internal_functions_h_generator.py +76 -0
- mindspore/ops_generate/pyboost/pyboost_internal_kernel_info_adapter_generator.py +125 -0
- mindspore/ops_generate/pyboost/pyboost_native_grad_functions_generator.py +4 -3
- mindspore/ops_generate/pyboost/pyboost_op_cpp_code_generator.py +348 -61
- mindspore/ops_generate/pyboost/pyboost_overload_functions_cpp_generator.py +1 -1
- mindspore/ops_generate/pyboost/pyboost_utils.py +118 -9
- mindspore/ops_generate/tensor_py_cc_generator.py +1 -24
- mindspore/parallel/_auto_parallel_context.py +16 -23
- mindspore/parallel/_cell_wrapper.py +113 -45
- mindspore/parallel/_parallel_serialization.py +4 -3
- mindspore/parallel/_ps_context.py +4 -6
- mindspore/parallel/_tensor.py +167 -12
- mindspore/parallel/_transformer/moe.py +1 -1
- mindspore/parallel/_transformer/transformer.py +17 -12
- mindspore/parallel/_utils.py +5 -11
- mindspore/parallel/auto_parallel.py +35 -14
- mindspore/parallel/checkpoint_convert.py +3 -3
- mindspore/parallel/checkpoint_transform.py +13 -7
- mindspore/parallel/cluster/process_entity/_api.py +88 -49
- mindspore/parallel/cluster/process_entity/_utils.py +95 -7
- mindspore/parallel/cluster/run.py +48 -7
- mindspore/parallel/function/__init__.py +8 -1
- mindspore/parallel/function/reshard_func.py +12 -12
- mindspore/parallel/nn/__init__.py +15 -2
- mindspore/parallel/nn/parallel_cell_wrapper.py +50 -14
- mindspore/parallel/nn/parallel_grad_reducer.py +7 -14
- mindspore/parallel/shard.py +10 -25
- mindspore/parallel/transform_safetensors.py +469 -174
- mindspore/pgodb140.dll +0 -0
- mindspore/pgort140.dll +0 -0
- mindspore/profiler/__init__.py +2 -1
- mindspore/profiler/analysis/parser/timeline_assembly_factory/ascend_timeline_assembler.py +7 -7
- mindspore/profiler/analysis/parser/timeline_assembly_factory/base_timeline_assembler.py +3 -0
- mindspore/profiler/analysis/parser/timeline_assembly_factory/trace_view_container.py +12 -6
- mindspore/profiler/analysis/parser/timeline_creator/cpu_op_timeline_creator.py +3 -3
- mindspore/profiler/analysis/parser/timeline_creator/fwk_timeline_creator.py +3 -3
- mindspore/profiler/analysis/parser/timeline_creator/msprof_timeline_creator.py +4 -4
- mindspore/profiler/analysis/parser/timeline_creator/scope_layer_timeline_creator.py +3 -3
- mindspore/profiler/analysis/parser/timeline_event/fwk_event.py +4 -1
- mindspore/profiler/analysis/parser/timeline_event/timeline_event_pool.py +2 -1
- mindspore/profiler/analysis/task_manager.py +1 -1
- mindspore/profiler/analysis/viewer/ascend_communication_viewer.py +5 -1
- mindspore/profiler/analysis/viewer/ascend_integrate_viewer.py +2 -1
- mindspore/profiler/analysis/viewer/ascend_kernel_details_viewer.py +10 -9
- mindspore/profiler/analysis/viewer/ascend_op_memory_viewer.py +43 -23
- mindspore/profiler/analysis/viewer/ascend_step_trace_time_viewer.py +3 -2
- mindspore/profiler/analysis/viewer/ms_minddata_viewer.py +9 -5
- mindspore/profiler/analysis/viewer/ms_operator_details_viewer.py +132 -0
- mindspore/profiler/common/constant.py +16 -0
- mindspore/profiler/common/msprof_cmd_tool.py +2 -2
- mindspore/profiler/common/path_manager.py +9 -0
- mindspore/profiler/common/profiler_context.py +50 -29
- mindspore/profiler/common/profiler_info.py +0 -16
- mindspore/profiler/common/profiler_meta_data.py +1 -0
- mindspore/profiler/common/profiler_op_analyse.py +239 -0
- mindspore/profiler/common/profiler_output_path.py +23 -8
- mindspore/profiler/common/profiler_parameters.py +128 -35
- mindspore/profiler/dynamic_profile/__init__.py +0 -0
- mindspore/profiler/dynamic_profile/dynamic_monitor_proxy.py +39 -0
- mindspore/profiler/dynamic_profile/dynamic_profiler_config_context.py +666 -0
- mindspore/profiler/dynamic_profile/dynamic_profiler_utils.py +62 -0
- mindspore/profiler/dynamic_profiler.py +374 -338
- mindspore/profiler/envprofiler.py +42 -12
- mindspore/profiler/experimental_config.py +112 -7
- mindspore/profiler/mstx.py +33 -12
- mindspore/profiler/platform/__init__.py +2 -3
- mindspore/profiler/platform/cpu_profiler.py +10 -4
- mindspore/profiler/platform/npu_profiler.py +30 -20
- mindspore/profiler/profiler.py +218 -154
- mindspore/profiler/profiler_action_controller.py +65 -77
- mindspore/profiler/profiler_interface.py +2 -2
- mindspore/profiler/schedule.py +10 -4
- mindspore/rewrite/common/config.py +1 -0
- mindspore/rewrite/common/namer.py +1 -0
- mindspore/rewrite/common/namespace.py +1 -0
- mindspore/rewrite/node/node.py +31 -11
- mindspore/rewrite/parsers/assign_parser.py +1 -1
- mindspore/rewrite/symbol_tree/symbol_tree.py +2 -2
- mindspore/run_check/_check_version.py +7 -10
- mindspore/runtime/__init__.py +8 -6
- mindspore/runtime/event.py +10 -4
- mindspore/runtime/executor.py +87 -45
- mindspore/runtime/memory.py +31 -32
- mindspore/runtime/thread_bind_core.py +299 -165
- mindspore/safeguard/rewrite_obfuscation.py +12 -13
- mindspore/swresample-4.dll +0 -0
- mindspore/swscale-6.dll +0 -0
- mindspore/tbbmalloc.dll +0 -0
- mindspore/tinyxml2.dll +0 -0
- mindspore/train/_utils.py +17 -7
- mindspore/train/amp.py +43 -23
- mindspore/train/callback/__init__.py +5 -5
- mindspore/train/callback/_callback.py +2 -1
- mindspore/train/callback/_checkpoint.py +4 -14
- mindspore/train/callback/_flops_collector.py +11 -7
- mindspore/train/callback/_landscape.py +0 -1
- mindspore/train/callback/_train_fault_tolerance.py +98 -21
- mindspore/train/data_sink.py +15 -6
- mindspore/train/dataset_helper.py +14 -5
- mindspore/train/model.py +133 -69
- mindspore/train/serialization.py +168 -126
- mindspore/train/summary/summary_record.py +13 -2
- mindspore/train/train_thor/model_thor.py +2 -2
- mindspore/turbojpeg.dll +0 -0
- mindspore/utils/__init__.py +3 -2
- mindspore/utils/dryrun.py +0 -6
- mindspore/utils/runtime_execution_order_check.py +163 -77
- mindspore/utils/sdc_detect.py +68 -0
- mindspore/utils/utils.py +14 -17
- mindspore/vcmeta.dll +0 -0
- mindspore/vcruntime140.dll +0 -0
- mindspore/vcruntime140_1.dll +0 -0
- mindspore/version.py +1 -1
- {mindspore-2.6.0rc1.dist-info → mindspore-2.7.0.dist-info}/METADATA +5 -4
- {mindspore-2.6.0rc1.dist-info → mindspore-2.7.0.dist-info}/RECORD +403 -442
- mindspore/_deprecated/jit.py +0 -198
- mindspore/_extends/remote/kernel_build_server_ascend.py +0 -75
- mindspore/communication/_hccl_management.py +0 -297
- mindspore/experimental/es/embedding_service.py +0 -891
- mindspore/experimental/es/embedding_service_layer.py +0 -581
- mindspore/profiler/common/validator/__init__.py +0 -14
- mindspore/profiler/common/validator/validate_path.py +0 -84
- mindspore/profiler/parser/__init__.py +0 -14
- mindspore/profiler/parser/aicpu_data_parser.py +0 -272
- mindspore/profiler/parser/ascend_analysis/__init__.py +0 -14
- mindspore/profiler/parser/ascend_analysis/constant.py +0 -71
- mindspore/profiler/parser/ascend_analysis/file_manager.py +0 -180
- mindspore/profiler/parser/ascend_analysis/function_event.py +0 -185
- mindspore/profiler/parser/ascend_analysis/fwk_cann_parser.py +0 -136
- mindspore/profiler/parser/ascend_analysis/fwk_file_parser.py +0 -131
- mindspore/profiler/parser/ascend_analysis/msprof_timeline_parser.py +0 -104
- mindspore/profiler/parser/ascend_analysis/path_manager.py +0 -313
- mindspore/profiler/parser/ascend_analysis/profiler_info_parser.py +0 -123
- mindspore/profiler/parser/ascend_analysis/tlv_decoder.py +0 -86
- mindspore/profiler/parser/ascend_analysis/trace_event_manager.py +0 -75
- mindspore/profiler/parser/ascend_cluster_generator.py +0 -116
- mindspore/profiler/parser/ascend_communicate_generator.py +0 -314
- mindspore/profiler/parser/ascend_flops_generator.py +0 -116
- mindspore/profiler/parser/ascend_fpbp_generator.py +0 -82
- mindspore/profiler/parser/ascend_hccl_generator.py +0 -271
- mindspore/profiler/parser/ascend_integrate_generator.py +0 -42
- mindspore/profiler/parser/ascend_memory_generator.py +0 -185
- mindspore/profiler/parser/ascend_msprof_exporter.py +0 -282
- mindspore/profiler/parser/ascend_msprof_generator.py +0 -187
- mindspore/profiler/parser/ascend_op_generator.py +0 -334
- mindspore/profiler/parser/ascend_steptrace_generator.py +0 -94
- mindspore/profiler/parser/ascend_timeline_generator.py +0 -545
- mindspore/profiler/parser/base_timeline_generator.py +0 -483
- mindspore/profiler/parser/container.py +0 -229
- mindspore/profiler/parser/cpu_gpu_timeline_generator.py +0 -697
- mindspore/profiler/parser/flops_parser.py +0 -531
- mindspore/profiler/parser/framework_enum.py +0 -111
- mindspore/profiler/parser/framework_parser.py +0 -464
- mindspore/profiler/parser/framework_struct.py +0 -61
- mindspore/profiler/parser/gpu_analysis/__init__.py +0 -14
- mindspore/profiler/parser/gpu_analysis/function_event.py +0 -44
- mindspore/profiler/parser/gpu_analysis/fwk_file_parser.py +0 -89
- mindspore/profiler/parser/gpu_analysis/profiler_info_parser.py +0 -72
- mindspore/profiler/parser/hccl_parser.py +0 -573
- mindspore/profiler/parser/hwts_log_parser.py +0 -122
- mindspore/profiler/parser/integrator.py +0 -526
- mindspore/profiler/parser/memory_usage_parser.py +0 -277
- mindspore/profiler/parser/minddata_analyzer.py +0 -800
- mindspore/profiler/parser/minddata_parser.py +0 -186
- mindspore/profiler/parser/minddata_pipeline_parser.py +0 -299
- mindspore/profiler/parser/op_intermediate_parser.py +0 -149
- mindspore/profiler/parser/optime_parser.py +0 -250
- mindspore/profiler/parser/profiler_info.py +0 -213
- mindspore/profiler/parser/step_trace_parser.py +0 -666
- mindspore/utils/hooks.py +0 -81
- /mindspore/common/{_auto_dynamic.py → dynamic_shape/_auto_dynamic.py} +0 -0
- {mindspore-2.6.0rc1.dist-info → mindspore-2.7.0.dist-info}/WHEEL +0 -0
- {mindspore-2.6.0rc1.dist-info → mindspore-2.7.0.dist-info}/entry_points.txt +0 -0
- {mindspore-2.6.0rc1.dist-info → mindspore-2.7.0.dist-info}/top_level.txt +0 -0
mindspore/runtime/executor.py
CHANGED
|
@@ -15,7 +15,8 @@
|
|
|
15
15
|
|
|
16
16
|
"""Executor manager interfaces."""
|
|
17
17
|
from mindspore._c_expression import RuntimeConf
|
|
18
|
-
from mindspore.runtime.thread_bind_core import
|
|
18
|
+
from mindspore.runtime.thread_bind_core import _get_cpu_affinity_strategy, _validate_affinity_cpu_list, \
|
|
19
|
+
_validate_module_cpu_index, _adapt_to_dict
|
|
19
20
|
from mindspore._checkparam import args_type_check
|
|
20
21
|
from mindspore import _checkparam as Validator
|
|
21
22
|
from mindspore import log as logger
|
|
@@ -64,57 +65,64 @@ def dispatch_threads_num(threads_num):
|
|
|
64
65
|
return RuntimeConf.get_instance().set_dispatch_threads_num(threads_num)
|
|
65
66
|
|
|
66
67
|
|
|
67
|
-
|
|
68
|
-
def set_cpu_affinity(enable_affinity, affinity_cpu_list=None):
|
|
68
|
+
def set_cpu_affinity(enable_affinity, affinity_cpu_list=None, module_to_cpu_dict=None):
|
|
69
69
|
"""
|
|
70
|
-
Enable thread-level core binding to
|
|
71
|
-
runtime, minddata),
|
|
70
|
+
Enable thread-level core binding to allocate specific CPU cores for key MindSpore modules (main thread, pynative,
|
|
71
|
+
runtime, and minddata), preventing performance instability caused by CPU core contention among MindSpore threads.
|
|
72
72
|
|
|
73
73
|
Note:
|
|
74
|
-
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
74
|
+
- Flexible Core Binding Configuration:
|
|
75
|
+
|
|
76
|
+
1. When `affinity_cpu_list` is not specified, the process automatically determines the CPU affinity range
|
|
77
|
+
based on available CPU cores, NUMA nodes, and device resources in the environment.
|
|
78
|
+
2. When `affinity_cpu_list` is specified, the process manually binds to the CPU range defined in
|
|
79
|
+
`affinity_cpu_list`.
|
|
80
|
+
3. When `module_to_cpu_dict` is not specified, the default bind-core strategy assigns the CPU
|
|
81
|
+
cores to the `"main"` module.
|
|
82
|
+
4. When `module_to_cpu_dict` is specified, the process manually binds each module to CPU ranges as
|
|
83
|
+
defined in `module_to_cpu_dict`.
|
|
84
|
+
- The automated bind-core strategy generation scenario invokes system commands to obtain CPU, NUMA node, and
|
|
79
85
|
device resources on the environment, and some commands cannot be executed successfully due to environment
|
|
80
|
-
differences; the automated bind-core
|
|
86
|
+
differences; the automated bind-core strategy generated will vary according to the resources available on the
|
|
81
87
|
environment:
|
|
82
88
|
|
|
83
89
|
1. `cat /sys/fs/cgroup/cpuset/cpuset.cpus`, to obtain the available CPU resources on the environment; if the
|
|
84
90
|
execution of this command fails, the bind-core function will not take effect.
|
|
85
91
|
2. `npu-smi info -m`, get the available NPU resources on the environment; if the execution of this command
|
|
86
|
-
fails, the bind-core
|
|
92
|
+
fails, the bind-core strategy will be generated only based on the available CPU resources,
|
|
87
93
|
without considering the device affinity.
|
|
88
94
|
3. `npu-smi info -t board -i {NPU_ID} -c {CHIP_ID}`, get NPU details based on the logical ID of the device;
|
|
89
|
-
if the execution of this command fails, the bind-core
|
|
95
|
+
if the execution of this command fails, the bind-core strategy is generated based on the available CPU
|
|
90
96
|
resources only, regardless of device affinity.
|
|
91
97
|
4. `lspci -s {PCIe_No} -vvv`, get the hardware information of the device on the environment; if the execution
|
|
92
|
-
of this command fails, the bind-core
|
|
98
|
+
of this command fails, the bind-core strategy is generated only based on the available CPU resources,
|
|
93
99
|
without considering the device affinity.
|
|
94
100
|
5. `lscpu`, get information about CPUs and NUMA nodes on the environment; if the execution of this command
|
|
95
|
-
fails, only the available CPU resources are used to generate the bind-core
|
|
101
|
+
fails, only the available CPU resources are used to generate the bind-core strategy, without considering
|
|
96
102
|
the device affinity.
|
|
97
103
|
|
|
98
104
|
Args:
|
|
99
|
-
enable_affinity (bool):
|
|
100
|
-
affinity_cpu_list (
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
+
enable_affinity (bool): Enables/disables thread-level core binding.
|
|
106
|
+
affinity_cpu_list (list, optional): Manually specifies the CPU affinity range for the process. Format:
|
|
107
|
+
`["cpuidX-cpuidY"]` (e.g., ``["0-3", "8-11"]``). Default: ``None`` (uses auto-generated binding strategy
|
|
108
|
+
based on system resources). Passing an empty list `[]` behaves the same as ``None``.
|
|
109
|
+
module_to_cpu_dict (dict, optional): Customizes core binding for specific modules. Valid keys
|
|
110
|
+
(module names) are ``"main"``, ``"runtime"``, ``"pynative"``, ``"minddata"``. Valid value is a list
|
|
111
|
+
of ``int`` indices representing CPU cores (e.g., ``{"main": [0,1], "minddata": [6,7]}``).
|
|
112
|
+
Default: ``None`` (automatically binds core for module `"main"`). Passing an empty dict `{}`
|
|
113
|
+
behaves the same as ``None``.
|
|
105
114
|
|
|
106
115
|
Raises:
|
|
107
|
-
TypeError: The
|
|
108
|
-
TypeError: The
|
|
109
|
-
|
|
110
|
-
ValueError:
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
available in the environment.
|
|
116
|
+
TypeError: The `enable_affinity` parameter is not a boolean.
|
|
117
|
+
TypeError: The `affinity_cpu_list` parameter is neither a list nor ``None``.
|
|
118
|
+
TypeError: An element in `affinity_cpu_list` is not a string.
|
|
119
|
+
ValueError: An element in `affinity_cpu_list` does not follow the ``["cpuidX-cpuidY"]`` format.
|
|
120
|
+
TypeError: The `module_to_cpu_dict` parameter is neither a dictionary nor ``None``.
|
|
121
|
+
TypeError: A key in `module_to_cpu_dict` is not a string.
|
|
122
|
+
TypeError: A value in `module_to_cpu_dict` is not a list.
|
|
123
|
+
ValueError: An element in `module_to_cpu_dict` values is not a non-negative integer.
|
|
124
|
+
RuntimeError: In custom core binding scenarios, the specified CPU cores for a device are unavailable
|
|
125
|
+
in the environment.
|
|
118
126
|
RuntimeError: The `mindspore.runtime.set_cpu_affinity` API is called repeatedly.
|
|
119
127
|
|
|
120
128
|
Examples:
|
|
@@ -124,24 +132,31 @@ def set_cpu_affinity(enable_affinity, affinity_cpu_list=None):
|
|
|
124
132
|
>>>
|
|
125
133
|
>>> import mindspore as ms
|
|
126
134
|
>>> ms.set_device("Ascend", 1)
|
|
127
|
-
>>> ms.runtime.set_cpu_affinity(True,
|
|
135
|
+
>>> ms.runtime.set_cpu_affinity(True, ["10-19", "23-40"])
|
|
136
|
+
>>>
|
|
137
|
+
>>> import mindspore as ms
|
|
138
|
+
>>> ms.set_device("Ascend", 1)
|
|
139
|
+
>>> ms.runtime.set_cpu_affinity(True, ["10-19", "23-40"], {"main": [0,1,2,3], "runtime": [4,5,6]})
|
|
128
140
|
"""
|
|
141
|
+
affinity_cpu_list = _adapt_to_dict(affinity_cpu_list)
|
|
142
|
+
if affinity_cpu_list is False:
|
|
143
|
+
return
|
|
144
|
+
|
|
145
|
+
_validate_affinity_cpu_list(affinity_cpu_list)
|
|
146
|
+
_validate_module_cpu_index(module_to_cpu_dict)
|
|
147
|
+
|
|
129
148
|
if RuntimeConf.get_instance().is_thread_bind_core_configured():
|
|
130
149
|
raise RuntimeError("The 'mindspore.runtime.set_cpu_affinity' cannot be set repeatedly.")
|
|
131
|
-
if enable_affinity:
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
if bind_policy_flag:
|
|
139
|
-
RuntimeConf.get_instance().thread_bind_core_with_policy(module_bind_core_policy)
|
|
140
|
-
else:
|
|
141
|
-
RuntimeConf.get_instance().thread_bind_core(module_bind_core_policy)
|
|
142
|
-
else:
|
|
150
|
+
if not enable_affinity:
|
|
151
|
+
RuntimeConf.get_instance().set_thread_bind_core_configured()
|
|
152
|
+
return
|
|
153
|
+
module_bind_core_strategy = _get_cpu_affinity_strategy(affinity_cpu_list, module_to_cpu_dict)
|
|
154
|
+
if not module_bind_core_strategy:
|
|
155
|
+
logger.warning("set_cpu_affinity is not enabled because the environment does not meet the "
|
|
156
|
+
"basic conditions for binding core.")
|
|
143
157
|
RuntimeConf.get_instance().set_thread_bind_core_configured()
|
|
144
158
|
return
|
|
159
|
+
RuntimeConf.get_instance().thread_bind_core(module_bind_core_strategy)
|
|
145
160
|
|
|
146
161
|
|
|
147
162
|
@args_type_check(thread_num=int, kernel_group_num=int)
|
|
@@ -164,6 +179,9 @@ def set_kernel_launch_group(thread_num=2, kernel_group_num=8):
|
|
|
164
179
|
if RuntimeConf.get_instance().is_kernel_launch_group_configured():
|
|
165
180
|
raise RuntimeError("The 'kernel_launch_group' can not be set repeatedly.")
|
|
166
181
|
|
|
182
|
+
if RuntimeConf.get_instance().get_enable_kernel_launch_capture():
|
|
183
|
+
raise RuntimeError("The kernel launch group and kernel launch capture can not be set together")
|
|
184
|
+
|
|
167
185
|
if thread_num < 1:
|
|
168
186
|
raise ValueError(f"The value of thread_num should be at least 1, but got {thread_num}")
|
|
169
187
|
|
|
@@ -175,3 +193,27 @@ def set_kernel_launch_group(thread_num=2, kernel_group_num=8):
|
|
|
175
193
|
f"be evenly divisible by thread_num: {thread_num}")
|
|
176
194
|
|
|
177
195
|
return RuntimeConf.get_instance().set_kernel_launch_group(thread_num, kernel_group_num)
|
|
196
|
+
|
|
197
|
+
|
|
198
|
+
@args_type_check(enable_capture_graph=bool)
|
|
199
|
+
def set_kernel_launch_capture(enable_capture_graph):
|
|
200
|
+
"""
|
|
201
|
+
In O0/O1 mode, the incremental inference scenario supports graph capture.
|
|
202
|
+
By capturing the CPU-side operator dispatch behavior into a graph,
|
|
203
|
+
the performance of CPU-side operator dispatch is improved.
|
|
204
|
+
|
|
205
|
+
.. warning::
|
|
206
|
+
This is an experimental API that is subject to change or deletion.
|
|
207
|
+
|
|
208
|
+
Args:
|
|
209
|
+
enable_capture_graph (bool): Whether to enable graph capture.
|
|
210
|
+
It can be turned on or off at any position in the script.
|
|
211
|
+
|
|
212
|
+
Examples:
|
|
213
|
+
>>> import mindspore as ms
|
|
214
|
+
>>> ms.runtime.set_kernel_launch_capture(enable_capture_graph=True)
|
|
215
|
+
"""
|
|
216
|
+
if RuntimeConf.get_instance().is_kernel_launch_group_configured():
|
|
217
|
+
raise RuntimeError("The kernel launch group and kernel launch capture can not be set together")
|
|
218
|
+
|
|
219
|
+
return RuntimeConf.get_instance().set_kernel_launch_capture(enable_capture_graph)
|
mindspore/runtime/memory.py
CHANGED
|
@@ -14,9 +14,9 @@
|
|
|
14
14
|
# ============================================================================
|
|
15
15
|
|
|
16
16
|
"""Memory interfaces."""
|
|
17
|
-
|
|
17
|
+
import os
|
|
18
18
|
from mindspore._c_expression import RuntimeConf, DeviceManagerConf, _memory_stats, \
|
|
19
|
-
_reset_max_mem_reserved, _reset_max_mem_allocated, DeviceContextManager
|
|
19
|
+
_reset_max_mem_reserved, _reset_max_mem_allocated, DeviceContextManager, _empty_cache, _memory_replay
|
|
20
20
|
from mindspore import _checkparam as Validator
|
|
21
21
|
from mindspore._checkparam import args_type_check
|
|
22
22
|
from mindspore import log as logger
|
|
@@ -50,6 +50,7 @@ def set_memory(init_size="2GB", increase_size="2GB", max_size="1024GB", optimize
|
|
|
50
50
|
The format is "xxGB". Default is the maximum available memory of the device, expressed as ``1024GB``.
|
|
51
51
|
optimize_level (str): The memory optimize level. The value must be in ['O0', 'O1']. Default: ``O0`` .
|
|
52
52
|
huge_page_reserve_size (str): The reserved size of huge page memory. The format is "xxGB". Default: ``0GB``.
|
|
53
|
+
When virtual memory is enabled, reserve huge page function is not available and this parameter is ignored.
|
|
53
54
|
|
|
54
55
|
Supported Platforms:
|
|
55
56
|
``Ascend`` ``GPU`` ``CPU``
|
|
@@ -97,18 +98,9 @@ def _check_memory_conf_valid(memory_size):
|
|
|
97
98
|
"It must be a string ending with 'GB', in addition to that, it must contain "
|
|
98
99
|
"only numbers or decimal points, such as \"5GB\" or \"3.5GB\", but got {}."
|
|
99
100
|
.format(memory_size))
|
|
100
|
-
if memory_size
|
|
101
|
+
if memory_size in ["0GB", "0.0GB"]:
|
|
101
102
|
raise ValueError("The memory value should not be \"0GB\".")
|
|
102
103
|
|
|
103
|
-
def _is_initialized(device_target):
|
|
104
|
-
"""
|
|
105
|
-
Returns whether specified backend is initialized.
|
|
106
|
-
"""
|
|
107
|
-
_device_context = _device_context_mgr.get_device_context(device_target)
|
|
108
|
-
if _device_context is None:
|
|
109
|
-
return False
|
|
110
|
-
return _device_context.initialized()
|
|
111
|
-
|
|
112
104
|
def memory_stats():
|
|
113
105
|
"""
|
|
114
106
|
Returns status information queried from the memory pool.
|
|
@@ -138,9 +130,6 @@ def memory_stats():
|
|
|
138
130
|
'persistent_mem_pool_stats': {'block_unit_size': 1073741824, 'block_counts': 0, 'blocks_info': {}}}
|
|
139
131
|
"""
|
|
140
132
|
device_target = ms.context.get_context("device_target")
|
|
141
|
-
if not _is_initialized(device_target):
|
|
142
|
-
logger.warning(f"Backend {device_target} is not initialized yet. Return empty dict.")
|
|
143
|
-
return {}
|
|
144
133
|
return _memory_stats(device_target)
|
|
145
134
|
|
|
146
135
|
|
|
@@ -169,9 +158,6 @@ def memory_reserved():
|
|
|
169
158
|
1073741824
|
|
170
159
|
"""
|
|
171
160
|
device_target = ms.context.get_context("device_target")
|
|
172
|
-
if not _is_initialized(device_target):
|
|
173
|
-
logger.warning(f"Backend {device_target} is not initialized yet. Return 0.")
|
|
174
|
-
return 0
|
|
175
161
|
return _memory_stats(device_target).get("total_reserved_memory", 0)
|
|
176
162
|
|
|
177
163
|
|
|
@@ -200,22 +186,23 @@ def max_memory_reserved():
|
|
|
200
186
|
1073741824
|
|
201
187
|
"""
|
|
202
188
|
device_target = ms.context.get_context("device_target")
|
|
203
|
-
if not _is_initialized(device_target):
|
|
204
|
-
logger.warning(f"Backend {device_target} is not initialized yet. Return 0.")
|
|
205
|
-
return 0
|
|
206
189
|
return _memory_stats(device_target).get("max_reserved_memory", 0)
|
|
207
190
|
|
|
208
191
|
|
|
209
192
|
def empty_cache():
|
|
210
193
|
"""
|
|
211
|
-
|
|
212
|
-
will be optimized.
|
|
194
|
+
Empty cache in the memory pool.
|
|
213
195
|
|
|
214
196
|
Note:
|
|
215
|
-
|
|
216
|
-
|
|
197
|
+
- Empty cache help reduce the fragmentation of device memory.
|
|
198
|
+
- Support Atlas A2 series products.
|
|
199
|
+
|
|
200
|
+
Supported Platforms:
|
|
201
|
+
``Ascend``
|
|
217
202
|
"""
|
|
218
|
-
|
|
203
|
+
device_target = ms.context.get_context("device_target")
|
|
204
|
+
release_size = _empty_cache(device_target)
|
|
205
|
+
logger.info(f"The empty_cache operation is executed successfully, release size: {release_size}.")
|
|
219
206
|
|
|
220
207
|
|
|
221
208
|
def reset_peak_memory_stats():
|
|
@@ -322,9 +309,6 @@ def memory_allocated():
|
|
|
322
309
|
1024
|
|
323
310
|
"""
|
|
324
311
|
device_target = ms.context.get_context("device_target")
|
|
325
|
-
if not _is_initialized(device_target):
|
|
326
|
-
logger.warning(f"Backend {device_target} is not initialized yet. Return 0.")
|
|
327
|
-
return 0
|
|
328
312
|
return _memory_stats(device_target).get("total_allocated_memory", 0)
|
|
329
313
|
|
|
330
314
|
|
|
@@ -353,9 +337,6 @@ def max_memory_allocated():
|
|
|
353
337
|
1536
|
|
354
338
|
"""
|
|
355
339
|
device_target = ms.context.get_context("device_target")
|
|
356
|
-
if not _is_initialized(device_target):
|
|
357
|
-
logger.warning(f"Backend {device_target} is not initialized yet. Return 0.")
|
|
358
|
-
return 0
|
|
359
340
|
return _memory_stats(device_target).get("max_allocated_memory", 0)
|
|
360
341
|
|
|
361
342
|
|
|
@@ -407,3 +388,21 @@ def reset_max_memory_allocated():
|
|
|
407
388
|
"""
|
|
408
389
|
device_target = ms.context.get_context("device_target")
|
|
409
390
|
_reset_max_mem_allocated(device_target)
|
|
391
|
+
|
|
392
|
+
|
|
393
|
+
def memory_replay(file_path):
|
|
394
|
+
"""
|
|
395
|
+
Replay the memory operation based on the application and release order of
|
|
396
|
+
memory_block.csv.
|
|
397
|
+
|
|
398
|
+
Args:
|
|
399
|
+
file_path (str): The path of memory_block.csv.
|
|
400
|
+
|
|
401
|
+
Supported Platforms:
|
|
402
|
+
``Ascend``
|
|
403
|
+
|
|
404
|
+
Examples:
|
|
405
|
+
>>> import mindspore as ms
|
|
406
|
+
>>> ms.runtime.memory_replay("/data/memory_block.csv")
|
|
407
|
+
"""
|
|
408
|
+
_memory_replay(os.path.realpath(file_path))
|