mindspore 2.5.0__cp310-cp310-win_amd64.whl → 2.6.0rc1__cp310-cp310-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 +6 -4
- mindspore/_c_dataengine.cp310-win_amd64.pyd +0 -0
- mindspore/_c_expression.cp310-win_amd64.pyd +0 -0
- mindspore/_c_mindrecord.cp310-win_amd64.pyd +0 -0
- mindspore/_check_jit_forbidden_api.py +3 -0
- mindspore/_checkparam.py +3 -33
- mindspore/_deprecated/__init__.py +17 -0
- mindspore/_deprecated/jit.py +198 -0
- mindspore/_extends/builtin_operations.py +1 -1
- mindspore/_extends/parse/__init__.py +6 -7
- mindspore/_extends/parse/compile_config.py +19 -0
- mindspore/_extends/parse/deprecated/deprecated_tensor_method.py +22 -3
- mindspore/_extends/parse/jit_fallback_modules/__init__.py +0 -0
- mindspore/_extends/parse/jit_fallback_modules/check_utils.py +123 -0
- mindspore/_extends/parse/jit_fallback_modules/third_party_modules.py +50 -0
- mindspore/_extends/parse/parser.py +24 -193
- mindspore/_extends/parse/resources.py +1 -5
- mindspore/_extends/parse/standard_method.py +97 -74
- mindspore/_extends/pijit/__init__.py +2 -2
- mindspore/_extends/pijit/pijit_func_white_list.py +16 -11
- mindspore/_extends/pijit/tensor_func_list.py +27 -0
- mindspore/_extends/utils.py +1 -1
- mindspore/amp.py +4 -4
- 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/__init__.py +2 -2
- mindspore/boost/base.py +3 -7
- mindspore/boost/boost_cell_wrapper.py +2 -2
- mindspore/c1.dll +0 -0
- mindspore/c1xx.dll +0 -0
- mindspore/c2.dll +0 -0
- mindspore/common/__init__.py +4 -3
- mindspore/common/_grad_function.py +56 -0
- mindspore/common/_pijit_context.py +14 -5
- mindspore/common/_register_for_tensor.py +1 -1
- mindspore/common/_stub_tensor.py +5 -10
- mindspore/common/_tensor_cpp_method.py +1 -1
- mindspore/common/_tensor_docs.py +1915 -3287
- mindspore/common/api.py +341 -354
- mindspore/common/auto_dynamic_shape.py +41 -44
- mindspore/common/dtype.py +5 -2
- mindspore/common/dump.py +7 -5
- mindspore/common/file_system.py +3 -0
- mindspore/common/hook_handle.py +5 -3
- mindspore/common/initializer.py +10 -6
- mindspore/common/jit_begin_end.py +94 -0
- mindspore/common/jit_config.py +6 -1
- mindspore/common/jit_context.py +76 -0
- mindspore/common/jit_trace.py +378 -0
- mindspore/common/lazy_inline.py +2 -2
- mindspore/common/mutable.py +5 -4
- mindspore/common/parameter.py +106 -39
- mindspore/common/seed.py +2 -2
- mindspore/common/sparse_tensor.py +23 -17
- mindspore/common/tensor.py +297 -714
- mindspore/communication/__init__.py +7 -5
- mindspore/communication/_comm_helper.py +47 -2
- mindspore/communication/comm_func.py +70 -53
- mindspore/communication/management.py +83 -17
- mindspore/context.py +214 -560
- mindspore/dataset/__init__.py +44 -20
- mindspore/dataset/audio/__init__.py +2 -8
- mindspore/dataset/audio/transforms.py +3 -17
- mindspore/dataset/core/config.py +3 -3
- mindspore/dataset/engine/cache_client.py +1 -1
- mindspore/dataset/engine/datasets.py +102 -120
- mindspore/dataset/engine/datasets_audio.py +22 -22
- mindspore/dataset/engine/datasets_standard_format.py +43 -24
- mindspore/dataset/engine/datasets_text.py +78 -85
- mindspore/dataset/engine/datasets_user_defined.py +108 -76
- mindspore/dataset/engine/datasets_vision.py +111 -108
- mindspore/dataset/engine/iterators.py +5 -3
- mindspore/dataset/engine/obs/obs_mindrecord_dataset.py +1 -1
- mindspore/dataset/engine/samplers.py +279 -57
- mindspore/dataset/engine/serializer_deserializer.py +2 -1
- mindspore/dataset/engine/validators.py +10 -0
- mindspore/dataset/text/__init__.py +7 -6
- mindspore/dataset/text/transforms.py +6 -5
- mindspore/dataset/text/utils.py +3 -3
- mindspore/dataset/transforms/__init__.py +0 -9
- mindspore/dataset/transforms/transforms.py +3 -3
- mindspore/dataset/utils/browse_dataset.py +1 -1
- mindspore/dataset/vision/__init__.py +2 -9
- mindspore/dataset/vision/transforms.py +202 -158
- mindspore/dataset/vision/utils.py +7 -5
- mindspore/device_context/ascend/op_debug.py +60 -1
- mindspore/device_context/ascend/op_tuning.py +0 -4
- mindspore/device_manager.py +39 -3
- mindspore/dnnl.dll +0 -0
- mindspore/dpcmi.dll +0 -0
- mindspore/experimental/es/embedding_service.py +35 -27
- mindspore/experimental/map_parameter.py +4 -4
- mindspore/experimental/optim/adadelta.py +22 -26
- mindspore/experimental/optim/adagrad.py +4 -4
- mindspore/experimental/optim/adam.py +4 -0
- mindspore/experimental/optim/adamax.py +4 -4
- mindspore/experimental/optim/adamw.py +4 -0
- mindspore/experimental/optim/asgd.py +1 -1
- mindspore/experimental/optim/lr_scheduler.py +40 -22
- mindspore/experimental/optim/radam.py +5 -5
- mindspore/experimental/optim/rprop.py +1 -1
- mindspore/experimental/optim/sgd.py +1 -1
- mindspore/hal/contiguous_tensors_handle.py +6 -10
- mindspore/hal/device.py +55 -81
- mindspore/hal/event.py +38 -55
- mindspore/hal/memory.py +93 -144
- mindspore/hal/stream.py +81 -125
- mindspore/include/dataset/constants.h +7 -4
- mindspore/include/dataset/execute.h +2 -2
- mindspore/jpeg62.dll +0 -0
- mindspore/log.py +40 -2
- mindspore/mindrecord/__init__.py +20 -7
- 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_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_backend.dll → 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 +131 -700
- mindspore/mint/distributed/__init__.py +5 -1
- mindspore/mint/distributed/distributed.py +194 -109
- mindspore/mint/linalg/__init__.py +2 -0
- mindspore/mint/nn/__init__.py +280 -18
- mindspore/mint/nn/functional.py +282 -64
- mindspore/mint/nn/layer/__init__.py +4 -0
- mindspore/mint/nn/layer/_functions.py +7 -3
- mindspore/mint/nn/layer/activation.py +120 -13
- mindspore/mint/nn/layer/conv.py +218 -24
- mindspore/mint/nn/layer/normalization.py +15 -16
- mindspore/mint/nn/layer/padding.py +1 -1
- mindspore/mint/nn/layer/pooling.py +66 -1
- mindspore/mint/optim/__init__.py +2 -1
- mindspore/mint/optim/sgd.py +171 -0
- 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/__init__.py +4 -1
- mindspore/nn/cell.py +1250 -176
- mindspore/nn/layer/activation.py +23 -21
- mindspore/nn/layer/basic.py +22 -16
- mindspore/nn/layer/container.py +1 -1
- mindspore/nn/layer/conv.py +22 -17
- mindspore/nn/layer/embedding.py +9 -8
- mindspore/nn/layer/normalization.py +48 -42
- mindspore/nn/layer/pooling.py +75 -31
- mindspore/nn/layer/transformer.py +11 -10
- mindspore/nn/learning_rate_schedule.py +4 -2
- mindspore/nn/loss/loss.py +27 -19
- mindspore/nn/optim/ada_grad.py +6 -5
- mindspore/nn/optim/adadelta.py +9 -7
- mindspore/nn/optim/adafactor.py +1 -1
- mindspore/nn/optim/adam.py +16 -12
- mindspore/nn/optim/adamax.py +8 -7
- mindspore/nn/optim/adasum.py +5 -5
- mindspore/nn/optim/asgd.py +1 -1
- mindspore/nn/optim/ftrl.py +11 -9
- mindspore/nn/optim/lamb.py +1 -1
- mindspore/nn/optim/lazyadam.py +12 -10
- mindspore/nn/optim/momentum.py +7 -6
- mindspore/nn/optim/optimizer.py +2 -2
- mindspore/nn/optim/proximal_ada_grad.py +12 -10
- mindspore/nn/optim/rmsprop.py +13 -12
- mindspore/nn/optim/rprop.py +9 -7
- mindspore/nn/optim/sgd.py +9 -6
- mindspore/nn/optim/tft_wrapper.py +5 -2
- mindspore/nn/probability/bijector/bijector.py +17 -11
- mindspore/nn/probability/bijector/gumbel_cdf.py +5 -5
- mindspore/nn/probability/bijector/invert.py +2 -2
- mindspore/nn/probability/bijector/scalar_affine.py +3 -3
- mindspore/nn/probability/bijector/softplus.py +3 -2
- mindspore/nn/probability/distribution/beta.py +3 -3
- mindspore/nn/probability/distribution/categorical.py +1 -1
- mindspore/nn/probability/distribution/cauchy.py +4 -2
- mindspore/nn/probability/distribution/exponential.py +6 -7
- mindspore/nn/probability/distribution/gamma.py +2 -2
- mindspore/nn/probability/distribution/gumbel.py +2 -2
- mindspore/nn/probability/distribution/half_normal.py +5 -3
- mindspore/nn/probability/distribution/logistic.py +5 -3
- mindspore/nn/probability/distribution/poisson.py +1 -1
- mindspore/nn/probability/distribution/uniform.py +5 -3
- mindspore/nn/reinforcement/_tensors_queue.py +1 -1
- mindspore/nn/reinforcement/tensor_array.py +1 -1
- mindspore/nn/wrap/__init__.py +6 -6
- mindspore/nn/wrap/cell_wrapper.py +178 -117
- mindspore/nn/wrap/grad_reducer.py +45 -36
- mindspore/nn/wrap/loss_scale.py +3 -3
- mindspore/numpy/array_creations.py +3 -3
- mindspore/numpy/array_ops.py +1 -1
- mindspore/numpy/math_ops.py +4 -4
- mindspore/numpy/utils.py +1 -2
- mindspore/numpy/utils_const.py +1 -2
- mindspore/opencv_core452.dll +0 -0
- mindspore/opencv_imgcodecs452.dll +0 -0
- mindspore/opencv_imgproc452.dll +0 -0
- mindspore/ops/__init__.py +3 -2
- mindspore/ops/_grad_experimental/grad_comm_ops.py +18 -3
- mindspore/ops/_grad_experimental/grad_debug_ops.py +8 -1
- mindspore/ops/_grad_experimental/taylor_rule.py +29 -0
- mindspore/ops/_register_for_op.py +0 -11
- mindspore/{ops_generate → ops/_utils}/arg_dtype_cast.py +123 -4
- mindspore/{ops_generate → ops/_utils}/arg_handler.py +3 -4
- mindspore/ops/_vmap/vmap_array_ops.py +7 -6
- mindspore/ops/_vmap/vmap_grad_nn_ops.py +2 -1
- mindspore/ops/_vmap/vmap_math_ops.py +4 -7
- mindspore/ops/_vmap/vmap_nn_ops.py +9 -8
- mindspore/ops/auto_generate/__init__.py +4 -3
- mindspore/ops/auto_generate/cpp_create_prim_instance_helper.py +102 -49
- mindspore/ops/auto_generate/gen_extend_func.py +281 -135
- mindspore/ops/auto_generate/gen_ops_def.py +2574 -2326
- mindspore/ops/auto_generate/gen_ops_prim.py +8566 -2755
- mindspore/ops/auto_generate/pyboost_inner_prim.py +106 -76
- mindspore/ops/composite/__init__.py +2 -1
- mindspore/ops/composite/base.py +19 -24
- mindspore/ops/composite/math_ops.py +6 -16
- mindspore/ops/composite/multitype_ops/__init__.py +5 -2
- mindspore/ops/composite/multitype_ops/_compile_utils.py +2 -3
- mindspore/ops/composite/multitype_ops/_constexpr_utils.py +1 -2
- mindspore/ops/composite/multitype_ops/add_impl.py +2 -1
- mindspore/ops/composite/multitype_ops/bitwise_and_impl.py +2 -1
- mindspore/ops/composite/multitype_ops/bitwise_or_impl.py +2 -1
- mindspore/ops/composite/multitype_ops/bitwise_xor_impl.py +2 -1
- mindspore/ops/composite/multitype_ops/div_impl.py +6 -4
- mindspore/ops/composite/multitype_ops/equal_impl.py +4 -3
- mindspore/ops/composite/multitype_ops/floordiv_impl.py +2 -1
- mindspore/ops/composite/multitype_ops/getitem_impl.py +3 -2
- mindspore/ops/composite/multitype_ops/greater_equal_impl.py +4 -3
- mindspore/ops/composite/multitype_ops/greater_impl.py +4 -3
- mindspore/ops/composite/multitype_ops/in_impl.py +2 -1
- mindspore/ops/composite/multitype_ops/invert_impl.py +50 -0
- mindspore/ops/composite/multitype_ops/left_shift_impl.py +2 -1
- mindspore/ops/composite/multitype_ops/less_equal_impl.py +4 -3
- mindspore/ops/composite/multitype_ops/less_impl.py +4 -3
- mindspore/ops/composite/multitype_ops/logic_not_impl.py +3 -2
- mindspore/ops/composite/multitype_ops/logical_and_impl.py +2 -1
- mindspore/ops/composite/multitype_ops/logical_or_impl.py +2 -1
- mindspore/ops/composite/multitype_ops/mod_impl.py +2 -1
- mindspore/ops/composite/multitype_ops/mul_impl.py +3 -2
- mindspore/ops/composite/multitype_ops/negative_impl.py +2 -1
- mindspore/ops/composite/multitype_ops/not_equal_impl.py +2 -1
- mindspore/ops/composite/multitype_ops/not_in_impl.py +2 -1
- mindspore/ops/composite/multitype_ops/ones_like_impl.py +18 -0
- mindspore/ops/composite/multitype_ops/pow_impl.py +2 -1
- mindspore/ops/composite/multitype_ops/right_shift_impl.py +2 -1
- mindspore/ops/composite/multitype_ops/setitem_impl.py +2 -1
- mindspore/ops/composite/multitype_ops/sub_impl.py +2 -1
- mindspore/ops/function/__init__.py +28 -2
- mindspore/ops/function/_add_attr_func.py +58 -0
- mindspore/ops/function/array_func.py +1629 -2345
- mindspore/ops/function/clip_func.py +38 -45
- mindspore/ops/function/debug_func.py +36 -44
- mindspore/ops/function/grad/__init__.py +1 -0
- mindspore/ops/function/grad/grad_func.py +104 -71
- mindspore/ops/function/image_func.py +1 -1
- mindspore/ops/function/linalg_func.py +46 -78
- mindspore/ops/function/math_func.py +3035 -3705
- mindspore/ops/function/nn_func.py +676 -241
- mindspore/ops/function/other_func.py +159 -1
- mindspore/ops/function/parameter_func.py +17 -30
- mindspore/ops/function/random_func.py +204 -361
- mindspore/ops/function/reshard_func.py +4 -70
- mindspore/ops/function/sparse_func.py +3 -3
- mindspore/ops/function/sparse_unary_func.py +5 -5
- mindspore/ops/function/spectral_func.py +25 -58
- mindspore/ops/function/vmap_func.py +24 -17
- mindspore/ops/functional.py +6 -4
- mindspore/ops/functional_overload.py +547 -4
- mindspore/ops/op_info_register.py +32 -244
- mindspore/ops/operations/__init__.py +10 -5
- mindspore/ops/operations/_custom_ops_utils.py +247 -0
- mindspore/ops/operations/_grad_ops.py +1 -10
- mindspore/ops/operations/_inner_ops.py +5 -76
- mindspore/ops/operations/_ms_kernel.py +4 -10
- mindspore/ops/operations/_rl_inner_ops.py +1 -1
- mindspore/ops/operations/_scalar_ops.py +3 -2
- mindspore/ops/operations/_sequence_ops.py +1 -1
- mindspore/ops/operations/_tensor_array.py +1 -1
- mindspore/ops/operations/array_ops.py +37 -22
- mindspore/ops/operations/comm_ops.py +150 -107
- mindspore/ops/operations/custom_ops.py +221 -23
- mindspore/ops/operations/debug_ops.py +115 -16
- mindspore/ops/operations/inner_ops.py +1 -1
- mindspore/ops/operations/linalg_ops.py +1 -58
- mindspore/ops/operations/manually_defined/_inner.py +1 -1
- mindspore/ops/operations/manually_defined/ops_def.py +746 -79
- mindspore/ops/operations/math_ops.py +21 -18
- mindspore/ops/operations/nn_ops.py +65 -191
- mindspore/ops/operations/other_ops.py +62 -9
- mindspore/ops/operations/random_ops.py +13 -7
- mindspore/ops/operations/reshard_ops.py +1 -1
- mindspore/ops/operations/sparse_ops.py +2 -2
- mindspore/ops/primitive.py +43 -32
- mindspore/ops/tensor_method.py +232 -13
- mindspore/ops_generate/__init__.py +0 -5
- mindspore/ops_generate/aclnn/__init__.py +0 -0
- mindspore/ops_generate/{aclnn_kernel_register_auto_cc_generator.py → aclnn/aclnn_kernel_register_auto_cc_generator.py} +43 -18
- mindspore/ops_generate/{gen_aclnn_implement.py → aclnn/gen_aclnn_implement.py} +49 -51
- mindspore/ops_generate/api/__init__.py +0 -0
- mindspore/ops_generate/{add_tensor_docs_generator.py → api/add_tensor_docs_generator.py} +9 -7
- mindspore/ops_generate/{cpp_create_prim_instance_helper_generator.py → api/cpp_create_prim_instance_helper_generator.py} +6 -9
- mindspore/ops_generate/{functional_map_cpp_generator.py → api/functional_map_cpp_generator.py} +25 -12
- mindspore/ops_generate/{functional_overload_py_generator.py → api/functional_overload_py_generator.py} +8 -6
- mindspore/ops_generate/{functions_cc_generator.py → api/functions_cc_generator.py} +14 -10
- mindspore/ops_generate/api/gen_api.py +103 -0
- mindspore/ops_generate/{op_api_proto.py → api/op_api_proto.py} +98 -69
- mindspore/ops_generate/{tensor_func_reg_cpp_generator.py → api/tensor_func_reg_cpp_generator.py} +82 -43
- mindspore/ops_generate/common/__init__.py +0 -0
- mindspore/ops_generate/common/gen_constants.py +91 -0
- mindspore/ops_generate/{gen_utils.py → common/gen_utils.py} +72 -19
- mindspore/ops_generate/{op_proto.py → common/op_proto.py} +64 -1
- mindspore/ops_generate/{template.py → common/template.py} +96 -84
- mindspore/ops_generate/gen_ops.py +23 -325
- mindspore/ops_generate/op_def/__init__.py +0 -0
- mindspore/ops_generate/op_def/gen_op_def.py +90 -0
- mindspore/ops_generate/{lite_ops_cpp_generator.py → op_def/lite_ops_cpp_generator.py} +47 -11
- mindspore/ops_generate/{ops_def_cc_generator.py → op_def/ops_def_cc_generator.py} +18 -7
- mindspore/ops_generate/{ops_def_h_generator.py → op_def/ops_def_h_generator.py} +5 -5
- mindspore/ops_generate/{ops_name_h_generator.py → op_def/ops_name_h_generator.py} +30 -15
- mindspore/ops_generate/op_def/ops_primitive_h_generator.py +125 -0
- mindspore/ops_generate/op_def_py/__init__.py +0 -0
- mindspore/ops_generate/op_def_py/gen_op_def_py.py +47 -0
- mindspore/ops_generate/{op_def_py_generator.py → op_def_py/op_def_py_generator.py} +6 -5
- mindspore/ops_generate/{op_prim_py_generator.py → op_def_py/op_prim_py_generator.py} +24 -15
- mindspore/ops_generate/pyboost/__init__.py +0 -0
- mindspore/ops_generate/{auto_grad_impl_cc_generator.py → pyboost/auto_grad_impl_cc_generator.py} +11 -7
- mindspore/ops_generate/{auto_grad_reg_cc_generator.py → pyboost/auto_grad_reg_cc_generator.py} +7 -7
- mindspore/ops_generate/{gen_pyboost_func.py → pyboost/gen_pyboost_func.py} +40 -16
- mindspore/ops_generate/{op_template_parser.py → pyboost/op_template_parser.py} +105 -24
- mindspore/ops_generate/{pyboost_functions_cpp_generator.py → pyboost/pyboost_functions_cpp_generator.py} +55 -18
- mindspore/ops_generate/{pyboost_functions_h_generator.py → pyboost/pyboost_functions_h_generator.py} +42 -10
- mindspore/ops_generate/{pyboost_functions_py_generator.py → pyboost/pyboost_functions_py_generator.py} +6 -6
- mindspore/ops_generate/{pyboost_grad_function_cpp_generator.py → pyboost/pyboost_grad_function_cpp_generator.py} +11 -10
- mindspore/ops_generate/{pyboost_inner_prim_generator.py → pyboost/pyboost_inner_prim_generator.py} +8 -7
- mindspore/ops_generate/{pyboost_native_grad_functions_generator.py → pyboost/pyboost_native_grad_functions_generator.py} +14 -10
- mindspore/ops_generate/{pyboost_op_cpp_code_generator.py → pyboost/pyboost_op_cpp_code_generator.py} +140 -53
- mindspore/ops_generate/{pyboost_overload_functions_cpp_generator.py → pyboost/pyboost_overload_functions_cpp_generator.py} +28 -15
- mindspore/ops_generate/{pyboost_utils.py → pyboost/pyboost_utils.py} +88 -4
- mindspore/ops_generate/resources/__init__.py +0 -0
- mindspore/ops_generate/resources/resource_list.py +30 -0
- mindspore/ops_generate/resources/resource_loader.py +36 -0
- mindspore/ops_generate/resources/resource_manager.py +64 -0
- mindspore/ops_generate/resources/yaml_loader.py +88 -0
- mindspore/ops_generate/tensor_py_cc_generator.py +122 -0
- mindspore/parallel/__init__.py +6 -2
- mindspore/parallel/_auto_parallel_context.py +133 -6
- mindspore/parallel/_cell_wrapper.py +130 -15
- mindspore/parallel/_parallel_serialization.py +95 -4
- mindspore/parallel/_ps_context.py +1 -1
- mindspore/parallel/_recovery_context.py +7 -2
- mindspore/parallel/_tensor.py +142 -18
- mindspore/parallel/_utils.py +198 -25
- mindspore/parallel/algo_parameter_config.py +3 -3
- mindspore/parallel/auto_parallel.py +732 -0
- mindspore/parallel/checkpoint_convert.py +159 -0
- mindspore/parallel/checkpoint_transform.py +656 -37
- mindspore/parallel/cluster/process_entity/_api.py +151 -19
- mindspore/parallel/cluster/run.py +1 -1
- mindspore/parallel/function/__init__.py +24 -0
- mindspore/parallel/function/reshard_func.py +259 -0
- mindspore/parallel/nn/__init__.py +25 -0
- mindspore/parallel/nn/parallel_cell_wrapper.py +263 -0
- mindspore/parallel/nn/parallel_grad_reducer.py +169 -0
- mindspore/parallel/parameter_broadcast.py +24 -13
- mindspore/parallel/shard.py +137 -61
- mindspore/parallel/transform_safetensors.py +287 -95
- mindspore/pgodb140.dll +0 -0
- mindspore/pgort140.dll +0 -0
- mindspore/profiler/__init__.py +9 -5
- mindspore/profiler/analysis/parser/ascend_cann_parser.py +6 -2
- mindspore/profiler/analysis/parser/ms_framework_parser.py +4 -4
- mindspore/profiler/analysis/parser/timeline_assembly_factory/ascend_timeline_assembler.py +7 -4
- mindspore/profiler/analysis/parser/timeline_assembly_factory/trace_view_container.py +22 -0
- mindspore/profiler/analysis/parser/timeline_creator/fwk_timeline_creator.py +3 -3
- mindspore/profiler/analysis/parser/timeline_event/fwk_event.py +241 -86
- mindspore/profiler/analysis/viewer/ascend_communication_viewer.py +41 -2
- mindspore/profiler/analysis/viewer/ascend_kernel_details_viewer.py +33 -35
- mindspore/profiler/analysis/viewer/ascend_memory_viewer.py +7 -0
- mindspore/profiler/analysis/viewer/ascend_op_memory_viewer.py +8 -3
- mindspore/profiler/analysis/viewer/ascend_step_trace_time_viewer.py +141 -30
- mindspore/profiler/analysis/viewer/ms_dataset_viewer.py +5 -6
- mindspore/profiler/common/ascend_msprof_exporter.py +5 -4
- mindspore/profiler/common/constant.py +12 -0
- mindspore/profiler/common/msprof_cmd_tool.py +42 -23
- mindspore/profiler/common/path_manager.py +24 -0
- mindspore/profiler/common/profiler_context.py +26 -2
- mindspore/profiler/common/profiler_meta_data.py +74 -0
- mindspore/profiler/common/profiler_parameters.py +59 -18
- mindspore/profiler/common/profiler_path_manager.py +66 -7
- mindspore/profiler/dynamic_profiler.py +112 -79
- mindspore/profiler/envprofiler.py +26 -1
- mindspore/profiler/experimental_config.py +197 -0
- mindspore/profiler/mstx.py +57 -14
- mindspore/profiler/platform/npu_profiler.py +33 -7
- mindspore/profiler/profiler.py +541 -45
- mindspore/profiler/profiler_action_controller.py +1 -1
- mindspore/profiler/profiler_interface.py +4 -0
- mindspore/profiler/schedule.py +57 -22
- mindspore/rewrite/api/node.py +15 -13
- mindspore/rewrite/api/symbol_tree.py +1 -1
- mindspore/run_check/_check_version.py +25 -14
- mindspore/run_check/run_check.py +1 -1
- mindspore/runtime/__init__.py +2 -2
- mindspore/runtime/executor.py +40 -11
- mindspore/runtime/memory.py +25 -8
- mindspore/safeguard/rewrite_obfuscation.py +12 -9
- mindspore/swresample-4.dll +0 -0
- mindspore/swscale-6.dll +0 -0
- mindspore/tbbmalloc.dll +0 -0
- mindspore/tinyxml2.dll +0 -0
- mindspore/train/__init__.py +8 -8
- mindspore/train/_utils.py +35 -7
- mindspore/train/amp.py +1 -1
- mindspore/train/callback/__init__.py +2 -2
- mindspore/train/callback/_callback.py +2 -16
- mindspore/train/callback/_checkpoint.py +24 -40
- mindspore/train/callback/_cluster_monitor.py +14 -18
- mindspore/train/callback/_flops_collector.py +2 -3
- mindspore/train/callback/_history.py +7 -4
- mindspore/train/callback/_lambda_callback.py +2 -2
- mindspore/train/callback/_landscape.py +0 -3
- mindspore/train/callback/_loss_monitor.py +2 -1
- mindspore/train/callback/_on_request_exit.py +6 -5
- mindspore/train/callback/_reduce_lr_on_plateau.py +11 -6
- mindspore/train/callback/_summary_collector.py +8 -13
- mindspore/train/callback/_time_monitor.py +2 -1
- mindspore/train/callback/{_tft_register.py → _train_fault_tolerance.py} +179 -103
- mindspore/train/data_sink.py +25 -2
- mindspore/train/dataset_helper.py +4 -5
- mindspore/train/loss_scale_manager.py +8 -7
- mindspore/train/metrics/accuracy.py +3 -3
- mindspore/train/metrics/confusion_matrix.py +9 -9
- mindspore/train/metrics/error.py +3 -3
- mindspore/train/metrics/hausdorff_distance.py +4 -4
- mindspore/train/metrics/mean_surface_distance.py +3 -3
- mindspore/train/metrics/metric.py +0 -12
- mindspore/train/metrics/occlusion_sensitivity.py +4 -2
- mindspore/train/metrics/precision.py +8 -6
- mindspore/train/metrics/recall.py +9 -9
- mindspore/train/metrics/root_mean_square_surface_distance.py +2 -2
- mindspore/train/mind_ir_pb2.py +19 -12
- mindspore/train/model.py +176 -103
- mindspore/train/serialization.py +246 -988
- mindspore/train/summary/_summary_adapter.py +2 -2
- mindspore/train/summary/summary_record.py +1 -1
- mindspore/turbojpeg.dll +0 -0
- mindspore/utils/__init__.py +3 -2
- mindspore/utils/dryrun.py +4 -2
- mindspore/utils/hooks.py +81 -0
- mindspore/utils/utils.py +138 -4
- mindspore/vcmeta.dll +0 -0
- mindspore/vcruntime140.dll +0 -0
- mindspore/vcruntime140_1.dll +0 -0
- mindspore/version.py +1 -1
- {mindspore-2.5.0.dist-info → mindspore-2.6.0rc1.dist-info}/METADATA +2 -1
- {mindspore-2.5.0.dist-info → mindspore-2.6.0rc1.dist-info}/RECORD +483 -438
- mindspore/_install_custom.py +0 -43
- mindspore/common/_register_for_adapter.py +0 -74
- mindspore/ops/auto_generate/gen_arg_dtype_cast.py +0 -252
- mindspore/ops/auto_generate/gen_arg_handler.py +0 -136
- mindspore/ops/operations/_opaque_predicate_registry.py +0 -41
- mindspore/ops_generate/gen_constants.py +0 -190
- mindspore/ops_generate/gen_ops_inner_prim.py +0 -131
- mindspore/ops_generate/ops_primitive_h_generator.py +0 -81
- /mindspore/ops_generate/{base_generator.py → common/base_generator.py} +0 -0
- {mindspore-2.5.0.dist-info → mindspore-2.6.0rc1.dist-info}/WHEEL +0 -0
- {mindspore-2.5.0.dist-info → mindspore-2.6.0rc1.dist-info}/entry_points.txt +0 -0
- {mindspore-2.5.0.dist-info → mindspore-2.6.0rc1.dist-info}/top_level.txt +0 -0
|
@@ -1,190 +0,0 @@
|
|
|
1
|
-
# Copyright 2024 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
|
-
"""
|
|
16
|
-
This module contains the constant strings used in generating ops files.
|
|
17
|
-
|
|
18
|
-
Constants:
|
|
19
|
-
PY_LICENSE: License strings used for .py files
|
|
20
|
-
CC_LICENSE: License strings used for .h/.cc files
|
|
21
|
-
......
|
|
22
|
-
Other constant strings in the module are used for generation paths
|
|
23
|
-
"""
|
|
24
|
-
|
|
25
|
-
import os
|
|
26
|
-
|
|
27
|
-
# py license
|
|
28
|
-
PY_LICENSE = f"""# Copyright 2024 Huawei Technologies Co., Ltd
|
|
29
|
-
#
|
|
30
|
-
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
31
|
-
# you may not use this file except in compliance with the License.
|
|
32
|
-
# You may obtain a copy of the License at
|
|
33
|
-
#
|
|
34
|
-
# http://www.apache.org/licenses/LICENSE-2.0
|
|
35
|
-
#
|
|
36
|
-
# Unless required by applicable law or agreed to in writing, software
|
|
37
|
-
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
38
|
-
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
39
|
-
# See the License for the specific language governing permissions and
|
|
40
|
-
# limitations under the License.
|
|
41
|
-
# ============================================================================
|
|
42
|
-
"""
|
|
43
|
-
|
|
44
|
-
# cc license
|
|
45
|
-
CC_LICENSE = f"""/**
|
|
46
|
-
* Copyright 2024 Huawei Technologies Co., Ltd
|
|
47
|
-
*
|
|
48
|
-
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
49
|
-
* you may not use this file except in compliance with the License.
|
|
50
|
-
* You may obtain a copy of the License at
|
|
51
|
-
*
|
|
52
|
-
* http://www.apache.org/licenses/LICENSE-2.0
|
|
53
|
-
*
|
|
54
|
-
* Unless required by applicable law or agreed to in writing, software
|
|
55
|
-
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
56
|
-
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
57
|
-
* See the License for the specific language governing permissions and
|
|
58
|
-
* limitations under the License.
|
|
59
|
-
*/"""
|
|
60
|
-
|
|
61
|
-
# op_def
|
|
62
|
-
OP_DEF_AUTO_GENERATE_PATH = "op_def/auto_generate"
|
|
63
|
-
MS_OP_DEF_AUTO_GENERATE_PATH = "mindspore/ops/op_def/auto_generate"
|
|
64
|
-
MS_OP_DEF_YAML_PATH = "mindspore/ops/op_def/yaml"
|
|
65
|
-
MS_OP_DEPRECATED_DEF_YAML_PATH = "mindspore/ops/op_def/deprecated"
|
|
66
|
-
MS_OP_API_YAML_PATH = "mindspore/ops/api_def"
|
|
67
|
-
MS_TENSOR_METHOD_DOC_YAML_PATH = "mindspore/ops/api_def/method_doc"
|
|
68
|
-
MS_MINT_FUNC_DOC_YAML_PATH = "mindspore/ops/api_def/function_doc"
|
|
69
|
-
MS_MINT_FUNC_OVERLOAD_PATH = "mindspore/python/mindspore/ops"
|
|
70
|
-
PY_AUTO_GEN_PATH = "mindspore/python/mindspore/ops/auto_generate"
|
|
71
|
-
PY_OPS_GEN_PATH = "mindspore/python/mindspore/ops_generate"
|
|
72
|
-
PYBOOST_NATIVE_GRAD_FUNC_GEN_PATH = "mindspore/ccsrc/pipeline/pynative/grad/function/auto_generate"
|
|
73
|
-
PYBOOST_AUTO_GRAD_FUNC_GEN_PATH = "mindspore/ccsrc/pipeline/pynative/op_function/auto_generate"
|
|
74
|
-
PIPELINE_PYBOOST_FUNC_GEN_PATH = "mindspore/ccsrc/pipeline/pynative/op_function/auto_generate"
|
|
75
|
-
RUNTIME_PYBOOST_FUNC_GEN_PATH = "mindspore/ccsrc/runtime/pynative/op_function/auto_generate"
|
|
76
|
-
TENSOR_FUNC_REGISTER_PATH = "mindspore/ccsrc/pybind_api/ir/tensor_register/auto_generate"
|
|
77
|
-
TENSOR_API_PATH = "mindspore/ccsrc/pybind_api/ir/tensor_api/auto_generate"
|
|
78
|
-
ADD_TENSOR_DOCS_PY_PATH = "mindspore/python/mindspore/common"
|
|
79
|
-
ADD_MINT_DOCS_PY_PATH = "mindspore/python/mindspore/mint"
|
|
80
|
-
|
|
81
|
-
# yaml keys def
|
|
82
|
-
OP_KEYS = {'args', 'args_signature', 'returns', 'function', 'class', 'view', 'dispatch', 'labels', 'bprop_expander'}
|
|
83
|
-
ARG_KEYS = {'dtype', 'default', 'prim_init', 'type_cast', 'arg_handler'}
|
|
84
|
-
RETURN_KEYS = {'dtype', 'inplace', 'type_cast'}
|
|
85
|
-
ARG_SIGNATURE_KEYS = {'rw_write', 'rw_read', 'rw_ref', 'dtype_group'}
|
|
86
|
-
CLASS_KEYS = {'name', 'disable'}
|
|
87
|
-
FUNCTION_KEYS = {'name', 'disable'}
|
|
88
|
-
DISPATCH_KEYS = {'enable', 'is_comm_op', 'Ascend', 'GPU', 'CPU'}
|
|
89
|
-
TENSOR_FUNC_KEYS = {'op_yaml', 'py_method', 'kwonlyargs', 'varargs', 'alias', 'Ascend', 'GPU', 'CPU', 'interface'}
|
|
90
|
-
|
|
91
|
-
# func signature parsing
|
|
92
|
-
ARG_HANDLER_MAP = {"to_2d_paddings": "int|tuple[int]|list[int]",
|
|
93
|
-
"dtype_to_type_id": "type",
|
|
94
|
-
"to_kernel_size": "int|tuple[int]|list[int]",
|
|
95
|
-
"to_strides": "int|tuple[int]|list[int]",
|
|
96
|
-
"str_to_enum": "str",
|
|
97
|
-
"to_pair": "int|tuple[int]|list[int]|float",
|
|
98
|
-
"to_dilations": "tuple[int]|list[int]|int",
|
|
99
|
-
"to_output_padding": "int|tuple[int]|list[int]",
|
|
100
|
-
"to_rates": "int|tuple[int]|list[int]"}
|
|
101
|
-
INPUT_ARGS_NAME = {"input", "x", "input_x"}
|
|
102
|
-
INPUT_NAME_MAP = {"DeprecatedExpandAs": "input"}
|
|
103
|
-
|
|
104
|
-
# infer
|
|
105
|
-
MS_OPS_FUNC_IMPL_PATH = "mindspore/ops/infer/ops_func_impl"
|
|
106
|
-
|
|
107
|
-
# view
|
|
108
|
-
MS_OPS_VIEW_PATH = "mindspore/ops/view"
|
|
109
|
-
|
|
110
|
-
# kernel
|
|
111
|
-
MS_OPS_KERNEL_PATH = "mindspore/ops/kernel"
|
|
112
|
-
MS_OPS_KERNEL_FUNCTIONS_AUTO_GEN_PATH = "mindspore/ops/kernel/functions/auto_generate"
|
|
113
|
-
MS_COMMON_PYBOOST_KERNEL_PATH = os.path.join(MS_OPS_KERNEL_PATH, "common/pyboost")
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
OP_NAME_OP_DEF = """
|
|
117
|
-
#ifndef MINDSPORE_CORE_OP_NAME_H_
|
|
118
|
-
#define MINDSPORE_CORE_OP_NAME_H_
|
|
119
|
-
|
|
120
|
-
namespace mindspore::ops {
|
|
121
|
-
$ops_namespace_body
|
|
122
|
-
} // namespace mindspore::ops
|
|
123
|
-
|
|
124
|
-
#endif // MINDSPORE_CORE_OP_NAME_H_
|
|
125
|
-
"""
|
|
126
|
-
|
|
127
|
-
OP_PRIM_OP_DEF = """
|
|
128
|
-
#ifndef MINDSPORE_CORE_OPS_GEN_OPS_PRIMITIVE_H_
|
|
129
|
-
#define MINDSPORE_CORE_OPS_GEN_OPS_PRIMITIVE_H_
|
|
130
|
-
|
|
131
|
-
#include <memory>
|
|
132
|
-
#include "ir/anf.h"
|
|
133
|
-
#include "ir/primitive.h"
|
|
134
|
-
#include "$auto_gen_path/gen_ops_name.h"
|
|
135
|
-
#include "mindapi/base/macros.h"
|
|
136
|
-
|
|
137
|
-
namespace mindspore::prim {
|
|
138
|
-
$ops_prim_gen
|
|
139
|
-
} // namespace mindspore::prim
|
|
140
|
-
#endif // MINDSPORE_CORE_OPS_GEN_OPS_PRIMITIVE_H_
|
|
141
|
-
"""
|
|
142
|
-
|
|
143
|
-
LITE_OPS_CC = """
|
|
144
|
-
#include "$auto_gen_path/gen_lite_ops.h"
|
|
145
|
-
#include "mindapi/helper.h"
|
|
146
|
-
#include "ops/primitive_c.h"
|
|
147
|
-
#include "ops/base_operator.h"
|
|
148
|
-
#include "abstract/abstract_value.h"
|
|
149
|
-
|
|
150
|
-
namespace mindspore::ops {
|
|
151
|
-
$ops_namespace_body
|
|
152
|
-
|
|
153
|
-
} // namespace mindspore::ops
|
|
154
|
-
"""
|
|
155
|
-
|
|
156
|
-
LITE_OPS_H = """
|
|
157
|
-
#ifndef MINDSPORE_CORE_OPS_GEN_LITE_OPS_H_
|
|
158
|
-
#define MINDSPORE_CORE_OPS_GEN_LITE_OPS_H_
|
|
159
|
-
|
|
160
|
-
#include <vector>
|
|
161
|
-
#include "ops/base_operator.h"
|
|
162
|
-
#include "$auto_gen_path/gen_ops_name.h"
|
|
163
|
-
|
|
164
|
-
namespace mindspore::ops {
|
|
165
|
-
$ops_namespace_body
|
|
166
|
-
|
|
167
|
-
} // namespace mindspore::ops
|
|
168
|
-
#endif // MINDSPORE_CORE_OPS_GEN_LITE_OPS_H_
|
|
169
|
-
"""
|
|
170
|
-
|
|
171
|
-
CC_OPS_DEF = """
|
|
172
|
-
|
|
173
|
-
#include "$auto_generate_path/gen_ops_def.h"
|
|
174
|
-
#include "ir/signature.h"
|
|
175
|
-
$gen_include
|
|
176
|
-
|
|
177
|
-
namespace mindspore::ops {$gen_cc_code
|
|
178
|
-
} // namespace mindspore::ops
|
|
179
|
-
"""
|
|
180
|
-
|
|
181
|
-
ACLNN_REG_CODE = """
|
|
182
|
-
#include "$ops_gen_kernel_path/ascend/opapi/aclnn_kernel_mod.h"
|
|
183
|
-
|
|
184
|
-
namespace mindspore {
|
|
185
|
-
namespace kernel {
|
|
186
|
-
|
|
187
|
-
$aclnn_reg_code
|
|
188
|
-
} // namespace kernel
|
|
189
|
-
} // namespace mindspore
|
|
190
|
-
"""
|
|
@@ -1,131 +0,0 @@
|
|
|
1
|
-
# Copyright 2023-2024 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
|
-
"""Primitive defined for arg handler."""
|
|
16
|
-
|
|
17
|
-
from mindspore.ops.primitive import Primitive, prim_attr_register, prim_arg_register
|
|
18
|
-
from mindspore._c_expression import typing
|
|
19
|
-
from mindspore._c_expression import op_enum
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
class DtypeToEnum(Primitive):
|
|
23
|
-
r"""
|
|
24
|
-
Convert mindspore dtype to enum.
|
|
25
|
-
|
|
26
|
-
Inputs:
|
|
27
|
-
- **op_name** (str) - The op name
|
|
28
|
-
- **arg_name** (str) - The arg name
|
|
29
|
-
- **dtype** (mindspore.dtype) - The data type.
|
|
30
|
-
|
|
31
|
-
Outputs:
|
|
32
|
-
An integer.
|
|
33
|
-
|
|
34
|
-
Supported Platforms:
|
|
35
|
-
``Ascend`` ``GPU`` ``CPU``
|
|
36
|
-
"""
|
|
37
|
-
|
|
38
|
-
@prim_attr_register
|
|
39
|
-
def __init__(self):
|
|
40
|
-
"""Initialize"""
|
|
41
|
-
|
|
42
|
-
def __call__(self, op_name, arg_name, dtype):
|
|
43
|
-
"""Run in PyNative mode"""
|
|
44
|
-
if not isinstance(dtype, typing.Type):
|
|
45
|
-
raise TypeError(f"For '{op_name}', the input '{arg_name}' should be mindspore dtype, but got {dtype}.")
|
|
46
|
-
return typing.type_to_type_id(dtype)
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
class StringToEnum(Primitive):
|
|
50
|
-
r"""
|
|
51
|
-
Convert string to enum.
|
|
52
|
-
|
|
53
|
-
Inputs:
|
|
54
|
-
- **op_name** (str) - The op name
|
|
55
|
-
- **arg_name** (str) - The arg name
|
|
56
|
-
- **enum_str** (str) - The str data.
|
|
57
|
-
|
|
58
|
-
Outputs:
|
|
59
|
-
An integer.
|
|
60
|
-
|
|
61
|
-
Supported Platforms:
|
|
62
|
-
``CPU``
|
|
63
|
-
"""
|
|
64
|
-
|
|
65
|
-
@prim_attr_register
|
|
66
|
-
def __init__(self):
|
|
67
|
-
"""Initialize"""
|
|
68
|
-
|
|
69
|
-
def __call__(self, op_name, arg_name, enum_str):
|
|
70
|
-
"""Run in PyNative mode"""
|
|
71
|
-
if enum_str is None:
|
|
72
|
-
return None
|
|
73
|
-
if not isinstance(enum_str, str):
|
|
74
|
-
raise TypeError(f"For '{op_name}', the input '{arg_name}' should be a str, but got {type(enum_str)}.")
|
|
75
|
-
return op_enum.str_to_enum(op_name, arg_name, enum_str)
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
class TupleToList(Primitive):
|
|
79
|
-
r"""
|
|
80
|
-
Convert tuple to list.
|
|
81
|
-
|
|
82
|
-
Inputs:
|
|
83
|
-
- **x** (tuple) - The input
|
|
84
|
-
|
|
85
|
-
Outputs:
|
|
86
|
-
List, has the same elements as the `input`.
|
|
87
|
-
|
|
88
|
-
Supported Platforms:
|
|
89
|
-
``CPU``
|
|
90
|
-
|
|
91
|
-
Examples:
|
|
92
|
-
>>> from mindspore.ops_generate import TupleToList
|
|
93
|
-
>>> x = (1, 2, 3)
|
|
94
|
-
>>> result = TupleToList()(x)
|
|
95
|
-
>>> print(result)
|
|
96
|
-
[1, 2, 3]
|
|
97
|
-
"""
|
|
98
|
-
@prim_arg_register
|
|
99
|
-
def __init__(self):
|
|
100
|
-
"""Initialize TupleToList"""
|
|
101
|
-
|
|
102
|
-
def __call__(self, input):
|
|
103
|
-
return list(input)
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
class ListToTuple(Primitive):
|
|
107
|
-
r"""
|
|
108
|
-
Convert list to tuple.
|
|
109
|
-
|
|
110
|
-
Inputs:
|
|
111
|
-
- **x** (list) - The input
|
|
112
|
-
|
|
113
|
-
Outputs:
|
|
114
|
-
Tuple, has the same elements as the `input`.
|
|
115
|
-
|
|
116
|
-
Supported Platforms:
|
|
117
|
-
``CPU``
|
|
118
|
-
|
|
119
|
-
Examples:
|
|
120
|
-
>>> from mindspore.ops_generate import ListToTuple
|
|
121
|
-
>>> x = [1, 2, 3]
|
|
122
|
-
>>> result = ListToTuple()(x)
|
|
123
|
-
>>> print(result)
|
|
124
|
-
(1, 2, 3)
|
|
125
|
-
"""
|
|
126
|
-
@prim_arg_register
|
|
127
|
-
def __init__(self):
|
|
128
|
-
"""Initialize TupleToList"""
|
|
129
|
-
|
|
130
|
-
def __call__(self, input):
|
|
131
|
-
return tuple(input)
|
|
@@ -1,81 +0,0 @@
|
|
|
1
|
-
# Copyright 2024 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
|
-
"""
|
|
16
|
-
Module for generating C++ header files for operator primitives.
|
|
17
|
-
|
|
18
|
-
This module defines the `OpsPrimitiveHGenerator` class, which creates C++ header files
|
|
19
|
-
containing definitions for operator primitives based on provided operator prototypes.
|
|
20
|
-
"""
|
|
21
|
-
|
|
22
|
-
import os
|
|
23
|
-
|
|
24
|
-
import gen_constants as K
|
|
25
|
-
import gen_utils
|
|
26
|
-
import pyboost_utils
|
|
27
|
-
|
|
28
|
-
# refactored
|
|
29
|
-
import template
|
|
30
|
-
|
|
31
|
-
from base_generator import BaseGenerator
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
class OpsPrimitiveHGenerator(BaseGenerator):
|
|
35
|
-
"""
|
|
36
|
-
This class generates the header file for operator primitives.
|
|
37
|
-
"""
|
|
38
|
-
|
|
39
|
-
def __init__(self):
|
|
40
|
-
"""
|
|
41
|
-
Initializes the generator with templates for operator primitive definitions.
|
|
42
|
-
"""
|
|
43
|
-
self.op_prim_op_def_template = template.Template(K.OP_PRIM_OP_DEF)
|
|
44
|
-
self.op_def_template = template.Template(
|
|
45
|
-
"GVAR_DEF(PrimitivePtr, kPrim${k_name_op}, std::make_shared<Primitive>(ops::kName${k_name_op}))\n")
|
|
46
|
-
self.op_def_rw_template = template.Template(
|
|
47
|
-
"GVAR_DEF(PrimitivePtr, kPrim${k_name_op}, std::make_shared<Primitive>(ops::kName${k_name_op}, "
|
|
48
|
-
"true, kPrimTypeBuiltIn, true))\n")
|
|
49
|
-
|
|
50
|
-
def generate(self, work_path, op_protos):
|
|
51
|
-
"""
|
|
52
|
-
Generates the header file content for operator primitives and saves it.
|
|
53
|
-
|
|
54
|
-
Args:
|
|
55
|
-
work_path (str): The directory to save the generated files.
|
|
56
|
-
op_protos (list): A list of operator prototypes.
|
|
57
|
-
|
|
58
|
-
Returns:
|
|
59
|
-
None
|
|
60
|
-
|
|
61
|
-
The method generates the content of the header file for each operator primitive
|
|
62
|
-
defined in the 'op_protos' list and saves it to the specified work path.
|
|
63
|
-
"""
|
|
64
|
-
ops_prim_gen_list = []
|
|
65
|
-
for op_proto in op_protos:
|
|
66
|
-
k_name_op = pyboost_utils.get_op_name(op_proto.op_name, op_proto.op_class.name)
|
|
67
|
-
if op_proto.op_args_signature:
|
|
68
|
-
if op_proto.op_args_signature.rw_write:
|
|
69
|
-
ops_prim_gen_list.append(self.op_def_rw_template.replace(k_name_op=k_name_op))
|
|
70
|
-
continue
|
|
71
|
-
|
|
72
|
-
ops_prim_gen_list.append(self.op_def_template.replace(k_name_op=k_name_op))
|
|
73
|
-
|
|
74
|
-
op_prim_op_def = self.op_prim_op_def_template.replace(auto_gen_path=K.MS_OP_DEF_AUTO_GENERATE_PATH,
|
|
75
|
-
ops_prim_gen=ops_prim_gen_list)
|
|
76
|
-
|
|
77
|
-
res_str = template.CC_LICENSE_STR + op_prim_op_def
|
|
78
|
-
|
|
79
|
-
save_path = os.path.join(work_path, K.MS_OP_DEF_AUTO_GENERATE_PATH)
|
|
80
|
-
file_name = "gen_ops_primitive.h"
|
|
81
|
-
gen_utils.save_file(save_path, file_name, res_str)
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|