mindspore 2.0.0rc1__cp38-none-any.whl → 2.2.0__cp38-none-any.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/Third_Party_Open_Source_Software_Notice +2 -2
- mindspore/__init__.py +5 -2
- mindspore/_akg/akg/build_module.py +5 -6
- mindspore/_akg/akg/composite/build_module.py +49 -16
- mindspore/_akg/akg/composite/split_stitch.py +10 -11
- mindspore/_akg/akg/config/repository.json +195 -0
- mindspore/_akg/akg/global_configs.py +5 -1
- mindspore/_akg/akg/ms/info_version_adapt.py +67 -1
- mindspore/_akg/akg/tvm/api.py +4 -3
- mindspore/_akg/akg/tvm/autotvm/__init__.py +1 -2
- mindspore/_akg/akg/tvm/autotvm/graph_tuner/base_graph_tuner.py +1 -5
- mindspore/_akg/akg/tvm/autotvm/measure/__init__.py +1 -1
- mindspore/_akg/akg/tvm/autotvm/measure/measure.py +1 -10
- mindspore/_akg/akg/tvm/autotvm/measure/measure_methods.py +1 -372
- mindspore/_akg/akg/tvm/build_module.py +16 -1
- mindspore/_akg/akg/tvm/contrib/graph_runtime.py +0 -53
- mindspore/_akg/akg/tvm/hybrid/parser.py +7 -6
- mindspore/_akg/akg/tvm/ir_builder.py +1 -1
- mindspore/_akg/akg/tvm/module.py +1 -2
- mindspore/_akg/akg/tvm/stmt.py +2 -2
- mindspore/_akg/akg/utils/composite_op_helper.py +9 -10
- mindspore/_akg/akg/utils/kernel_exec.py +58 -260
- mindspore/_akg/akg/utils/op_dsl.py +17 -1
- mindspore/_akg/akg/utils/result_analysis.py +4 -24
- mindspore/_akg/akg/utils/tbe_codegen_utils.py +198 -0
- mindspore/_c_dataengine.cpython-38-aarch64-linux-gnu.so +0 -0
- mindspore/_c_expression.cpython-38-aarch64-linux-gnu.so +0 -0
- mindspore/_c_mindrecord.cpython-38-aarch64-linux-gnu.so +0 -0
- mindspore/_check_jit_forbidden_api.py +5 -1
- mindspore/_checkparam.py +79 -62
- mindspore/_extends/graph_kernel/__init__.py +0 -1
- mindspore/_extends/graph_kernel/model/graph_split.py +2 -0
- mindspore/_extends/graph_kernel/model/model_builder.py +9 -50
- mindspore/_extends/graph_kernel/splitter.py +1 -9
- mindspore/_extends/parallel_compile/akg_compiler/akg_process.py +128 -21
- mindspore/_extends/parallel_compile/akg_compiler/build_tbe_kernel.py +2 -2
- mindspore/_extends/parallel_compile/akg_compiler/tbe_topi.py +4 -2
- mindspore/_extends/parallel_compile/tbe_compiler/tbe_adapter.py +18 -13
- mindspore/_extends/parallel_compile/tbe_compiler/tbe_helper.py +13 -9
- mindspore/_extends/parallel_compile/tbe_compiler/tbe_job.py +1 -1
- mindspore/_extends/parallel_compile/tbe_compiler/tbe_job_manager.py +1 -1
- mindspore/_extends/parse/__init__.py +19 -17
- mindspore/_extends/parse/namespace.py +7 -36
- mindspore/_extends/parse/parser.py +375 -189
- mindspore/_extends/parse/resources.py +36 -41
- mindspore/_extends/parse/standard_method.py +350 -245
- mindspore/_extends/parse/trope.py +2 -12
- mindspore/_extends/remote/kernel_build_server.py +24 -7
- mindspore/_extends/remote/kernel_build_server_akg_v2.py +55 -0
- mindspore/_install_custom.py +43 -0
- mindspore/_mindspore_offline_debug.cpython-38-aarch64-linux-gnu.so +0 -0
- mindspore/amp.py +85 -19
- mindspore/bin/cache_admin +0 -0
- mindspore/bin/cache_server +0 -0
- mindspore/boost/base.py +2 -2
- mindspore/boost/boost.py +27 -32
- mindspore/boost/boost_cell_wrapper.py +37 -13
- mindspore/boost/grad_accumulation.py +1 -1
- mindspore/boost/grad_freeze.py +34 -6
- mindspore/boost/group_loss_scale_manager.py +15 -14
- mindspore/boost/less_batch_normalization.py +28 -3
- mindspore/common/__init__.py +15 -11
- mindspore/common/_auto_dynamic.py +68 -0
- mindspore/common/_jit_fallback_utils.py +111 -0
- mindspore/common/_register_for_adapter.py +17 -5
- mindspore/common/_register_for_tensor.py +2 -2
- mindspore/common/_stub_tensor.py +18 -15
- mindspore/common/_utils.py +31 -7
- mindspore/common/api.py +269 -101
- mindspore/common/auto_dynamic_shape.py +498 -0
- mindspore/common/dtype.py +61 -21
- mindspore/common/dump.py +9 -7
- mindspore/common/initializer.py +106 -76
- mindspore/common/jit_config.py +35 -14
- mindspore/common/lazy_inline.py +187 -0
- mindspore/common/mindir_util.py +101 -0
- mindspore/common/mutable.py +10 -13
- mindspore/common/parameter.py +246 -55
- mindspore/common/seed.py +13 -7
- mindspore/common/sparse_tensor.py +29 -33
- mindspore/common/tensor.py +907 -251
- mindspore/communication/__init__.py +7 -4
- mindspore/communication/_comm_helper.py +84 -4
- mindspore/communication/management.py +160 -88
- mindspore/config/op_info.config +99 -75
- mindspore/config/super_bar_config.json +36 -4
- mindspore/context.py +526 -219
- mindspore/dataset/__init__.py +9 -46
- mindspore/dataset/audio/__init__.py +4 -19
- mindspore/dataset/audio/transforms.py +545 -233
- mindspore/dataset/audio/utils.py +21 -18
- mindspore/dataset/callback/ds_callback.py +42 -13
- mindspore/dataset/core/config.py +158 -100
- mindspore/dataset/core/validator_helpers.py +1 -63
- mindspore/dataset/debug/debug_hook.py +45 -13
- mindspore/dataset/debug/pre_defined_hook.py +5 -5
- mindspore/dataset/engine/__init__.py +0 -5
- mindspore/dataset/engine/cache_client.py +38 -15
- mindspore/dataset/engine/datasets.py +615 -278
- mindspore/dataset/engine/datasets_audio.py +154 -283
- mindspore/dataset/engine/datasets_standard_format.py +104 -116
- mindspore/dataset/engine/datasets_text.py +443 -326
- mindspore/dataset/engine/datasets_user_defined.py +251 -164
- mindspore/dataset/engine/datasets_vision.py +839 -1443
- mindspore/dataset/engine/iterators.py +11 -4
- mindspore/dataset/engine/obs/obs_mindrecord_dataset.py +7 -3
- mindspore/dataset/engine/obs/util.py +3 -0
- mindspore/dataset/engine/offload.py +6 -6
- mindspore/dataset/engine/queue.py +15 -14
- mindspore/dataset/engine/samplers.py +39 -23
- mindspore/dataset/engine/serializer_deserializer.py +22 -6
- mindspore/dataset/engine/validators.py +21 -331
- mindspore/dataset/text/__init__.py +5 -33
- mindspore/dataset/text/transforms.py +334 -165
- mindspore/dataset/text/utils.py +215 -145
- mindspore/dataset/transforms/__init__.py +1 -1
- mindspore/dataset/transforms/c_transforms.py +3 -2
- mindspore/dataset/transforms/py_transforms_util.py +40 -12
- mindspore/dataset/transforms/transforms.py +174 -71
- mindspore/dataset/utils/browse_dataset.py +25 -17
- mindspore/dataset/utils/line_reader.py +24 -21
- mindspore/dataset/vision/__init__.py +5 -26
- mindspore/dataset/vision/c_transforms.py +177 -165
- mindspore/dataset/vision/py_transforms.py +114 -119
- mindspore/dataset/vision/py_transforms_util.py +54 -51
- mindspore/dataset/vision/transforms.py +1127 -381
- mindspore/dataset/vision/utils.py +54 -38
- mindspore/dataset/vision/validators.py +12 -2
- mindspore/experimental/map_parameter.py +38 -4
- mindspore/{dataset/datapreprocess → experimental/optim}/__init__.py +14 -4
- mindspore/experimental/optim/adam.py +192 -0
- mindspore/experimental/optim/adamw.py +181 -0
- mindspore/experimental/optim/lr_scheduler.py +1427 -0
- mindspore/experimental/optim/optimizer.py +252 -0
- mindspore/experimental/optim/sgd.py +147 -0
- mindspore/gen_ops.py +273 -0
- mindspore/include/OWNERS +1 -2
- mindspore/include/api/context.h +21 -1
- mindspore/include/api/data_type.h +2 -1
- mindspore/include/api/graph.h +0 -15
- mindspore/include/api/kernel.h +2 -0
- mindspore/include/api/kernel_api.h +37 -12
- mindspore/include/api/model.h +29 -42
- mindspore/include/api/model_group.h +14 -3
- mindspore/include/api/model_parallel_runner.h +18 -2
- mindspore/include/api/serialization.h +26 -0
- mindspore/include/api/status.h +1 -0
- mindspore/include/api/types.h +38 -4
- mindspore/include/c_api/ms/abstract.h +67 -0
- mindspore/include/c_api/ms/attribute.h +197 -0
- mindspore/include/c_api/ms/base/handle_types.h +43 -0
- mindspore/include/c_api/ms/base/macros.h +32 -0
- mindspore/include/c_api/ms/base/status.h +33 -0
- mindspore/include/c_api/ms/base/types.h +282 -0
- mindspore/include/c_api/ms/context.h +102 -0
- mindspore/include/c_api/ms/graph.h +160 -0
- mindspore/include/c_api/ms/node.h +606 -0
- mindspore/include/c_api/ms/tensor.h +161 -0
- mindspore/include/c_api/ms/value.h +84 -0
- mindspore/include/c_api/status_c.h +3 -0
- mindspore/include/dataset/constants.h +6 -12
- mindspore/include/dataset/execute.h +23 -13
- mindspore/include/dataset/text.h +26 -26
- mindspore/include/dataset/transforms.h +25 -31
- mindspore/include/dataset/vision.h +60 -60
- mindspore/include/dataset/vision_ascend.h +5 -6
- mindspore/include/dataset/vision_lite.h +17 -17
- mindspore/include/mindapi/base/format.h +0 -1
- mindspore/include/mindapi/base/type_id.h +2 -1
- mindspore/include/mindapi/base/types.h +5 -1
- mindspore/lib/libdnnl.so.2 +0 -0
- mindspore/lib/libjemalloc.so.2 +0 -0
- mindspore/lib/libmindspore.so +0 -0
- mindspore/lib/libmindspore_backend.so +0 -0
- mindspore/lib/libmindspore_common.so +0 -0
- mindspore/lib/libmindspore_core.so +0 -0
- mindspore/lib/libmindspore_glog.so.0 +0 -0
- mindspore/lib/libmindspore_gpr.so.15 +0 -0
- mindspore/lib/libmindspore_grpc++.so.1 +0 -0
- mindspore/lib/libmindspore_grpc.so.15 +0 -0
- mindspore/lib/libmindspore_shared_lib.so +0 -0
- mindspore/lib/libmpi_adapter.so +0 -0
- mindspore/lib/libnnacl.so +0 -0
- mindspore/lib/libopencv_core.so.4.5 +0 -0
- mindspore/lib/libopencv_imgcodecs.so.4.5 +0 -0
- mindspore/lib/libopencv_imgproc.so.4.5 +0 -0
- mindspore/lib/libps_cache.so +0 -0
- mindspore/lib/plugin/ascend/custom_aicpu_ops/op_impl/cpu/aicpu_kernel/impl/libcust_aicpu_kernels.so +0 -0
- mindspore/lib/plugin/ascend/custom_aicpu_ops/op_impl/cpu/aicpu_kernel/impl/libcust_cpu_kernels.so +0 -0
- mindspore/lib/plugin/ascend/custom_aicpu_ops/op_impl/cpu/config/cust_aicpu_kernel.json +9000 -0
- mindspore/lib/plugin/ascend/custom_aicpu_ops/op_proto/libcust_op_proto.so +0 -0
- mindspore/lib/plugin/ascend/libakg.so +0 -0
- mindspore/lib/plugin/ascend/libascend_collective.so +0 -0
- mindspore/lib/plugin/ascend/libdvpp_utils.so +0 -0
- mindspore/lib/plugin/ascend/libhccl_plugin.so +0 -0
- mindspore/lib/plugin/ascend/libmindspore_aicpu_kernels.so +0 -0
- mindspore/lib/plugin/ascend/libmindspore_cpu_kernels.so +0 -0
- mindspore/lib/plugin/cpu/libakg.so +0 -0
- mindspore/lib/plugin/libmindspore_ascend.so.1 +0 -0
- mindspore/lib/plugin/libmindspore_ascend.so.2 +0 -0
- mindspore/log.py +9 -6
- mindspore/mindrecord/filereader.py +33 -4
- mindspore/mindrecord/filewriter.py +70 -35
- mindspore/mindrecord/mindpage.py +40 -34
- mindspore/mindrecord/shardreader.py +1 -1
- mindspore/mindrecord/shardsegment.py +1 -1
- mindspore/mindrecord/tools/cifar100_to_mr.py +25 -18
- mindspore/mindrecord/tools/cifar10_to_mr.py +25 -18
- mindspore/mindrecord/tools/csv_to_mr.py +29 -13
- mindspore/mindrecord/tools/imagenet_to_mr.py +24 -10
- mindspore/mindrecord/tools/mnist_to_mr.py +24 -11
- mindspore/mindrecord/tools/tfrecord_to_mr.py +31 -26
- mindspore/nn/cell.py +463 -169
- mindspore/nn/dynamic_lr.py +47 -43
- mindspore/nn/layer/activation.py +225 -82
- mindspore/nn/layer/basic.py +121 -79
- mindspore/nn/layer/channel_shuffle.py +21 -21
- mindspore/nn/layer/combined.py +33 -26
- mindspore/nn/layer/container.py +277 -22
- mindspore/nn/layer/conv.py +441 -304
- mindspore/nn/layer/dense.py +19 -13
- mindspore/nn/layer/embedding.py +62 -49
- mindspore/nn/layer/flash_attention.py +264 -0
- mindspore/nn/layer/image.py +50 -39
- mindspore/nn/layer/math.py +62 -51
- mindspore/nn/layer/normalization.py +219 -167
- mindspore/nn/layer/padding.py +58 -70
- mindspore/nn/layer/pooling.py +334 -287
- mindspore/nn/layer/rnn_cells.py +53 -38
- mindspore/nn/layer/rnns.py +59 -56
- mindspore/nn/layer/thor_layer.py +52 -44
- mindspore/nn/layer/timedistributed.py +6 -4
- mindspore/nn/layer/transformer.py +284 -164
- mindspore/nn/learning_rate_schedule.py +34 -25
- mindspore/nn/loss/__init__.py +3 -2
- mindspore/nn/loss/loss.py +554 -311
- mindspore/nn/optim/ada_grad.py +12 -9
- mindspore/nn/optim/adadelta.py +14 -11
- mindspore/nn/optim/adafactor.py +19 -16
- mindspore/nn/optim/adam.py +62 -47
- mindspore/nn/optim/adamax.py +13 -10
- mindspore/nn/optim/adasum.py +12 -8
- mindspore/nn/optim/asgd.py +10 -9
- mindspore/nn/optim/ftrl.py +20 -17
- mindspore/nn/optim/lamb.py +16 -12
- mindspore/nn/optim/lars.py +8 -6
- mindspore/nn/optim/lazyadam.py +25 -20
- mindspore/nn/optim/momentum.py +10 -7
- mindspore/nn/optim/optimizer.py +61 -9
- mindspore/nn/optim/proximal_ada_grad.py +14 -13
- mindspore/nn/optim/rmsprop.py +17 -13
- mindspore/nn/optim/rprop.py +30 -17
- mindspore/nn/optim/sgd.py +40 -23
- mindspore/nn/optim/thor.py +24 -26
- mindspore/nn/probability/bijector/bijector.py +11 -11
- mindspore/nn/probability/bijector/exp.py +1 -1
- mindspore/nn/probability/bijector/gumbel_cdf.py +3 -3
- mindspore/nn/probability/bijector/invert.py +1 -1
- mindspore/nn/probability/bijector/power_transform.py +29 -29
- mindspore/nn/probability/bijector/scalar_affine.py +3 -3
- mindspore/nn/probability/bijector/softplus.py +5 -5
- mindspore/nn/probability/bnn_layers/bnn_cell_wrapper.py +4 -2
- mindspore/nn/probability/bnn_layers/conv_variational.py +13 -13
- mindspore/nn/probability/bnn_layers/dense_variational.py +12 -12
- mindspore/nn/probability/bnn_layers/layer_distribution.py +9 -8
- mindspore/nn/probability/distribution/_utils/custom_ops.py +19 -3
- mindspore/nn/probability/distribution/_utils/utils.py +1 -1
- mindspore/nn/probability/distribution/bernoulli.py +9 -9
- mindspore/nn/probability/distribution/beta.py +8 -8
- mindspore/nn/probability/distribution/categorical.py +23 -15
- mindspore/nn/probability/distribution/cauchy.py +5 -6
- mindspore/nn/probability/distribution/distribution.py +3 -3
- mindspore/nn/probability/distribution/exponential.py +4 -4
- mindspore/nn/probability/distribution/gamma.py +10 -10
- mindspore/nn/probability/distribution/geometric.py +8 -8
- mindspore/nn/probability/distribution/gumbel.py +8 -9
- mindspore/nn/probability/distribution/half_normal.py +5 -5
- mindspore/nn/probability/distribution/laplace.py +5 -5
- mindspore/nn/probability/distribution/log_normal.py +12 -11
- mindspore/nn/probability/distribution/logistic.py +8 -8
- mindspore/nn/probability/distribution/normal.py +6 -5
- mindspore/nn/probability/distribution/poisson.py +10 -11
- mindspore/nn/probability/distribution/student_t.py +8 -9
- mindspore/nn/probability/distribution/transformed_distribution.py +5 -5
- mindspore/nn/probability/distribution/uniform.py +11 -11
- mindspore/nn/reinforcement/tensor_array.py +2 -2
- mindspore/nn/sparse/sparse.py +9 -9
- mindspore/nn/wrap/cell_wrapper.py +188 -63
- mindspore/nn/wrap/grad_reducer.py +21 -12
- mindspore/nn/wrap/loss_scale.py +136 -49
- mindspore/numpy/__init__.py +4 -4
- mindspore/numpy/array_creations.py +55 -56
- mindspore/numpy/array_ops.py +134 -35
- mindspore/numpy/logic_ops.py +66 -20
- mindspore/numpy/math_ops.py +142 -139
- mindspore/numpy/utils_const.py +2 -2
- mindspore/offline_debug/convert_async.py +2 -2
- mindspore/ops/_grad_experimental/__init__.py +7 -5
- mindspore/ops/_grad_experimental/grad_array_ops.py +231 -348
- mindspore/ops/{_grad → _grad_experimental}/grad_base.py +1 -33
- mindspore/ops/{_grad → _grad_experimental}/grad_comm_ops.py +25 -13
- mindspore/ops/{_grad/__init__.py → _grad_experimental/grad_debug_ops.py} +15 -7
- mindspore/ops/{_grad → _grad_experimental}/grad_implementations.py +17 -11
- mindspore/ops/_grad_experimental/grad_inner_ops.py +33 -52
- mindspore/ops/_grad_experimental/grad_math_ops.py +151 -1224
- mindspore/ops/_grad_experimental/grad_nn_ops.py +141 -414
- mindspore/ops/{_grad → _grad_experimental}/grad_quant_ops.py +10 -6
- mindspore/ops/_grad_experimental/grad_sparse.py +317 -2
- mindspore/ops/_grad_experimental/grad_sparse_ops.py +3 -13
- mindspore/ops/{_grad → _grad_experimental}/taylor_rule.py +1 -1
- mindspore/ops/_op_impl/_custom_op/dsd_back_impl.py +1 -1
- mindspore/ops/_op_impl/_custom_op/flash_attention/__init__.py +0 -0
- mindspore/ops/_op_impl/_custom_op/flash_attention/attention.py +406 -0
- mindspore/{_extends/graph_kernel/expanders/complex/__init__.py → ops/_op_impl/_custom_op/flash_attention/constants.py} +27 -8
- mindspore/ops/_op_impl/_custom_op/flash_attention/flash_attention_bwd.py +467 -0
- mindspore/ops/_op_impl/_custom_op/flash_attention/flash_attention_fwd.py +563 -0
- mindspore/ops/_op_impl/_custom_op/flash_attention/flash_attention_impl.py +193 -0
- mindspore/ops/_op_impl/_custom_op/flash_attention/tik_ops_utils.py +435 -0
- mindspore/ops/_op_impl/_custom_op/flash_attention/tiling_strategy/__init__.py +0 -0
- mindspore/ops/_op_impl/_custom_op/flash_attention/tiling_strategy/sparse_tiling.py +45 -0
- mindspore/ops/_op_impl/_custom_op/flash_attention/tiling_strategy/strategy.py +67 -0
- mindspore/ops/_op_impl/_custom_op/flash_attention/tiling_strategy/wukong_tiling.py +62 -0
- mindspore/ops/_op_impl/_custom_op/matmul_cube_dense_left_impl.py +2 -2
- mindspore/ops/_op_impl/aicpu/__init__.py +41 -1
- mindspore/ops/_op_impl/aicpu/adaptive_max_pool_2d.py +37 -0
- mindspore/ops/_op_impl/aicpu/bias_add_grad.py +0 -1
- mindspore/ops/_op_impl/aicpu/cast.py +52 -0
- mindspore/ops/_op_impl/aicpu/coalesce.py +2 -0
- mindspore/ops/_op_impl/aicpu/col2im.py +3 -1
- mindspore/ops/_op_impl/aicpu/count_nonzero.py +43 -0
- mindspore/ops/_op_impl/aicpu/dropout_genmask.py +6 -0
- mindspore/ops/_op_impl/aicpu/eps.py +32 -0
- mindspore/ops/_op_impl/aicpu/eye.py +4 -4
- mindspore/ops/_op_impl/aicpu/fft_with_size.py +6 -0
- mindspore/ops/_op_impl/aicpu/fill_diagonal.py +5 -0
- mindspore/ops/_op_impl/aicpu/gamma.py +2 -2
- mindspore/ops/_op_impl/aicpu/im2col.py +3 -5
- mindspore/ops/_op_impl/aicpu/lgamma.py +1 -0
- mindspore/ops/_op_impl/aicpu/log_uniform_candidate_sampler.py +6 -3
- mindspore/ops/_op_impl/aicpu/lu.py +39 -0
- mindspore/ops/_op_impl/aicpu/lu_unpack_grad.py +0 -1
- mindspore/ops/_op_impl/aicpu/masked_scatter.py +1 -0
- mindspore/ops/_op_impl/aicpu/masked_select_grad.py +3 -0
- mindspore/ops/_op_impl/aicpu/matrix_band_part.py +59 -0
- mindspore/ops/_op_impl/aicpu/matrix_power.py +6 -1
- mindspore/ops/_op_impl/aicpu/median.py +1 -0
- mindspore/ops/_op_impl/aicpu/multinomial.py +9 -9
- mindspore/ops/_op_impl/aicpu/not_equal.py +0 -5
- mindspore/ops/_op_impl/aicpu/pad_v3.py +3 -1
- mindspore/ops/_op_impl/aicpu/pad_v3_grad.py +2 -0
- mindspore/ops/_op_impl/aicpu/parameterized_truncated_normal.py +15 -7
- mindspore/ops/_op_impl/aicpu/random_categorical.py +39 -19
- mindspore/ops/_op_impl/aicpu/random_choice_with_mask.py +5 -2
- mindspore/ops/_op_impl/aicpu/random_poisson.py +103 -52
- mindspore/ops/_op_impl/aicpu/random_shuffle.py +17 -15
- mindspore/ops/_op_impl/aicpu/resize_bilinear_grad.py +0 -1
- mindspore/ops/_op_impl/aicpu/resize_nearest_neighbor_v2.py +0 -6
- mindspore/ops/_op_impl/aicpu/resize_nearest_neighbor_v2_grad.py +0 -7
- mindspore/ops/_op_impl/aicpu/scatter_nd.py +2 -0
- mindspore/ops/_op_impl/aicpu/sequence_concat.py +40 -0
- mindspore/ops/_op_impl/aicpu/sequence_stack.py +40 -0
- mindspore/ops/_op_impl/aicpu/{sparseaddmm.py → sparse_addmm.py} +2 -2
- mindspore/ops/_op_impl/aicpu/{sparsesparsemaximum.py → sparse_sparse_maximum.py} +4 -4
- mindspore/ops/_op_impl/aicpu/standard_laplace.py +5 -4
- mindspore/ops/_op_impl/aicpu/standard_normal.py +5 -4
- mindspore/ops/_op_impl/aicpu/truncated_normal.py +9 -7
- mindspore/ops/_op_impl/aicpu/uniform.py +5 -3
- mindspore/ops/_op_impl/aicpu/uniform_candidate_sampler.py +8 -4
- mindspore/ops/_op_impl/aicpu/uniform_int.py +5 -5
- mindspore/ops/_op_impl/aicpu/uniform_real.py +4 -4
- mindspore/ops/_op_impl/aicpu/upsample_nearest_3d.py +14 -6
- mindspore/ops/_op_impl/aicpu/upsample_nearest_3d_grad.py +22 -8
- mindspore/ops/_op_impl/aicpu/upsample_trilinear_3d.py +11 -6
- mindspore/ops/_op_impl/aicpu/upsample_trilinear_3d_grad.py +21 -10
- mindspore/ops/_op_impl/tbe/__init__.py +6 -4
- mindspore/ops/_op_impl/tbe/atomic_addr_clean.py +1 -1
- mindspore/ops/_op_impl/tbe/avg_pool.py +2 -2
- mindspore/ops/_op_impl/tbe/avg_pool_3d.py +3 -3
- mindspore/ops/_op_impl/tbe/avg_pool_3d_grad.py +4 -4
- mindspore/ops/_op_impl/tbe/avg_pool_ds.py +2 -2
- mindspore/ops/_op_impl/tbe/avg_pool_grad.py +3 -3
- mindspore/ops/_op_impl/tbe/avg_pool_grad_vm.py +3 -3
- mindspore/ops/_op_impl/tbe/batch_to_space.py +1 -1
- mindspore/ops/_op_impl/tbe/batch_to_space_nd.py +2 -2
- mindspore/ops/_op_impl/tbe/bn_infer.py +2 -2
- mindspore/ops/_op_impl/tbe/bn_infer_ds.py +3 -2
- mindspore/ops/_op_impl/tbe/broadcast_to.py +1 -1
- mindspore/ops/_op_impl/tbe/depthwise_conv2d.py +3 -3
- mindspore/ops/_op_impl/tbe/expand_dims.py +1 -1
- mindspore/ops/_op_impl/tbe/gather_v2.py +56 -0
- mindspore/ops/_op_impl/tbe/im2col.py +4 -4
- mindspore/ops/_op_impl/tbe/inplace_index_add.py +7 -3
- mindspore/ops/_op_impl/tbe/mem_set.py +38 -0
- mindspore/ops/_op_impl/tbe/scatter_nd_add.py +3 -0
- mindspore/ops/_op_impl/tbe/scatter_nd_d.py +1 -1
- mindspore/ops/_op_impl/tbe/space_to_batch.py +1 -1
- mindspore/ops/_op_impl/tbe/space_to_batch_nd.py +2 -2
- mindspore/ops/_op_impl/tbe/trans_data_ds.py +2 -0
- mindspore/ops/_primitive_cache.py +1 -1
- mindspore/ops/_tracefunc.py +241 -0
- mindspore/ops/_utils/utils.py +10 -2
- mindspore/ops/_vmap/vmap_array_ops.py +5 -3
- mindspore/ops/_vmap/vmap_base.py +5 -4
- mindspore/ops/_vmap/vmap_convolution_ops.py +1 -1
- mindspore/ops/_vmap/vmap_grad_math_ops.py +6 -4
- mindspore/ops/_vmap/vmap_grad_nn_ops.py +11 -6
- mindspore/ops/_vmap/vmap_math_ops.py +5 -2
- mindspore/ops/_vmap/vmap_nn_ops.py +135 -11
- mindspore/ops/arg_dtype_cast.py +54 -0
- mindspore/ops/composite/__init__.py +7 -5
- mindspore/ops/composite/base.py +78 -34
- mindspore/ops/composite/math_ops.py +5 -695
- mindspore/ops/composite/multitype_ops/_compile_utils.py +403 -97
- mindspore/ops/composite/multitype_ops/_constexpr_utils.py +28 -22
- mindspore/ops/composite/multitype_ops/add_impl.py +69 -7
- 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 -0
- mindspore/ops/composite/multitype_ops/div_impl.py +1 -0
- mindspore/ops/composite/multitype_ops/floordiv_impl.py +1 -0
- mindspore/ops/composite/multitype_ops/getitem_impl.py +48 -10
- mindspore/ops/composite/multitype_ops/greater_equal_impl.py +2 -0
- mindspore/ops/composite/multitype_ops/greater_impl.py +2 -0
- mindspore/ops/composite/multitype_ops/left_shift_impl.py +2 -0
- mindspore/ops/composite/multitype_ops/less_equal_impl.py +2 -0
- mindspore/ops/composite/multitype_ops/less_impl.py +2 -0
- mindspore/ops/composite/multitype_ops/logic_not_impl.py +2 -2
- mindspore/ops/composite/multitype_ops/mod_impl.py +1 -0
- mindspore/ops/composite/multitype_ops/mul_impl.py +1 -0
- mindspore/ops/composite/multitype_ops/negative_impl.py +1 -0
- mindspore/ops/composite/multitype_ops/not_in_impl.py +1 -0
- mindspore/ops/composite/multitype_ops/ones_like_impl.py +6 -0
- mindspore/ops/composite/multitype_ops/pow_impl.py +1 -0
- mindspore/ops/composite/multitype_ops/right_shift_impl.py +2 -0
- mindspore/ops/composite/multitype_ops/setitem_impl.py +10 -7
- mindspore/ops/composite/multitype_ops/sub_impl.py +1 -0
- mindspore/ops/composite/multitype_ops/uadd_impl.py +2 -0
- mindspore/ops/composite/multitype_ops/zeros_like_impl.py +9 -0
- mindspore/ops/deprecated.py +304 -0
- mindspore/ops/function/__init__.py +41 -4
- mindspore/ops/function/array_func.py +1108 -467
- mindspore/ops/function/clip_func.py +94 -27
- mindspore/ops/function/debug_func.py +3 -1
- mindspore/ops/function/grad/grad_func.py +82 -73
- mindspore/ops/function/image_func.py +28 -12
- mindspore/ops/function/linalg_func.py +135 -39
- mindspore/ops/function/math_func.py +3779 -894
- mindspore/ops/function/nn_func.py +1584 -657
- mindspore/ops/function/parameter_func.py +13 -3
- mindspore/ops/function/random_func.py +247 -153
- mindspore/ops/function/sparse_func.py +14 -11
- mindspore/ops/function/sparse_unary_func.py +173 -47
- mindspore/ops/function/spectral_func.py +8 -4
- mindspore/ops/function/vmap_func.py +8 -7
- mindspore/ops/functional.py +47 -16
- mindspore/ops/op_info_register.py +346 -86
- mindspore/ops/operations/__init__.py +38 -22
- mindspore/ops/operations/_grad_ops.py +145 -149
- mindspore/ops/operations/_inner_ops.py +298 -56
- mindspore/ops/operations/_ms_kernel.py +3 -3
- mindspore/ops/operations/_quant_ops.py +24 -28
- mindspore/ops/operations/_rl_inner_ops.py +9 -7
- mindspore/ops/operations/_scalar_ops.py +115 -0
- mindspore/ops/operations/_sequence_ops.py +148 -10
- mindspore/ops/operations/_tensor_array.py +1 -1
- mindspore/ops/operations/_thor_ops.py +2 -2
- mindspore/ops/operations/array_ops.py +1239 -561
- mindspore/ops/operations/comm_ops.py +166 -90
- mindspore/ops/operations/control_ops.py +3 -3
- mindspore/ops/operations/custom_ops.py +124 -102
- mindspore/ops/operations/debug_ops.py +24 -11
- mindspore/ops/operations/image_ops.py +86 -71
- mindspore/ops/operations/inner_ops.py +18 -13
- mindspore/ops/operations/linalg_ops.py +30 -11
- mindspore/ops/operations/math_ops.py +1730 -435
- mindspore/ops/operations/nn_ops.py +1953 -943
- mindspore/ops/operations/other_ops.py +65 -43
- mindspore/ops/operations/random_ops.py +258 -98
- mindspore/ops/operations/rl_ops.py +4 -36
- mindspore/ops/operations/sparse_ops.py +38 -33
- mindspore/ops/operations/spectral_ops.py +8 -4
- mindspore/ops/primitive.py +66 -44
- mindspore/ops/signature.py +5 -5
- mindspore/parallel/_auto_parallel_context.py +80 -19
- mindspore/parallel/_cost_model_context.py +42 -0
- mindspore/parallel/_offload_context.py +162 -72
- mindspore/parallel/_parallel_serialization.py +2 -2
- mindspore/parallel/_ps_context.py +16 -4
- mindspore/parallel/_recovery_context.py +2 -1
- mindspore/parallel/_tensor.py +15 -13
- mindspore/parallel/_transformer/layers.py +8 -6
- mindspore/parallel/_transformer/loss.py +1 -0
- mindspore/parallel/_transformer/moe.py +7 -7
- mindspore/parallel/_transformer/op_parallel_config.py +12 -1
- mindspore/parallel/_transformer/transformer.py +34 -14
- mindspore/parallel/_utils.py +36 -14
- mindspore/parallel/algo_parameter_config.py +114 -20
- mindspore/parallel/checkpoint_transform.py +16 -18
- mindspore/parallel/shard.py +16 -13
- mindspore/profiler/__init__.py +1 -1
- mindspore/profiler/common/struct_type.py +3 -3
- mindspore/profiler/common/util.py +3 -2
- mindspore/profiler/envprofiling.py +11 -4
- mindspore/profiler/parser/aicpu_data_parser.py +5 -3
- mindspore/profiler/parser/ascend_flops_generator.py +94 -0
- mindspore/profiler/parser/ascend_fpbp_generator.py +76 -0
- mindspore/profiler/parser/ascend_hccl_generator.py +288 -0
- mindspore/profiler/parser/ascend_msprof_exporter.py +213 -0
- mindspore/profiler/parser/ascend_msprof_generator.py +199 -0
- mindspore/profiler/parser/ascend_op_generator.py +276 -0
- mindspore/profiler/parser/ascend_steptrace_generator.py +94 -0
- mindspore/profiler/parser/ascend_timeline_generator.py +110 -54
- mindspore/profiler/parser/base_timeline_generator.py +11 -7
- mindspore/profiler/parser/cpu_gpu_timeline_generator.py +45 -46
- mindspore/profiler/parser/flops_parser.py +15 -11
- mindspore/profiler/parser/framework_parser.py +92 -73
- mindspore/profiler/parser/hccl_parser.py +16 -12
- mindspore/profiler/parser/integrator.py +22 -11
- mindspore/profiler/parser/memory_usage_parser.py +36 -11
- mindspore/profiler/parser/minddata_analyzer.py +12 -14
- mindspore/profiler/parser/minddata_pipeline_parser.py +1 -1
- mindspore/profiler/parser/msadvisor_parser.py +8 -4
- mindspore/profiler/parser/op_intermediate_parser.py +5 -2
- mindspore/profiler/parser/optime_parser.py +1 -1
- mindspore/profiler/parser/profiler_info.py +4 -5
- mindspore/profiler/parser/step_trace_parser.py +11 -14
- mindspore/profiler/profiling.py +678 -377
- mindspore/rewrite/api/node.py +211 -54
- mindspore/rewrite/api/node_type.py +5 -0
- mindspore/rewrite/api/pattern_engine.py +22 -23
- mindspore/rewrite/api/scoped_value.py +20 -17
- mindspore/rewrite/api/symbol_tree.py +252 -106
- mindspore/rewrite/api/tree_node_helper.py +3 -0
- mindspore/rewrite/ast_helpers/__init__.py +2 -1
- mindspore/rewrite/ast_helpers/ast_finder.py +129 -0
- mindspore/rewrite/ast_helpers/ast_modifier.py +116 -104
- mindspore/rewrite/ast_transformers/flatten_recursive_stmt.py +97 -46
- mindspore/rewrite/common/rewrite_elog.py +5 -1
- mindspore/rewrite/namer.py +51 -51
- mindspore/rewrite/namespace.py +14 -5
- mindspore/{ops/bprop_mindir → rewrite/node}/__init__.py +9 -4
- mindspore/rewrite/node/call_function.py +79 -0
- mindspore/rewrite/node/cell_container.py +135 -0
- mindspore/rewrite/node/control_flow.py +88 -0
- mindspore/rewrite/{node.py → node/node.py} +313 -247
- mindspore/rewrite/node/node_manager.py +254 -0
- mindspore/rewrite/node/node_topological_manager.py +243 -0
- mindspore/rewrite/parsers/arguments_parser.py +22 -21
- mindspore/rewrite/parsers/assign_parser.py +225 -239
- mindspore/rewrite/parsers/attribute_parser.py +9 -7
- mindspore/rewrite/parsers/class_def_parser.py +179 -218
- mindspore/rewrite/parsers/constant_parser.py +9 -6
- mindspore/rewrite/parsers/container_parser.py +9 -7
- mindspore/rewrite/parsers/for_parser.py +36 -15
- mindspore/rewrite/parsers/function_def_parser.py +23 -20
- mindspore/rewrite/parsers/if_parser.py +28 -24
- mindspore/rewrite/parsers/module_parser.py +202 -25
- mindspore/rewrite/{parser.py → parsers/parser.py} +4 -2
- mindspore/rewrite/{parser_register.py → parsers/parser_register.py} +1 -1
- mindspore/rewrite/parsers/return_parser.py +6 -6
- mindspore/rewrite/sparsify/sparse_transformer.py +12 -3
- mindspore/rewrite/sparsify/sparsify.py +4 -1
- mindspore/rewrite/sparsify/utils.py +11 -5
- mindspore/rewrite/symbol_tree.py +577 -732
- mindspore/rewrite/symbol_tree_builder.py +9 -175
- mindspore/rewrite/symbol_tree_dumper.py +2 -2
- mindspore/run_check/_check_version.py +46 -39
- mindspore/run_check/run_check.py +3 -2
- mindspore/{scipy/sparse → safeguard}/__init__.py +4 -5
- mindspore/safeguard/rewrite_obfuscation.py +517 -0
- mindspore/scipy/__init__.py +1 -1
- mindspore/scipy/linalg.py +67 -61
- mindspore/scipy/ops.py +5 -41
- mindspore/scipy/ops_grad.py +3 -2
- mindspore/scipy/ops_wrapper.py +5 -5
- mindspore/scipy/optimize/line_search.py +8 -8
- mindspore/scipy/optimize/linear_sum_assignment.py +4 -4
- mindspore/scipy/optimize/minimize.py +16 -12
- mindspore/scipy/utils.py +1 -52
- mindspore/scipy/utils_const.py +4 -4
- mindspore/train/__init__.py +4 -4
- mindspore/train/_utils.py +13 -5
- mindspore/train/amp.py +410 -148
- mindspore/train/anf_ir_pb2.py +16 -4
- mindspore/train/callback/_backup_and_restore.py +8 -11
- mindspore/train/callback/_callback.py +80 -3
- mindspore/train/callback/_checkpoint.py +82 -51
- mindspore/train/callback/_early_stop.py +12 -15
- mindspore/train/callback/_history.py +1 -1
- mindspore/train/callback/_lambda_callback.py +13 -13
- mindspore/train/callback/_landscape.py +21 -17
- mindspore/train/callback/_loss_monitor.py +9 -10
- mindspore/train/callback/_on_request_exit.py +16 -33
- mindspore/train/callback/_reduce_lr_on_plateau.py +21 -24
- mindspore/train/callback/_summary_collector.py +44 -30
- mindspore/train/callback/_time_monitor.py +62 -12
- mindspore/train/data_sink.py +10 -16
- mindspore/train/dataset_helper.py +154 -86
- mindspore/train/loss_scale_manager.py +14 -9
- mindspore/train/metrics/__init__.py +10 -2
- mindspore/train/metrics/accuracy.py +1 -1
- mindspore/train/metrics/auc.py +1 -1
- mindspore/train/metrics/bleu_score.py +2 -2
- mindspore/train/metrics/confusion_matrix.py +14 -14
- mindspore/train/metrics/cosine_similarity.py +3 -3
- mindspore/train/metrics/dice.py +1 -1
- mindspore/train/metrics/fbeta.py +1 -1
- mindspore/train/metrics/hausdorff_distance.py +8 -6
- mindspore/train/metrics/mean_surface_distance.py +5 -4
- mindspore/train/metrics/metric.py +49 -17
- mindspore/train/metrics/occlusion_sensitivity.py +4 -4
- mindspore/train/metrics/perplexity.py +1 -1
- mindspore/train/metrics/precision.py +2 -2
- mindspore/train/metrics/recall.py +2 -3
- mindspore/train/metrics/roc.py +7 -7
- mindspore/train/metrics/root_mean_square_surface_distance.py +5 -4
- mindspore/train/metrics/topk.py +7 -4
- mindspore/train/mind_ir_pb2.py +193 -48
- mindspore/train/model.py +377 -133
- mindspore/train/serialization.py +697 -245
- mindspore/train/summary/_summary_adapter.py +5 -2
- mindspore/train/summary/_writer_pool.py +4 -3
- mindspore/train/summary/summary_record.py +25 -23
- mindspore/train/train_thor/convert_utils.py +39 -23
- mindspore/train/train_thor/dataset_helper.py +4 -3
- mindspore/train/train_thor/model_thor.py +8 -8
- mindspore/version.py +1 -1
- {mindspore-2.0.0rc1.dist-info → mindspore-2.2.0.dist-info}/METADATA +7 -8
- {mindspore-2.0.0rc1.dist-info → mindspore-2.2.0.dist-info}/RECORD +633 -804
- {mindspore-2.0.0rc1.dist-info → mindspore-2.2.0.dist-info}/entry_points.txt +0 -1
- mindspore/_akg/akg/tvm/contrib/debugger/__init__.py +0 -16
- mindspore/_akg/akg/tvm/contrib/debugger/debug_result.py +0 -274
- mindspore/_akg/akg/tvm/contrib/debugger/debug_runtime.py +0 -259
- mindspore/_akg/akg/tvm/contrib/peak.py +0 -341
- mindspore/_akg/akg/tvm/contrib/rpc.py +0 -25
- mindspore/_akg/akg/tvm/contrib/xcode.py +0 -257
- mindspore/_akg/akg/tvm/exec/__init__.py +0 -17
- mindspore/_akg/akg/tvm/exec/autotvm_log_editor.py +0 -60
- mindspore/_akg/akg/tvm/exec/measure_peak.py +0 -48
- mindspore/_akg/akg/tvm/exec/query_rpc_tracker.py +0 -48
- mindspore/_akg/akg/tvm/exec/rpc_proxy.py +0 -98
- mindspore/_akg/akg/tvm/exec/rpc_server.py +0 -88
- mindspore/_akg/akg/tvm/exec/rpc_tracker.py +0 -62
- mindspore/_akg/akg/tvm/rpc/__init__.py +0 -29
- mindspore/_akg/akg/tvm/rpc/base.py +0 -182
- mindspore/_akg/akg/tvm/rpc/client.py +0 -436
- mindspore/_akg/akg/tvm/rpc/proxy.py +0 -595
- mindspore/_akg/akg/tvm/rpc/server.py +0 -413
- mindspore/_akg/akg/tvm/rpc/tornado_util.py +0 -121
- mindspore/_akg/akg/tvm/rpc/tracker.py +0 -431
- mindspore/_extends/graph_kernel/expander.py +0 -80
- mindspore/_extends/graph_kernel/expanders/__init__.py +0 -57
- mindspore/_extends/graph_kernel/expanders/_utils.py +0 -269
- mindspore/_extends/graph_kernel/expanders/addn.py +0 -33
- mindspore/_extends/graph_kernel/expanders/batchnorm.py +0 -152
- mindspore/_extends/graph_kernel/expanders/batchnorm_grad.py +0 -105
- mindspore/_extends/graph_kernel/expanders/bias_add_grad.py +0 -49
- mindspore/_extends/graph_kernel/expanders/clip_by_norm_no_div_sum.py +0 -33
- mindspore/_extends/graph_kernel/expanders/complex/abs.py +0 -30
- mindspore/_extends/graph_kernel/expanders/complex/add.py +0 -44
- mindspore/_extends/graph_kernel/expanders/complex/div.py +0 -62
- mindspore/_extends/graph_kernel/expanders/complex/mul.py +0 -52
- mindspore/_extends/graph_kernel/expanders/complex/real_div.py +0 -62
- mindspore/_extends/graph_kernel/expanders/complex/sub.py +0 -45
- mindspore/_extends/graph_kernel/expanders/conv2d.py +0 -200
- mindspore/_extends/graph_kernel/expanders/dropout_grad.py +0 -30
- mindspore/_extends/graph_kernel/expanders/equal_count.py +0 -50
- mindspore/_extends/graph_kernel/expanders/erfc.py +0 -35
- mindspore/_extends/graph_kernel/expanders/expand_dims.py +0 -50
- mindspore/_extends/graph_kernel/expanders/fused_adam.py +0 -44
- mindspore/_extends/graph_kernel/expanders/fused_adam_weight_decay.py +0 -47
- mindspore/_extends/graph_kernel/expanders/fused_mul_add.py +0 -28
- mindspore/_extends/graph_kernel/expanders/gather.py +0 -43
- mindspore/_extends/graph_kernel/expanders/gelu_grad.py +0 -70
- mindspore/_extends/graph_kernel/expanders/gkdropout.py +0 -40
- mindspore/_extends/graph_kernel/expanders/identity.py +0 -25
- mindspore/_extends/graph_kernel/expanders/layernorm.py +0 -93
- mindspore/_extends/graph_kernel/expanders/layernorm_grad.py +0 -113
- mindspore/_extends/graph_kernel/expanders/logsoftmax.py +0 -46
- mindspore/_extends/graph_kernel/expanders/logsoftmax_grad.py +0 -36
- mindspore/_extends/graph_kernel/expanders/matmul.py +0 -80
- mindspore/_extends/graph_kernel/expanders/maximum_grad.py +0 -59
- mindspore/_extends/graph_kernel/expanders/minimum_grad.py +0 -80
- mindspore/_extends/graph_kernel/expanders/oneslike.py +0 -26
- mindspore/_extends/graph_kernel/expanders/reduce_mean.py +0 -43
- mindspore/_extends/graph_kernel/expanders/relu_grad.py +0 -32
- mindspore/_extends/graph_kernel/expanders/sigmoid_cross_entropy_with_logits.py +0 -41
- mindspore/_extends/graph_kernel/expanders/sigmoid_cross_entropy_with_logits_grad.py +0 -35
- mindspore/_extends/graph_kernel/expanders/sigmoid_grad.py +0 -31
- mindspore/_extends/graph_kernel/expanders/slice.py +0 -35
- mindspore/_extends/graph_kernel/expanders/softmax_cross_entropy_with_logits.py +0 -42
- mindspore/_extends/graph_kernel/expanders/softmax_grad_ext.py +0 -41
- mindspore/_extends/graph_kernel/expanders/softsign.py +0 -28
- mindspore/_extends/graph_kernel/expanders/sqrt_grad.py +0 -29
- mindspore/_extends/graph_kernel/expanders/square_sum_all.py +0 -44
- mindspore/_extends/graph_kernel/expanders/square_sum_v1.py +0 -37
- mindspore/_extends/graph_kernel/expanders/squared_difference.py +0 -43
- mindspore/_extends/graph_kernel/expanders/tanh_grad.py +0 -31
- mindspore/_extends/graph_kernel/expanders/tile.py +0 -54
- mindspore/_extends/graph_kernel/model/op_infer.py +0 -506
- mindspore/_extends/parse/jit_fallback_modules.py +0 -51
- mindspore/dataset/datapreprocess/preprocess_imagenet_validate_dataset.py +0 -54
- mindspore/dataset/engine/graphdata.py +0 -1586
- mindspore/include/api/net.h +0 -142
- mindspore/ops/_grad/grad_array_ops.py +0 -1347
- mindspore/ops/_grad/grad_clip_ops.py +0 -84
- mindspore/ops/_grad/grad_debug_ops.py +0 -68
- mindspore/ops/_grad/grad_inner_ops.py +0 -235
- mindspore/ops/_grad/grad_math_ops.py +0 -1684
- mindspore/ops/_grad/grad_nn_ops.py +0 -1529
- mindspore/ops/_grad/grad_other_ops.py +0 -89
- mindspore/ops/_grad/grad_sequence_ops.py +0 -296
- mindspore/ops/_grad/grad_sparse.py +0 -323
- mindspore/ops/_grad_experimental/grad_image_ops.py +0 -249
- mindspore/ops/_grad_experimental/grad_linalg_ops.py +0 -195
- mindspore/ops/_grad_experimental/grad_scalar_ops.py +0 -112
- mindspore/ops/bprop_mindir/AdaptiveAvgPool2D_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/AdaptiveMaxPool2D_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/ApproximateEqual_bprop.mindir +0 -19
- mindspore/ops/bprop_mindir/Argmax_bprop.mindir +0 -15
- mindspore/ops/bprop_mindir/Argmin_bprop.mindir +0 -15
- mindspore/ops/bprop_mindir/AssignSub_bprop.mindir +0 -19
- mindspore/ops/bprop_mindir/Assign_bprop.mindir +0 -17
- mindspore/ops/bprop_mindir/AvgPool3D_bprop.mindir +0 -150
- mindspore/ops/bprop_mindir/AvgPool_bprop.mindir +0 -66
- mindspore/ops/bprop_mindir/BCEWithLogitsLoss_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/BNTrainingReduce_bprop.mindir +0 -15
- mindspore/ops/bprop_mindir/BatchNormGrad_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/BatchToSpaceND_bprop.mindir +0 -28
- mindspore/ops/bprop_mindir/BiasAddGrad_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/BinaryCrossEntropy_bprop.mindir +0 -33
- mindspore/ops/bprop_mindir/BroadcastTo_bprop.mindir +0 -306
- mindspore/ops/bprop_mindir/Broadcast_bprop.mindir +0 -13
- mindspore/ops/bprop_mindir/CTCLoss_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/Concat_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/Conv2DBackpropFilter_bprop.mindir +0 -240
- mindspore/ops/bprop_mindir/Conv2DBackpropInput_bprop.mindir +0 -247
- mindspore/ops/bprop_mindir/Conv2DTranspose_bprop.mindir +0 -247
- mindspore/ops/bprop_mindir/Conv3DTranspose_bprop.mindir +0 -315
- mindspore/ops/bprop_mindir/Conv3D_bprop.mindir +0 -278
- mindspore/ops/bprop_mindir/DType_bprop.mindir +0 -14
- mindspore/ops/bprop_mindir/DeformableOffsets_bprop.mindir +0 -58
- mindspore/ops/bprop_mindir/Depend_bprop.mindir +0 -13
- mindspore/ops/bprop_mindir/DepthToSpace_bprop.mindir +0 -23
- mindspore/ops/bprop_mindir/DepthwiseConv2dNative_bprop.mindir +0 -138
- mindspore/ops/bprop_mindir/DiagPart_bprop.mindir +0 -15
- mindspore/ops/bprop_mindir/Dropout2D_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/Dropout3D_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/DropoutDoMask_bprop.mindir +0 -25
- mindspore/ops/bprop_mindir/DropoutGenMask_bprop.mindir +0 -18
- mindspore/ops/bprop_mindir/DropoutGrad_bprop.mindir +0 -27
- mindspore/ops/bprop_mindir/Dropout_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/DynamicGRUV2_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/DynamicRNN_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/DynamicShape_bprop.mindir +0 -14
- mindspore/ops/bprop_mindir/Elu_bprop.mindir +0 -16
- mindspore/ops/bprop_mindir/EmbeddingLookup_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/Equal_bprop.mindir +0 -19
- mindspore/ops/bprop_mindir/ExpandDims_bprop.mindir +0 -58
- mindspore/ops/bprop_mindir/FastGeLU_bprop.mindir +0 -16
- mindspore/ops/bprop_mindir/Flatten_bprop.mindir +0 -54
- mindspore/ops/bprop_mindir/FloorDiv_bprop.mindir +0 -19
- mindspore/ops/bprop_mindir/GatherD_bprop.mindir +0 -26
- mindspore/ops/bprop_mindir/GatherNd_bprop.mindir +0 -57
- mindspore/ops/bprop_mindir/Gather_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/GreaterEqual_bprop.mindir +0 -19
- mindspore/ops/bprop_mindir/Greater_bprop.mindir +0 -19
- mindspore/ops/bprop_mindir/HSigmoid_bprop.mindir +0 -16
- mindspore/ops/bprop_mindir/HSwish_bprop.mindir +0 -16
- mindspore/ops/bprop_mindir/IOU_bprop.mindir +0 -19
- mindspore/ops/bprop_mindir/InstanceNorm_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/IsFinite_bprop.mindir +0 -15
- mindspore/ops/bprop_mindir/IsInf_bprop.mindir +0 -15
- mindspore/ops/bprop_mindir/IsNan_bprop.mindir +0 -15
- mindspore/ops/bprop_mindir/KLDivLoss_bprop.mindir +0 -126
- mindspore/ops/bprop_mindir/L2Loss_bprop.mindir +0 -15
- mindspore/ops/bprop_mindir/L2Normalize_bprop.mindir +0 -30
- mindspore/ops/bprop_mindir/LRN_bprop.mindir +0 -43
- mindspore/ops/bprop_mindir/LayerNormGrad_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/LessEqual_bprop.mindir +0 -19
- mindspore/ops/bprop_mindir/Less_bprop.mindir +0 -19
- mindspore/ops/bprop_mindir/LinSpace_bprop.mindir +0 -23
- mindspore/ops/bprop_mindir/Load_bprop.mindir +0 -13
- mindspore/ops/bprop_mindir/LogSoftmax_bprop.mindir +0 -23
- mindspore/ops/bprop_mindir/LogicalAnd_bprop.mindir +0 -19
- mindspore/ops/bprop_mindir/LogicalNot_bprop.mindir +0 -15
- mindspore/ops/bprop_mindir/MaskedSelect_bprop.mindir +0 -21
- mindspore/ops/bprop_mindir/MaxPool3DGradGrad_bprop.mindir +0 -74
- mindspore/ops/bprop_mindir/MaxPool3DGrad_bprop.mindir +0 -74
- mindspore/ops/bprop_mindir/MaxPool3D_bprop.mindir +0 -75
- mindspore/ops/bprop_mindir/MaxPoolGradGrad_bprop.mindir +0 -65
- mindspore/ops/bprop_mindir/MaxPoolWithArgmax_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/Maximum_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/Minimum_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/MirrorPad_bprop.mindir +0 -27
- mindspore/ops/bprop_mindir/Mish_bprop.mindir +0 -35
- mindspore/ops/bprop_mindir/MulNoNan_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/NLLLoss_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/NonZero_bprop.mindir +0 -14
- mindspore/ops/bprop_mindir/NotEqual_bprop.mindir +0 -19
- mindspore/ops/bprop_mindir/OneHot_bprop.mindir +0 -26
- mindspore/ops/bprop_mindir/OnesLike_bprop.mindir +0 -14
- mindspore/ops/bprop_mindir/PReLU_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/Pad_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/Padding_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/RNNTLoss_bprop.mindir +0 -29
- mindspore/ops/bprop_mindir/ROIAlign_bprop.mindir +0 -82
- mindspore/ops/bprop_mindir/Range_bprop.mindir +0 -22
- mindspore/ops/bprop_mindir/Rank_bprop.mindir +0 -14
- mindspore/ops/bprop_mindir/ReLU6_bprop.mindir +0 -16
- mindspore/ops/bprop_mindir/ReLUV2_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/ReduceAll_bprop.mindir +0 -19
- mindspore/ops/bprop_mindir/ReduceAny_bprop.mindir +0 -19
- mindspore/ops/bprop_mindir/ReluGrad_bprop.mindir +0 -20
- mindspore/ops/bprop_mindir/Reshape_bprop.mindir +0 -60
- mindspore/ops/bprop_mindir/ResizeBilinear_bprop.mindir +0 -29
- mindspore/ops/bprop_mindir/ResizeNearestNeighbor_bprop.mindir +0 -89
- mindspore/ops/bprop_mindir/ReverseSequence_bprop.mindir +0 -52
- mindspore/ops/bprop_mindir/ReverseV2_bprop.mindir +0 -22
- mindspore/ops/bprop_mindir/Round_bprop.mindir +0 -15
- mindspore/ops/bprop_mindir/ScatterMax_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/ScatterMin_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/ScatterNdUpdate_bprop.mindir +0 -22
- mindspore/ops/bprop_mindir/ScatterNd_bprop.mindir +0 -24
- mindspore/ops/bprop_mindir/ScatterNonAliasingAdd_bprop.mindir +0 -22
- mindspore/ops/bprop_mindir/ScatterUpdate_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/SeLU_bprop.mindir +0 -21
- mindspore/ops/bprop_mindir/Select_bprop.mindir +0 -31
- mindspore/ops/bprop_mindir/Shape_bprop.mindir +0 -14
- mindspore/ops/bprop_mindir/SigmoidCrossEntropyWithLogits_bprop.mindir +0 -21
- mindspore/ops/bprop_mindir/SigmoidGrad_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/Sigmoid_bprop.mindir +0 -16
- mindspore/ops/bprop_mindir/Sign_bprop.mindir +0 -15
- mindspore/ops/bprop_mindir/Slice_bprop.mindir +0 -26
- mindspore/ops/bprop_mindir/SmoothL1Loss_bprop.mindir +0 -36
- mindspore/ops/bprop_mindir/SoftmaxCrossEntropyWithLogits_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/Softplus_bprop.mindir +0 -16
- mindspore/ops/bprop_mindir/Softsign_bprop.mindir +0 -33
- mindspore/ops/bprop_mindir/Sort_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/SpaceToBatchND_bprop.mindir +0 -28
- mindspore/ops/bprop_mindir/SpaceToDepth_bprop.mindir +0 -23
- mindspore/ops/bprop_mindir/SparseGatherV2_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/SparseSoftmaxCrossEntropyWithLogits_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/Split_bprop.mindir +0 -22
- mindspore/ops/bprop_mindir/Squeeze_bprop.mindir +0 -54
- mindspore/ops/bprop_mindir/StridedSliceGrad_bprop.mindir +0 -95
- mindspore/ops/bprop_mindir/StridedSlice_bprop.mindir +0 -98
- mindspore/ops/bprop_mindir/Switch_bprop.mindir +0 -29
- mindspore/ops/bprop_mindir/TanhGrad_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/Tanh_bprop.mindir +0 -66
- mindspore/ops/bprop_mindir/TensorScatterAdd_bprop.mindir +0 -22
- mindspore/ops/bprop_mindir/TensorScatterUpdate_bprop.mindir +0 -29
- mindspore/ops/bprop_mindir/TensorShape_bprop.mindir +0 -14
- mindspore/ops/bprop_mindir/Tile_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/TopK_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/TransShape_bprop.mindir +0 -23
- mindspore/ops/bprop_mindir/TruncateDiv_bprop.mindir +0 -19
- mindspore/ops/bprop_mindir/TupleGetItem_bprop.mindir +0 -20
- mindspore/ops/bprop_mindir/Unique_bprop.mindir +0 -16
- mindspore/ops/bprop_mindir/Unstack_bprop.mindir +0 -22
- mindspore/ops/bprop_mindir/UpsampleNearest3D_bprop.mindir +0 -32
- mindspore/ops/bprop_mindir/UpsampleTrilinear3D_bprop.mindir +0 -38
- mindspore/ops/bprop_mindir/ZerosLike_bprop.mindir +0 -15
- mindspore/ops/bprop_mindir/generate_mindir.py +0 -114
- mindspore/rewrite/node_visitor.py +0 -44
- mindspore/rewrite/topological_manager.py +0 -203
- mindspore/scipy/sparse/linalg.py +0 -192
- {mindspore-2.0.0rc1.dist-info → mindspore-2.2.0.dist-info}/WHEEL +0 -0
- {mindspore-2.0.0rc1.dist-info → mindspore-2.2.0.dist-info}/top_level.txt +0 -0
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
0.1.1 MindSpore*2.0.0:�
|
|
3
|
-
,get_bprop_tensor_scatter_update.1:[CNode]2:1,get_bprop_tensor_scatter_update.1:[CNode]2:1"REF::bprop.3:Default/bprop.3-op0
|
|
4
|
-
�9get_bprop_tensor_scatter_update.1:tensor_scatter_update:29get_bprop_tensor_scatter_update.1:tensor_scatter_update:2"FREF::ClassType::mindspore.ops.operations.array_ops.TensorScatterUpdate:JDefault/class 'mindspore.ops.operations.array_ops.TensorScatterUpdate'-op1
|
|
5
|
-
�-get_bprop_tensor_scatter_update.1:gather_nd:6-get_bprop_tensor_scatter_update.1:gather_nd:6";REF::ClassType::mindspore.ops.operations.array_ops.GatherNd:?Default/class 'mindspore.ops.operations.array_ops.GatherNd'-op5!get_bprop_tensor_scatter_update.1*(
|
|
6
|
-
&get_bprop_tensor_scatter_update.1:self*%
|
|
7
|
-
#get_bprop_tensor_scatter_update.1:x*+
|
|
8
|
-
)get_bprop_tensor_scatter_update.1:indices**
|
|
9
|
-
(get_bprop_tensor_scatter_update.1:update*'
|
|
10
|
-
%get_bprop_tensor_scatter_update.1:out*(
|
|
11
|
-
&get_bprop_tensor_scatter_update.1:dout2.
|
|
12
|
-
,get_bprop_tensor_scatter_update.1:[CNode]2:1:@8c2f7c478e1ce828147875b7eeb3e898896dea47389d946a79a1d2499b6915d8J/grad_array_ops.pyB�
|
|
13
|
-
�
|
|
14
|
-
(get_bprop_tensor_scatter_update.1:updatebprop.3:[CNode]4:3bprop.3:[CNode]4:3".REF::MetaFuncGraph::hyper_map[zeros_like_leaf]:-Default/S-Prim-hyper_map[zeros_like_leaf]-op2
|
|
15
|
-
�
|
|
16
|
-
&get_bprop_tensor_scatter_update.1:dout
|
|
17
|
-
)get_bprop_tensor_scatter_update.1:indices
|
|
18
|
-
bprop.3:[CNode]4:3bprop.3:x_grad:4bprop.3:x_grad:4">REF::get_bprop_tensor_scatter_update.1:tensor_scatter_update:2:3
|
|
19
|
-
�
|
|
20
|
-
)get_bprop_tensor_scatter_update.1:indicesbprop.3:[CNode]5:5bprop.3:[CNode]5:5".REF::MetaFuncGraph::hyper_map[zeros_like_leaf]:-Default/S-Prim-hyper_map[zeros_like_leaf]-op4
|
|
21
|
-
�
|
|
22
|
-
&get_bprop_tensor_scatter_update.1:dout
|
|
23
|
-
)get_bprop_tensor_scatter_update.1:indicesbprop.3:update_grad:7bprop.3:update_grad:7"2REF::get_bprop_tensor_scatter_update.1:gather_nd:6:6
|
|
24
|
-
�
|
|
25
|
-
bprop.3:x_grad:4
|
|
26
|
-
bprop.3:[CNode]5:5
|
|
27
|
-
bprop.3:update_grad:7bprop.3:[CNode]6:8bprop.3:[CNode]6:8"REF::S-Prim-MakeTuple:9:Default/S-Prim-MakeTuple-op7bprop.32
|
|
28
|
-
bprop.3:[CNode]6:8Pb&
|
|
29
|
-
S-Prim-MakeTuple:9S-Prim-MakeTupleh
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
0.1.1 MindSpore*2.0.0:�
|
|
3
|
-
r$get_bprop_tensorshape.21:[CNode]22:1$get_bprop_tensorshape.21:[CNode]22:1"
|
|
4
|
-
get_bprop_tensorshape.21:self*
|
|
5
|
-
get_bprop_tensorshape.21:x*
|
|
6
|
-
get_bprop_tensorshape.21:out*
|
|
7
|
-
get_bprop_tensorshape.21:dout2&
|
|
8
|
-
$get_bprop_tensorshape.21:[CNode]22:1:@62dc7ba53f71834ce824222195cb6a9af0b1f9d5c7e86cd3ac9eecfb0e3e1b3dJ/grad_array_ops.pyB�
|
|
9
|
-
�
|
|
10
|
-
get_bprop_tensorshape.21:xbprop.23:[CNode]24:2bprop.23:[CNode]24:2".REF::MetaFuncGraph::hyper_map[zeros_like_leaf]:.Default/S-Prim-hyper_map[zeros_like_leaf]-op14
|
|
11
|
-
z
|
|
12
|
-
bprop.23:[CNode]24:2bprop.23:[CNode]25:3bprop.23:[CNode]25:3"REF::S-Prim-MakeTuple:4:Default/S-Prim-MakeTuple-op15bprop.232
|
|
13
|
-
bprop.23:[CNode]25:3Pb&
|
|
14
|
-
S-Prim-MakeTuple:4S-Prim-MakeTupleh
|
|
Binary file
|
|
Binary file
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
0.1.1 MindSpore*2.0.0:�
|
|
3
|
-
k"get_bprop_trans_shape.1:[CNode]2:1"get_bprop_trans_shape.1:[CNode]2:1"REF::bprop.3:Default/bprop.3-op0
|
|
4
|
-
�get_bprop_trans_shape.1:op:2get_bprop_trans_shape.1:op:2"=REF::ClassType::mindspore.ops.operations.array_ops.TransShape:ADefault/class 'mindspore.ops.operations.array_ops.TransShape'-op1get_bprop_trans_shape.1*
|
|
5
|
-
get_bprop_trans_shape.1:self*
|
|
6
|
-
get_bprop_trans_shape.1:x*
|
|
7
|
-
get_bprop_trans_shape.1:shape*
|
|
8
|
-
get_bprop_trans_shape.1:out*
|
|
9
|
-
get_bprop_trans_shape.1:dout2$
|
|
10
|
-
"get_bprop_trans_shape.1:[CNode]2:1:@adaf31d907574c3f63f9202dc6a36f2f70f0e7caf15e7294fa4a4f2427bc8d02J/grad_array_ops.pyB�
|
|
11
|
-
r
|
|
12
|
-
get_bprop_trans_shape.1:xbprop.3:[CNode]4:3bprop.3:[CNode]4:3"REF::S-Prim-Shape:4:Default/S-Prim-Shape-op2
|
|
13
|
-
t
|
|
14
|
-
get_bprop_trans_shape.1:dout
|
|
15
|
-
bprop.3:[CNode]4:3bprop.3:dx:5bprop.3:dx:5"!REF::get_bprop_trans_shape.1:op:2:3
|
|
16
|
-
�
|
|
17
|
-
get_bprop_trans_shape.1:shapebprop.3:[CNode]5:6bprop.3:[CNode]5:6".REF::MetaFuncGraph::hyper_map[zeros_like_leaf]:-Default/S-Prim-hyper_map[zeros_like_leaf]-op4
|
|
18
|
-
�
|
|
19
|
-
bprop.3:dx:5
|
|
20
|
-
bprop.3:[CNode]5:6bprop.3:[CNode]6:7bprop.3:[CNode]6:7"REF::S-Prim-MakeTuple:8:Default/S-Prim-MakeTuple-op5bprop.32
|
|
21
|
-
bprop.3:[CNode]6:7Pb
|
|
22
|
-
S-Prim-Shape:4S-Prim-Shapeb&
|
|
23
|
-
S-Prim-MakeTuple:8S-Prim-MakeTupleh
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
0.1.1 MindSpore*2.0.0:�
|
|
3
|
-
�)get_bprop_truncate_div.1125:[CNode]1126:1)get_bprop_truncate_div.1125:[CNode]1126:1"REF::bprop.1127:Default/bprop.1127-op886get_bprop_truncate_div.1125*"
|
|
4
|
-
get_bprop_truncate_div.1125:self*
|
|
5
|
-
get_bprop_truncate_div.1125:x*
|
|
6
|
-
get_bprop_truncate_div.1125:y*!
|
|
7
|
-
get_bprop_truncate_div.1125:out*"
|
|
8
|
-
get_bprop_truncate_div.1125:dout2+
|
|
9
|
-
)get_bprop_truncate_div.1125:[CNode]1126:1:@a8f96e783e49fe455f7fee2dbda70043761c9bb3cbcd1c9ad3cd37eecd1f80e5J/grad_math_ops.pyB�
|
|
10
|
-
�
|
|
11
|
-
get_bprop_truncate_div.1125:xbprop.1127:[CNode]1128:2bprop.1127:[CNode]1128:2".REF::MetaFuncGraph::hyper_map[zeros_like_leaf]:/Default/S-Prim-hyper_map[zeros_like_leaf]-op887
|
|
12
|
-
�
|
|
13
|
-
get_bprop_truncate_div.1125:ybprop.1127:[CNode]1129:3bprop.1127:[CNode]1129:3".REF::MetaFuncGraph::hyper_map[zeros_like_leaf]:/Default/S-Prim-hyper_map[zeros_like_leaf]-op888
|
|
14
|
-
�
|
|
15
|
-
bprop.1127:[CNode]1128:2
|
|
16
|
-
bprop.1127:[CNode]1129:3bprop.1127:[CNode]1130:4bprop.1127:[CNode]1130:4"REF::S-Prim-MakeTuple:5:Default/S-Prim-MakeTuple-op889
|
|
17
|
-
bprop.11272
|
|
18
|
-
bprop.1127:[CNode]1130:4Pb&
|
|
19
|
-
S-Prim-MakeTuple:5S-Prim-MakeTupleh
|
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
0.1.1 MindSpore*2.0.0:�
|
|
3
|
-
�
|
|
4
|
-
bprop_tuple_getitem.1:data bprop_tuple_getitem.1:[CNode]2:1 bprop_tuple_getitem.1:[CNode]2:1".REF::MetaFuncGraph::hyper_map[zeros_like_leaf]:-Default/S-Prim-hyper_map[zeros_like_leaf]-op0
|
|
5
|
-
�
|
|
6
|
-
bprop_tuple_getitem.1:[CNode]2:1
|
|
7
|
-
bprop_tuple_getitem.1:idx
|
|
8
|
-
bprop_tuple_getitem.1:dout bprop_tuple_getitem.1:[CNode]3:2 bprop_tuple_getitem.1:[CNode]3:2"REF::S-Prim-tuple_setitem:3: Default/S-Prim-tuple_setitem-op1
|
|
9
|
-
�
|
|
10
|
-
bprop_tuple_getitem.1:idx bprop_tuple_getitem.1:[CNode]4:4 bprop_tuple_getitem.1:[CNode]4:4".REF::MetaFuncGraph::hyper_map[zeros_like_leaf]:-Default/S-Prim-hyper_map[zeros_like_leaf]-op2
|
|
11
|
-
�
|
|
12
|
-
bprop_tuple_getitem.1:[CNode]3:2
|
|
13
|
-
bprop_tuple_getitem.1:[CNode]4:4 bprop_tuple_getitem.1:[CNode]5:5 bprop_tuple_getitem.1:[CNode]5:5"REF::S-Prim-MakeTuple:6:Default/S-Prim-MakeTuple-op3bprop_tuple_getitem.1*
|
|
14
|
-
bprop_tuple_getitem.1:data*
|
|
15
|
-
bprop_tuple_getitem.1:idx*
|
|
16
|
-
bprop_tuple_getitem.1:out*
|
|
17
|
-
bprop_tuple_getitem.1:dout2"
|
|
18
|
-
bprop_tuple_getitem.1:[CNode]5:5:@badb8d2f379272a9bfe28f5e50b98c3de21620b357eb5d206a8abc1d48964179J/grad_implementations.pyPb.
|
|
19
|
-
S-Prim-tuple_setitem:3S-Prim-tuple_setitemb&
|
|
20
|
-
S-Prim-MakeTuple:6S-Prim-MakeTupleh
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
0.1.1 MindSpore*2.0.0:�
|
|
3
|
-
aget_bprop_unique.1:[CNode]2:1get_bprop_unique.1:[CNode]2:1"REF::bprop.3:Default/bprop.3-op0
|
|
4
|
-
�get_bprop_unique.1:op:2get_bprop_unique.1:op:2"=REF::ClassType::mindspore.ops.operations._grad_ops.UniqueGrad:ADefault/class 'mindspore.ops.operations._grad_ops.UniqueGrad'-op1get_bprop_unique.1*
|
|
5
|
-
get_bprop_unique.1:self*
|
|
6
|
-
get_bprop_unique.1:x*
|
|
7
|
-
get_bprop_unique.1:out*
|
|
8
|
-
get_bprop_unique.1:dout2
|
|
9
|
-
get_bprop_unique.1:[CNode]2:1:@250b2c34ad30cb5948758d14a57231a58534cf4e271d6445ab7a48ae067de84dJ/grad_array_ops.pyB�
|
|
10
|
-
n
|
|
11
|
-
get_bprop_unique.1:dout
|
|
12
|
-
get_bprop_unique.1:outbprop.3:dx:3bprop.3:dx:3"REF::get_bprop_unique.1:op:2:2
|
|
13
|
-
m
|
|
14
|
-
bprop.3:dx:3bprop.3:[CNode]4:4bprop.3:[CNode]4:4"REF::S-Prim-MakeTuple:5:Default/S-Prim-MakeTuple-op3bprop.32
|
|
15
|
-
bprop.3:[CNode]4:4Pb&
|
|
16
|
-
S-Prim-MakeTuple:5S-Prim-MakeTupleh
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
0.1.1 MindSpore*2.0.0:�
|
|
3
|
-
q"get_bprop_unstack.924:[CNode]925:1"get_bprop_unstack.924:[CNode]925:1"REF::bprop.926:Default/bprop.926-op749
|
|
4
|
-
<[ValueNode]927[ValueNode]927"Constant*
|
|
5
|
-
value*axis�
|
|
6
|
-
�
|
|
7
|
-
get_bprop_unstack.924:self
|
|
8
|
-
[ValueNode]927get_bprop_unstack.924:axis:2get_bprop_unstack.924:axis:2"REF::getattr:3:Default/getattr-op750get_bprop_unstack.924*
|
|
9
|
-
get_bprop_unstack.924:self*
|
|
10
|
-
get_bprop_unstack.924:x*
|
|
11
|
-
get_bprop_unstack.924:out*
|
|
12
|
-
get_bprop_unstack.924:dout2$
|
|
13
|
-
"get_bprop_unstack.924:[CNode]925:1:@c4c274247cc015c77285a377298c8228ea58370ed44389f89a8ac0e06f9aec24J/grad_array_ops.pyB�
|
|
14
|
-
�
|
|
15
|
-
get_bprop_unstack.924:axis:2bprop.926:unstack_grad:4bprop.926:unstack_grad:4"8REF::ClassType::mindspore.ops.operations.array_ops.Stack:>Default/class 'mindspore.ops.operations.array_ops.Stack'-op751
|
|
16
|
-
b
|
|
17
|
-
get_bprop_unstack.924:doutbprop.926:out:5bprop.926:out:5"REF::bprop.926:unstack_grad:4:752
|
|
18
|
-
z
|
|
19
|
-
bprop.926:out:5bprop.926:[CNode]928:6bprop.926:[CNode]928:6"REF::S-Prim-MakeTuple:7:Default/S-Prim-MakeTuple-op753 bprop.9262
|
|
20
|
-
bprop.926:[CNode]928:6Pb
|
|
21
|
-
getattr:3getattrb&
|
|
22
|
-
S-Prim-MakeTuple:7S-Prim-MakeTupleh
|
|
@@ -1,32 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
0.1.1 MindSpore*2.0.0:�
|
|
3
|
-
�0get_bprop_upsample_nearest_3d_grad.2:[CNode]13:10get_bprop_upsample_nearest_3d_grad.2:[CNode]13:1"REF::bprop.4:Default/bprop.4-op0
|
|
4
|
-
�0get_bprop_upsample_nearest_3d_grad.2:get_shape:20get_bprop_upsample_nearest_3d_grad.2:get_shape:2"8REF::ClassType::mindspore.ops.operations.array_ops.Shape:LDefault/MindIRClassType:class 'mindspore.ops.operations.array_ops.Shape'-op1
|
|
5
|
-
A
|
|
6
|
-
value*output_size�
|
|
7
|
-
�
|
|
8
|
-
)get_bprop_upsample_nearest_3d_grad.2:self
|
|
9
|
-
|
|
10
|
-
<
|
|
11
|
-
value*scales�
|
|
12
|
-
�
|
|
13
|
-
)get_bprop_upsample_nearest_3d_grad.2:self
|
|
14
|
-
|
|
15
|
-
)get_bprop_upsample_nearest_3d_grad.2:self*.
|
|
16
|
-
,get_bprop_upsample_nearest_3d_grad.2:input_x**
|
|
17
|
-
(get_bprop_upsample_nearest_3d_grad.2:out*+
|
|
18
|
-
)get_bprop_upsample_nearest_3d_grad.2:dout22
|
|
19
|
-
0get_bprop_upsample_nearest_3d_grad.2:[CNode]13:1:@89f303661abc4ca7469d2cbbfdc77c210c2a3053877fbd2b8ab19c9b86f6f56aJ/grad_nn_ops.pyB�
|
|
20
|
-
�
|
|
21
|
-
,get_bprop_upsample_nearest_3d_grad.2:input_xbprop.4:[CNode]1:3bprop.4:[CNode]1:3"5REF::get_bprop_upsample_nearest_3d_grad.2:get_shape:2:2
|
|
22
|
-
�
|
|
23
|
-
bprop.4:[CNode]1:3
|
|
24
|
-
2get_bprop_upsample_nearest_3d_grad.2:output_size:4
|
|
25
|
-
-get_bprop_upsample_nearest_3d_grad.2:scales:6bprop.4:input_grad:7bprop.4:input_grad:7"HREF::ClassType::mindspore.ops.operations._grad_ops.UpsampleNearest3DGrad:\Default/MindIRClassType:class 'mindspore.ops.operations._grad_ops.UpsampleNearest3DGrad'-op5
|
|
26
|
-
e
|
|
27
|
-
)get_bprop_upsample_nearest_3d_grad.2:doutbprop.4:dx:8bprop.4:dx:8"REF::bprop.4:input_grad:7:6
|
|
28
|
-
n
|
|
29
|
-
bprop.4:dx:8bprop.4:[CNode]3:9bprop.4:[CNode]3:9"REF::S-Prim-MakeTuple:10:Default/S-Prim-MakeTuple-op7bprop.42
|
|
30
|
-
bprop.4:[CNode]3:9Pb
|
|
31
|
-
getattr:5getattrb'
|
|
32
|
-
S-Prim-MakeTuple:10S-Prim-MakeTupleh
|
|
@@ -1,38 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
0.1.1 MindSpore*2.0.0:�
|
|
3
|
-
�2get_bprop_upsample_trilinear_3d_grad.2:[CNode]13:12get_bprop_upsample_trilinear_3d_grad.2:[CNode]13:1"REF::bprop.4:Default/bprop.4-op0
|
|
4
|
-
�2get_bprop_upsample_trilinear_3d_grad.2:get_shape:22get_bprop_upsample_trilinear_3d_grad.2:get_shape:2"8REF::ClassType::mindspore.ops.operations.array_ops.Shape:LDefault/MindIRClassType:class 'mindspore.ops.operations.array_ops.Shape'-op1
|
|
5
|
-
A
|
|
6
|
-
value*output_size�
|
|
7
|
-
�
|
|
8
|
-
+get_bprop_upsample_trilinear_3d_grad.2:self
|
|
9
|
-
|
|
10
|
-
<
|
|
11
|
-
value*scales�
|
|
12
|
-
�
|
|
13
|
-
+get_bprop_upsample_trilinear_3d_grad.2:self
|
|
14
|
-
|
|
15
|
-
C
|
|
16
|
-
value*
|
|
17
|
-
�
|
|
18
|
-
+get_bprop_upsample_trilinear_3d_grad.2:self
|
|
19
|
-
|
|
20
|
-
+get_bprop_upsample_trilinear_3d_grad.2:self*0
|
|
21
|
-
.get_bprop_upsample_trilinear_3d_grad.2:input_x*,
|
|
22
|
-
*get_bprop_upsample_trilinear_3d_grad.2:out*-
|
|
23
|
-
+get_bprop_upsample_trilinear_3d_grad.2:dout24
|
|
24
|
-
2get_bprop_upsample_trilinear_3d_grad.2:[CNode]13:1:@de557b6ab60e23e396148159c8aa5c5a3a0a77cf25b1b19f25b6e067c283d1e4J/grad_nn_ops.pyB�
|
|
25
|
-
�
|
|
26
|
-
.get_bprop_upsample_trilinear_3d_grad.2:input_xbprop.4:[CNode]1:3bprop.4:[CNode]1:3"7REF::get_bprop_upsample_trilinear_3d_grad.2:get_shape:2:2
|
|
27
|
-
�
|
|
28
|
-
bprop.4:[CNode]1:3
|
|
29
|
-
4get_bprop_upsample_trilinear_3d_grad.2:output_size:4
|
|
30
|
-
/get_bprop_upsample_trilinear_3d_grad.2:scales:6
|
|
31
|
-
6get_bprop_upsample_trilinear_3d_grad.2:align_corners:7bprop.4:input_grad:8bprop.4:input_grad:8"JREF::ClassType::mindspore.ops.operations._grad_ops.UpsampleTrilinear3DGrad:^Default/MindIRClassType:class 'mindspore.ops.operations._grad_ops.UpsampleTrilinear3DGrad'-op6
|
|
32
|
-
g
|
|
33
|
-
+get_bprop_upsample_trilinear_3d_grad.2:doutbprop.4:dx:9bprop.4:dx:9"REF::bprop.4:input_grad:8:7
|
|
34
|
-
p
|
|
35
|
-
bprop.4:dx:9bprop.4:[CNode]3:10bprop.4:[CNode]3:10"REF::S-Prim-MakeTuple:11:Default/S-Prim-MakeTuple-op8bprop.42
|
|
36
|
-
bprop.4:[CNode]3:10Pb
|
|
37
|
-
getattr:5getattrb'
|
|
38
|
-
S-Prim-MakeTuple:11S-Prim-MakeTupleh
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
0.1.1 MindSpore*2.0.0:�
|
|
3
|
-
{&get_bprop_zeroslike.1001:[CNode]1002:1&get_bprop_zeroslike.1001:[CNode]1002:1"REF::bprop.1003:Default/bprop.1003-op802get_bprop_zeroslike.1001*
|
|
4
|
-
get_bprop_zeroslike.1001:self*
|
|
5
|
-
get_bprop_zeroslike.1001:x*
|
|
6
|
-
get_bprop_zeroslike.1001:out*
|
|
7
|
-
get_bprop_zeroslike.1001:dout2(
|
|
8
|
-
&get_bprop_zeroslike.1001:[CNode]1002:1:@019bc2e3d6af94c73e4507b14158fc13a846c43d6f52e4d09d3044897de5461fJ/grad_array_ops.pyB�
|
|
9
|
-
�
|
|
10
|
-
get_bprop_zeroslike.1001:xbprop.1003:[CNode]1004:2bprop.1003:[CNode]1004:2".REF::MetaFuncGraph::hyper_map[zeros_like_leaf]:/Default/S-Prim-hyper_map[zeros_like_leaf]-op803
|
|
11
|
-
�
|
|
12
|
-
bprop.1003:[CNode]1004:2bprop.1003:[CNode]1005:3bprop.1003:[CNode]1005:3"REF::S-Prim-MakeTuple:4:Default/S-Prim-MakeTuple-op804
|
|
13
|
-
bprop.10032
|
|
14
|
-
bprop.1003:[CNode]1005:3Pb&
|
|
15
|
-
S-Prim-MakeTuple:4S-Prim-MakeTupleh
|
|
@@ -1,114 +0,0 @@
|
|
|
1
|
-
# Copyright 2021-2022 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
|
-
"""Generate the mindir for bprop"""
|
|
16
|
-
from __future__ import absolute_import
|
|
17
|
-
import os
|
|
18
|
-
import shutil
|
|
19
|
-
import argparse
|
|
20
|
-
import logging
|
|
21
|
-
|
|
22
|
-
import mindspore.ops._grad as g
|
|
23
|
-
from mindspore._c_expression import _export_bprop_mindir
|
|
24
|
-
from mindspore.ops._grad.grad_base import bprop_getters, bprops
|
|
25
|
-
|
|
26
|
-
logging.getLogger().setLevel(logging.INFO)
|
|
27
|
-
os.environ['MS_DEV_EXPORT_BPROP_MINDIR'] = '1'
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
def run_generate(bprop_mindir_install_dir, bprop_map, force_update):
|
|
31
|
-
"""Run the generate process of bprop mindir."""
|
|
32
|
-
for op_name in bprop_map.keys():
|
|
33
|
-
if not isinstance(op_name, str):
|
|
34
|
-
continue
|
|
35
|
-
if os.path.isfile(os.path.join(bprop_mindir_install_dir, op_name + "_bprop.mindir")):
|
|
36
|
-
_export_bprop_mindir(op_name, force_update)
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
def run_generate_with_op_name(op_name, force_update):
|
|
40
|
-
"""Run the generate process of bprop mindir for single op."""
|
|
41
|
-
_export_bprop_mindir(op_name, force_update)
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
if __name__ == "__main__":
|
|
45
|
-
parser = argparse.ArgumentParser(description="Bprop mindir generator")
|
|
46
|
-
parser.add_argument('--mindspore_path', type=str, default=None,
|
|
47
|
-
help="The absolute path of the mindspore root directory where the bprop source files has been \
|
|
48
|
-
modified. If not specified, it will find the bprop source files in your mindspore installed \
|
|
49
|
-
path. Default: None.")
|
|
50
|
-
parser.add_argument('--op', type=str, default=None,
|
|
51
|
-
help="The name of the operator whose bprop is to be transformed to mindir file. If not \
|
|
52
|
-
specified, it will generate all the mindir files of bprop which has already been transform \
|
|
53
|
-
to mindir. Default: None.")
|
|
54
|
-
parser.add_argument('--force', type=bool, default=False,
|
|
55
|
-
help="Whether to force to generate mindir file of a bprop function regardless of nothing \
|
|
56
|
-
changed. Default: False.")
|
|
57
|
-
|
|
58
|
-
args_opt = parser.parse_args()
|
|
59
|
-
# mindspore/ops/_grad/__init__.py
|
|
60
|
-
BPROP_PATH = g.__file__
|
|
61
|
-
bprop_installed_dir = BPROP_PATH[: BPROP_PATH.rindex('/')]
|
|
62
|
-
bprop_mindir_export_dir = os.path.join(bprop_installed_dir, "..", "bprop_mindir")
|
|
63
|
-
|
|
64
|
-
mindspore_path = args_opt.mindspore_path
|
|
65
|
-
bprop_src_dir = None
|
|
66
|
-
bprop_mindir_src_dir = None
|
|
67
|
-
if mindspore_path is not None:
|
|
68
|
-
mindspore_path = mindspore_path.rstrip('/')
|
|
69
|
-
python_ops_dir = os.path.join(mindspore_path, "mindspore", "python", "mindspore", "ops")
|
|
70
|
-
bprop_src_dir = os.path.join(python_ops_dir, "_grad")
|
|
71
|
-
bprop_mindir_src_dir = os.path.join(python_ops_dir, "bprop_mindir")
|
|
72
|
-
|
|
73
|
-
copy_flag = bprop_src_dir is not None and bprop_src_dir != bprop_installed_dir
|
|
74
|
-
# If the specified bprop source directory is not on the mindspore installed path,
|
|
75
|
-
# copy the bprop source files to the installed path.
|
|
76
|
-
BACKUP_SUFFIX = "_generate_bak"
|
|
77
|
-
if copy_flag:
|
|
78
|
-
shutil.rmtree(bprop_installed_dir + BACKUP_SUFFIX, ignore_errors=True)
|
|
79
|
-
os.rename(bprop_installed_dir, bprop_installed_dir + BACKUP_SUFFIX)
|
|
80
|
-
os.mkdir(bprop_installed_dir)
|
|
81
|
-
ls = os.listdir(bprop_src_dir)
|
|
82
|
-
for line in ls:
|
|
83
|
-
file_path = os.path.join(bprop_src_dir, line)
|
|
84
|
-
if os.path.isfile(file_path):
|
|
85
|
-
shutil.copy(file_path, bprop_installed_dir)
|
|
86
|
-
logging.info("copied: %s", file_path)
|
|
87
|
-
|
|
88
|
-
force = args_opt.force
|
|
89
|
-
op = args_opt.op
|
|
90
|
-
if op is None:
|
|
91
|
-
run_generate(bprop_mindir_export_dir, bprop_getters, force)
|
|
92
|
-
run_generate(bprop_mindir_export_dir, bprops, force)
|
|
93
|
-
else:
|
|
94
|
-
run_generate_with_op_name(op, force)
|
|
95
|
-
|
|
96
|
-
# If the specified bprop source directory is not on the mindspore installed path,
|
|
97
|
-
# copy the generated mindir files to the mindir directory relative to the specified path.
|
|
98
|
-
if copy_flag:
|
|
99
|
-
shutil.rmtree(bprop_installed_dir)
|
|
100
|
-
os.rename(bprop_installed_dir + BACKUP_SUFFIX, bprop_installed_dir)
|
|
101
|
-
ls = os.listdir(bprop_mindir_export_dir)
|
|
102
|
-
for line in ls:
|
|
103
|
-
file_path = os.path.join(bprop_mindir_export_dir, line)
|
|
104
|
-
if file_path.endswith(".mindir") and os.path.isfile(file_path):
|
|
105
|
-
os.chmod(file_path, 0o664)
|
|
106
|
-
shutil.copy(file_path, bprop_mindir_src_dir)
|
|
107
|
-
logging.info("copied: %s", file_path)
|
|
108
|
-
|
|
109
|
-
logging.info("The new bprop mindir files has been generated in the path \"%s\"", bprop_mindir_src_dir)
|
|
110
|
-
else:
|
|
111
|
-
logging.info("The new bprop mindir files has been generated in the path \"%s\", "
|
|
112
|
-
"copy the *.mindir to your mindspore path or PYTHONPATH if necessary.", bprop_mindir_export_dir)
|
|
113
|
-
|
|
114
|
-
del os.environ['MS_DEV_EXPORT_BPROP_MINDIR']
|
|
@@ -1,44 +0,0 @@
|
|
|
1
|
-
# Copyright 2022 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
|
-
"""Visit nods of SymbolTree."""
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
class NodeVisitor:
|
|
19
|
-
"""Iterator class to access SymbolTree nodes"""
|
|
20
|
-
def __init__(self, stree):
|
|
21
|
-
self._stree = stree
|
|
22
|
-
self._nodes = []
|
|
23
|
-
self._index = 0
|
|
24
|
-
|
|
25
|
-
def __iter__(self):
|
|
26
|
-
self._nodes = list(self._stree.get_nodes_dict().values())
|
|
27
|
-
self._index = 0
|
|
28
|
-
return self
|
|
29
|
-
|
|
30
|
-
def __next__(self):
|
|
31
|
-
if self._index < len(self._nodes):
|
|
32
|
-
node = self._nodes[self._index]
|
|
33
|
-
self._index += 1
|
|
34
|
-
return node
|
|
35
|
-
|
|
36
|
-
raise StopIteration
|
|
37
|
-
|
|
38
|
-
def append_node(self, node):
|
|
39
|
-
"""append new node to iterator"""
|
|
40
|
-
self._nodes.append(node)
|
|
41
|
-
|
|
42
|
-
def remove_node(self, node):
|
|
43
|
-
"""remove node of iterator"""
|
|
44
|
-
self._nodes.remove(node)
|
|
@@ -1,203 +0,0 @@
|
|
|
1
|
-
# Copyright 2022 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
|
-
"""SymbolTree topological-relationship manager."""
|
|
16
|
-
from typing import Tuple
|
|
17
|
-
|
|
18
|
-
from .api.scoped_value import ScopedValue
|
|
19
|
-
from .node import Node
|
|
20
|
-
from .common.observable import Observable
|
|
21
|
-
from .common.event import Event
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
class TopoManager(Observable):
|
|
25
|
-
"""SymbolTree topological-relationship manager."""
|
|
26
|
-
|
|
27
|
-
def __init__(self):
|
|
28
|
-
"""
|
|
29
|
-
Constructor of TopoManager.
|
|
30
|
-
Init provider and consumer.
|
|
31
|
-
Key of dict is an instance of ScopedValue.
|
|
32
|
-
Value of dict is a tuple whose first is an instance of Node, whose second is an index.
|
|
33
|
-
It means node's index th arg is argument
|
|
34
|
-
"""
|
|
35
|
-
super().__init__()
|
|
36
|
-
self._target_provider: {ScopedValue, (Node, int)} = {}
|
|
37
|
-
self._target_consumer: {ScopedValue, [(Node, int)]} = {}
|
|
38
|
-
|
|
39
|
-
def get_node_users(self, node: Node) -> [Tuple[Node, int]]:
|
|
40
|
-
"""
|
|
41
|
-
Get all nodes which depend on node corresponding to node_or_name.
|
|
42
|
-
|
|
43
|
-
Args:
|
|
44
|
-
node (Node): An instance of node.
|
|
45
|
-
|
|
46
|
-
Returns:
|
|
47
|
-
A list of nodes represents node users.
|
|
48
|
-
"""
|
|
49
|
-
targets = node.get_targets()
|
|
50
|
-
results = []
|
|
51
|
-
for target in targets:
|
|
52
|
-
consumers = self._target_consumer.get(target)
|
|
53
|
-
if consumers is None:
|
|
54
|
-
continue
|
|
55
|
-
results.extend(consumers)
|
|
56
|
-
unique_results = []
|
|
57
|
-
for result in results:
|
|
58
|
-
if result not in unique_results:
|
|
59
|
-
unique_results.append(result)
|
|
60
|
-
return unique_results
|
|
61
|
-
|
|
62
|
-
def topo_changed(self):
|
|
63
|
-
"""
|
|
64
|
-
The function is executed when an Event.TopologicalChangeEvent event is received.
|
|
65
|
-
"""
|
|
66
|
-
self.changed(Event.TopologicalChangeEvent)
|
|
67
|
-
|
|
68
|
-
def _add_consumer(self, product: ScopedValue, consumer: Node, index):
|
|
69
|
-
"""
|
|
70
|
-
Add a consumer to consumer dict.
|
|
71
|
-
|
|
72
|
-
Args:
|
|
73
|
-
product (ScopedValue): An instance of ScopedValue represents product to be consumed.
|
|
74
|
-
consumer (Node): An instance of Node represents consumer.
|
|
75
|
-
index (int): A int represents which input of consumer is the product.
|
|
76
|
-
"""
|
|
77
|
-
consumers = self._target_consumer.get(product)
|
|
78
|
-
if consumers is None:
|
|
79
|
-
self._target_consumer[product] = [(consumer, index)]
|
|
80
|
-
else:
|
|
81
|
-
self._target_consumer.get(product).append((consumer, index))
|
|
82
|
-
|
|
83
|
-
def _erase_provider(self, product: ScopedValue):
|
|
84
|
-
"""
|
|
85
|
-
Erase a provider from provider dict.
|
|
86
|
-
|
|
87
|
-
Args:
|
|
88
|
-
product (ScopedValue): An instance of ScopedValue represents product to be erased.
|
|
89
|
-
"""
|
|
90
|
-
if self._target_provider.get(product) is not None:
|
|
91
|
-
self._target_provider.pop(product)
|
|
92
|
-
|
|
93
|
-
def _erase_consumer(self, product: ScopedValue, consumer: Node):
|
|
94
|
-
"""
|
|
95
|
-
Erase a consumer from consumer dict.
|
|
96
|
-
|
|
97
|
-
Args:
|
|
98
|
-
product (ScopedValue): An instance of ScopedValue represents product whose consumer would be erased.
|
|
99
|
-
consumer (Node): An instance of Node which would be erased as a consumer.
|
|
100
|
-
"""
|
|
101
|
-
consumers = self._target_consumer.get(product)
|
|
102
|
-
if consumers is None:
|
|
103
|
-
return
|
|
104
|
-
for i in range(len(consumers) - 1, -1, -1):
|
|
105
|
-
exist_ele = consumers[i]
|
|
106
|
-
if id(exist_ele[0]) == id(consumer):
|
|
107
|
-
consumers.pop(i)
|
|
108
|
-
|
|
109
|
-
def _update_node_inputs(self, node: Node) -> [Node]:
|
|
110
|
-
"""
|
|
111
|
-
Update inputs of node by current provider dict and consumer dict.
|
|
112
|
-
|
|
113
|
-
Args:
|
|
114
|
-
node (Node): An instance of Node whose inputs will be updated.
|
|
115
|
-
|
|
116
|
-
Returns:
|
|
117
|
-
A list of instance of nodes represents inputs of node.
|
|
118
|
-
"""
|
|
119
|
-
if node.get_normalized_args() is None:
|
|
120
|
-
node.set_inputs([])
|
|
121
|
-
return []
|
|
122
|
-
inputs = []
|
|
123
|
-
for arg in node.get_normalized_args().values():
|
|
124
|
-
provider = self._target_provider.get(arg)
|
|
125
|
-
# some arg of some node may be self.xxx which is not an output of another node
|
|
126
|
-
if provider is not None:
|
|
127
|
-
inputs.append(provider[0])
|
|
128
|
-
node.set_inputs(inputs)
|
|
129
|
-
return inputs
|
|
130
|
-
|
|
131
|
-
def on_insert_node(self, node: Node):
|
|
132
|
-
"""
|
|
133
|
-
Update provider dict and consumer dict while inserting node into SymbolTree and update inputs of node by updated
|
|
134
|
-
provider dict and consumer dict.
|
|
135
|
-
|
|
136
|
-
Args:
|
|
137
|
-
node (Node): An instance of Node which been inserted into SymbolTree.
|
|
138
|
-
"""
|
|
139
|
-
if node.get_targets() is not None:
|
|
140
|
-
for i in range(0, len(node.get_targets())):
|
|
141
|
-
target = node.get_targets()[i]
|
|
142
|
-
if target.value == "_":
|
|
143
|
-
continue
|
|
144
|
-
if self._target_provider.get(target) is not None:
|
|
145
|
-
raise RuntimeError("target duplicated:", target)
|
|
146
|
-
self._target_provider[target] = (node, i)
|
|
147
|
-
if node.get_normalized_args() is not None:
|
|
148
|
-
for index, arg in enumerate(node.get_normalized_args().values()):
|
|
149
|
-
self._add_consumer(arg, node, index)
|
|
150
|
-
self._update_node_inputs(node)
|
|
151
|
-
self.topo_changed()
|
|
152
|
-
|
|
153
|
-
def on_erase_node(self, node: Node):
|
|
154
|
-
"""
|
|
155
|
-
Update provider dict and consumer dict while erasing node from SymbolTree.
|
|
156
|
-
|
|
157
|
-
Args:
|
|
158
|
-
node (Node): An instance of Node which been erased from SymbolTree.
|
|
159
|
-
"""
|
|
160
|
-
if node.get_targets() is not None:
|
|
161
|
-
for target in node.get_targets():
|
|
162
|
-
consumers = self._target_consumer.get(target)
|
|
163
|
-
if consumers is not None and consumers:
|
|
164
|
-
raise RuntimeError("Only support erase isolated node: ", node.get_name(), target)
|
|
165
|
-
self._erase_provider(target)
|
|
166
|
-
if node.get_normalized_args() is not None:
|
|
167
|
-
for arg in node.get_normalized_args().values():
|
|
168
|
-
self._erase_consumer(arg, node)
|
|
169
|
-
# clear inputs of node rather than call _update_node_inputs because node is already erase from consumer dict
|
|
170
|
-
node.set_inputs([])
|
|
171
|
-
self.topo_changed()
|
|
172
|
-
|
|
173
|
-
def on_update_arg(self, node: Node, arg_idx: int, old_arg: ScopedValue, new_arg: ScopedValue):
|
|
174
|
-
"""
|
|
175
|
-
Update provider dict and consumer dict while updating argument of node and update inputs of node by updated
|
|
176
|
-
provider dict and consumer dict.
|
|
177
|
-
|
|
178
|
-
Args:
|
|
179
|
-
node (Node): An instance of Node whose arguments being updated.
|
|
180
|
-
arg_idx (int): An int indicates which argument of node being updated.
|
|
181
|
-
old_arg (ScopedValue): An instance of ScopedValue represents original argument.
|
|
182
|
-
new_arg (ScopedValue): An instance of ScopedValue represents new argument.
|
|
183
|
-
"""
|
|
184
|
-
self._erase_consumer(old_arg, node)
|
|
185
|
-
self._add_consumer(new_arg, node, arg_idx)
|
|
186
|
-
self._update_node_inputs(node)
|
|
187
|
-
self.topo_changed()
|
|
188
|
-
|
|
189
|
-
def dump(self, title=""):
|
|
190
|
-
"""
|
|
191
|
-
Dump topological relation.
|
|
192
|
-
|
|
193
|
-
Args:
|
|
194
|
-
title (str): A string as a title will be printed before dumping topological relation.
|
|
195
|
-
"""
|
|
196
|
-
print(f"{title}------------------------------------------------------------------------------------")
|
|
197
|
-
for k, v in self._target_provider.items():
|
|
198
|
-
print(f"{v[0].get_name()} produces {k.value}")
|
|
199
|
-
for k, v in self._target_consumer.items():
|
|
200
|
-
print(f"{k.value} is consumed by: ")
|
|
201
|
-
for ele in v:
|
|
202
|
-
print(ele[0].get_name())
|
|
203
|
-
print(f"-----------------------------------------------------------------------------------------")
|