mindspore 2.0.0a0__cp38-cp38-win_amd64.whl → 2.0.0rc1__cp38-cp38-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/__init__.py +4 -2
- mindspore/_c_dataengine.cp38-win_amd64.pyd +0 -0
- mindspore/_c_expression.cp38-win_amd64.pyd +0 -0
- mindspore/_c_mindrecord.cp38-win_amd64.pyd +0 -0
- mindspore/_check_jit_forbidden_api.py +102 -0
- mindspore/_checkparam.py +1066 -1001
- mindspore/_extends/parallel_compile/akg_compiler/akg_process.py +4 -3
- mindspore/_extends/parallel_compile/akg_compiler/tbe_topi.py +50 -48
- mindspore/_extends/parallel_compile/akg_compiler/util.py +9 -4
- mindspore/_extends/parallel_compile/tbe_compiler/tbe_adapter.py +4 -4
- mindspore/_extends/parallel_compile/tbe_compiler/tbe_helper.py +9 -4
- mindspore/_extends/parse/__init__.py +5 -3
- mindspore/_extends/parse/namespace.py +16 -1
- mindspore/_extends/parse/parser.py +107 -22
- mindspore/_extends/parse/resources.py +0 -7
- mindspore/_extends/parse/standard_method.py +885 -413
- mindspore/amp.py +52 -57
- mindspore/boost/boost.py +2 -2
- mindspore/boost/boost_cell_wrapper.py +38 -20
- mindspore/boost/dim_reduce.py +3 -3
- mindspore/boost/group_loss_scale_manager.py +1 -1
- mindspore/common/__init__.py +4 -6
- mindspore/common/_decorator.py +2 -0
- mindspore/common/_register_for_adapter.py +55 -0
- mindspore/common/_stub_tensor.py +201 -0
- mindspore/common/_utils.py +41 -7
- mindspore/common/api.py +215 -141
- mindspore/common/dtype.py +8 -1
- mindspore/common/dump.py +2 -2
- mindspore/common/initializer.py +4 -2
- mindspore/common/jit_config.py +17 -13
- mindspore/common/mutable.py +33 -13
- mindspore/common/parameter.py +23 -21
- mindspore/common/seed.py +8 -24
- mindspore/common/sparse_tensor.py +62 -41
- mindspore/common/tensor.py +852 -1154
- mindspore/communication/__init__.py +2 -2
- mindspore/communication/_comm_helper.py +11 -4
- mindspore/communication/management.py +22 -21
- mindspore/config/op_info.config +501 -1008
- mindspore/context.py +201 -23
- mindspore/dataset/__init__.py +6 -6
- mindspore/dataset/audio/__init__.py +7 -7
- mindspore/dataset/audio/transforms.py +670 -30
- mindspore/dataset/audio/utils.py +47 -4
- mindspore/dataset/audio/validators.py +223 -1
- mindspore/dataset/callback/ds_callback.py +2 -2
- mindspore/dataset/core/config.py +210 -14
- mindspore/dataset/core/validator_helpers.py +2 -2
- mindspore/{parallel/nn/layers.py → dataset/debug/__init__.py} +7 -8
- mindspore/dataset/debug/debug_hook.py +65 -0
- mindspore/dataset/debug/pre_defined_hook.py +67 -0
- mindspore/dataset/engine/__init__.py +7 -3
- mindspore/dataset/engine/cache_client.py +1 -1
- mindspore/dataset/engine/datasets.py +322 -66
- mindspore/dataset/engine/datasets_audio.py +80 -76
- mindspore/dataset/engine/datasets_standard_format.py +51 -38
- mindspore/dataset/engine/datasets_text.py +232 -118
- mindspore/dataset/engine/datasets_user_defined.py +41 -17
- mindspore/dataset/engine/datasets_vision.py +746 -225
- mindspore/dataset/engine/graphdata.py +75 -10
- mindspore/dataset/engine/iterators.py +45 -5
- mindspore/dataset/engine/offload.py +48 -28
- mindspore/dataset/engine/validators.py +117 -8
- mindspore/dataset/text/__init__.py +6 -5
- mindspore/dataset/text/transforms.py +86 -3
- mindspore/dataset/text/utils.py +6 -4
- mindspore/dataset/text/validators.py +25 -0
- mindspore/dataset/transforms/__init__.py +3 -2
- mindspore/dataset/transforms/c_transforms.py +1 -1
- mindspore/dataset/transforms/transforms.py +2 -2
- mindspore/dataset/utils/__init__.py +2 -1
- mindspore/dataset/utils/line_reader.py +121 -0
- mindspore/dataset/vision/__init__.py +2 -3
- mindspore/dataset/vision/c_transforms.py +9 -9
- mindspore/dataset/vision/py_transforms.py +5 -5
- mindspore/dataset/vision/py_transforms_util.py +2 -0
- mindspore/dataset/vision/transforms.py +160 -161
- mindspore/dataset/vision/utils.py +3 -3
- mindspore/experimental/map_parameter.py +38 -26
- mindspore/include/OWNERS +0 -1
- mindspore/include/api/callback/callback.h +9 -13
- mindspore/include/api/callback/ckpt_saver.h +2 -2
- mindspore/include/api/callback/loss_monitor.h +2 -2
- mindspore/include/api/callback/lr_scheduler.h +5 -5
- mindspore/include/api/callback/time_monitor.h +2 -2
- mindspore/include/api/callback/train_accuracy.h +4 -6
- mindspore/include/api/cfg.h +19 -6
- mindspore/include/api/context.h +44 -9
- mindspore/include/api/delegate.h +1 -1
- mindspore/include/api/metrics/accuracy.h +2 -2
- mindspore/include/api/metrics/metrics.h +4 -3
- mindspore/include/api/model.h +9 -4
- mindspore/include/api/model_parallel_runner.h +2 -2
- mindspore/include/api/net.h +12 -11
- mindspore/include/api/serialization.h +19 -3
- mindspore/include/api/types.h +3 -3
- mindspore/include/dataset/constants.h +7 -0
- mindspore/include/dataset/text.h +59 -0
- mindspore/jpeg62.dll +0 -0
- mindspore/log.py +1 -1
- mindspore/mindrecord/filereader.py +18 -0
- mindspore/mindrecord/filewriter.py +197 -34
- mindspore/mindrecord/shardreader.py +9 -0
- mindspore/mindrecord/shardwriter.py +1 -1
- mindspore/mindrecord/tools/cifar100_to_mr.py +3 -3
- mindspore/mindrecord/tools/cifar10_to_mr.py +3 -3
- mindspore/mindrecord/tools/csv_to_mr.py +3 -3
- mindspore/mindrecord/tools/imagenet_to_mr.py +16 -11
- mindspore/mindrecord/tools/mnist_to_mr.py +2 -2
- mindspore/mindrecord/tools/tfrecord_to_mr.py +6 -6
- mindspore/mindspore_backend.dll +0 -0
- mindspore/mindspore_common.dll +0 -0
- mindspore/mindspore_core.dll +0 -0
- mindspore/mindspore_glog.dll +0 -0
- mindspore/mindspore_shared_lib.dll +0 -0
- mindspore/nn/__init__.py +0 -4
- mindspore/nn/cell.py +204 -132
- mindspore/nn/dynamic_lr.py +1 -1
- mindspore/nn/grad/cell_grad.py +7 -6
- mindspore/nn/layer/__init__.py +5 -4
- mindspore/nn/layer/activation.py +40 -89
- mindspore/nn/layer/basic.py +255 -624
- mindspore/nn/layer/channel_shuffle.py +7 -6
- mindspore/nn/layer/combined.py +1 -1
- mindspore/nn/layer/container.py +41 -4
- mindspore/nn/layer/conv.py +64 -28
- mindspore/nn/layer/dense.py +9 -8
- mindspore/nn/layer/embedding.py +27 -25
- mindspore/nn/layer/image.py +53 -46
- mindspore/nn/layer/math.py +97 -105
- mindspore/nn/layer/normalization.py +117 -86
- mindspore/nn/layer/padding.py +185 -95
- mindspore/nn/layer/pooling.py +817 -414
- mindspore/nn/layer/rnn_cells.py +10 -15
- mindspore/nn/layer/rnns.py +37 -38
- mindspore/nn/layer/thor_layer.py +11 -12
- mindspore/nn/layer/timedistributed.py +5 -5
- mindspore/nn/layer/transformer.py +701 -0
- mindspore/nn/learning_rate_schedule.py +8 -8
- mindspore/nn/loss/__init__.py +5 -4
- mindspore/nn/loss/loss.py +334 -199
- mindspore/nn/optim/ada_grad.py +6 -6
- mindspore/nn/optim/adadelta.py +2 -3
- mindspore/nn/optim/adafactor.py +4 -5
- mindspore/nn/optim/adam.py +126 -62
- mindspore/nn/optim/adamax.py +3 -4
- mindspore/nn/optim/adasum.py +6 -6
- mindspore/nn/optim/asgd.py +2 -2
- mindspore/nn/optim/ftrl.py +67 -38
- mindspore/nn/optim/lamb.py +4 -5
- mindspore/nn/optim/lars.py +2 -2
- mindspore/nn/optim/lazyadam.py +43 -4
- mindspore/nn/optim/momentum.py +6 -5
- mindspore/nn/optim/optimizer.py +3 -1
- mindspore/nn/optim/proximal_ada_grad.py +2 -2
- mindspore/nn/optim/rmsprop.py +1 -1
- mindspore/nn/optim/rprop.py +8 -9
- mindspore/nn/optim/sgd.py +19 -13
- mindspore/nn/optim/thor.py +10 -15
- mindspore/nn/probability/__init__.py +0 -2
- mindspore/nn/probability/bijector/bijector.py +4 -4
- mindspore/nn/probability/bijector/invert.py +1 -1
- mindspore/nn/probability/bijector/softplus.py +2 -2
- mindspore/nn/probability/bnn_layers/dense_variational.py +1 -1
- mindspore/nn/probability/bnn_layers/layer_distribution.py +2 -2
- mindspore/nn/probability/distribution/_utils/utils.py +9 -15
- mindspore/nn/probability/distribution/bernoulli.py +3 -3
- mindspore/nn/probability/distribution/beta.py +1 -1
- mindspore/nn/probability/distribution/categorical.py +5 -7
- mindspore/nn/probability/distribution/cauchy.py +3 -3
- mindspore/nn/probability/distribution/distribution.py +2 -2
- mindspore/nn/probability/distribution/exponential.py +2 -2
- mindspore/nn/probability/distribution/gamma.py +3 -3
- mindspore/nn/probability/distribution/geometric.py +1 -1
- mindspore/nn/probability/distribution/gumbel.py +3 -3
- mindspore/nn/probability/distribution/half_normal.py +15 -11
- mindspore/nn/probability/distribution/laplace.py +16 -13
- mindspore/nn/probability/distribution/logistic.py +2 -2
- mindspore/nn/probability/distribution/normal.py +1 -1
- mindspore/nn/probability/distribution/poisson.py +1 -1
- mindspore/nn/probability/distribution/student_t.py +20 -15
- mindspore/nn/probability/distribution/transformed_distribution.py +4 -4
- mindspore/nn/probability/distribution/uniform.py +2 -2
- mindspore/nn/reinforcement/_tensors_queue.py +3 -3
- mindspore/nn/reinforcement/tensor_array.py +2 -2
- mindspore/nn/sparse/sparse.py +2 -2
- mindspore/nn/wrap/cell_wrapper.py +27 -10
- mindspore/nn/wrap/grad_reducer.py +2 -2
- mindspore/nn/wrap/loss_scale.py +40 -24
- mindspore/numpy/array_creations.py +33 -22
- mindspore/numpy/array_ops.py +35 -30
- mindspore/numpy/logic_ops.py +6 -27
- mindspore/numpy/math_ops.py +22 -19
- mindspore/numpy/utils.py +1 -1
- mindspore/numpy/utils_const.py +108 -58
- mindspore/opencv_core452.dll +0 -0
- mindspore/opencv_imgcodecs452.dll +0 -0
- mindspore/opencv_imgproc452.dll +0 -0
- mindspore/ops/_constants.py +0 -6
- mindspore/ops/_grad/__init__.py +2 -1
- mindspore/ops/_grad/grad_array_ops.py +86 -117
- mindspore/ops/_grad/grad_base.py +23 -1
- mindspore/ops/_grad/grad_clip_ops.py +2 -3
- mindspore/ops/_grad/grad_comm_ops.py +34 -24
- mindspore/ops/_grad/grad_implementations.py +9 -45
- mindspore/ops/_grad/grad_inner_ops.py +47 -4
- mindspore/ops/_grad/grad_math_ops.py +142 -117
- mindspore/ops/_grad/grad_nn_ops.py +71 -165
- mindspore/ops/_grad/grad_sequence_ops.py +296 -0
- mindspore/ops/_grad/grad_sparse.py +7 -6
- mindspore/ops/_grad_experimental/__init__.py +1 -0
- mindspore/ops/_grad_experimental/grad_array_ops.py +150 -15
- mindspore/ops/_grad_experimental/grad_image_ops.py +16 -7
- mindspore/ops/_grad_experimental/grad_inner_ops.py +1 -22
- mindspore/ops/_grad_experimental/grad_linalg_ops.py +4 -11
- mindspore/ops/_grad_experimental/grad_math_ops.py +210 -89
- mindspore/ops/_grad_experimental/grad_nn_ops.py +26 -22
- mindspore/ops/_grad_experimental/grad_scalar_ops.py +112 -0
- mindspore/ops/_grad_experimental/grad_sparse_ops.py +49 -8
- mindspore/ops/_op_impl/_custom_op/batch_matmul_impl.py +1 -1
- mindspore/ops/_op_impl/_custom_op/batchnorm_fold.py +2 -2
- mindspore/ops/_op_impl/_custom_op/batchnorm_fold2.py +2 -2
- mindspore/ops/_op_impl/_custom_op/batchnorm_fold2_grad.py +2 -2
- mindspore/ops/_op_impl/_custom_op/batchnorm_fold2_grad_reduce.py +4 -4
- mindspore/ops/_op_impl/_custom_op/batchnorm_fold_grad.py +3 -3
- mindspore/ops/_op_impl/_custom_op/cholesky_trsm_impl.py +1 -1
- mindspore/ops/_op_impl/_custom_op/correction_mul.py +2 -2
- mindspore/ops/_op_impl/_custom_op/correction_mul_grad.py +2 -2
- mindspore/ops/_op_impl/_custom_op/dsd_back_impl.py +1 -5
- mindspore/ops/_op_impl/_custom_op/dsd_impl.py +1 -1
- mindspore/ops/_op_impl/_custom_op/fake_learned_scale_quant_perchannel.py +2 -2
- mindspore/ops/_op_impl/_custom_op/fake_learned_scale_quant_perchannel_grad.py +2 -2
- mindspore/ops/_op_impl/_custom_op/fake_learned_scale_quant_perchannel_grad_reduce.py +2 -2
- mindspore/ops/_op_impl/_custom_op/fake_learned_scale_quant_perlayer.py +2 -2
- mindspore/ops/_op_impl/_custom_op/fake_learned_scale_quant_perlayer_grad.py +2 -2
- mindspore/ops/_op_impl/_custom_op/fake_learned_scale_quant_perlayer_grad_reduce.py +2 -2
- mindspore/ops/_op_impl/_custom_op/fake_quant_perchannel.py +2 -2
- mindspore/ops/_op_impl/_custom_op/fake_quant_perchannel_grad.py +2 -2
- mindspore/ops/_op_impl/_custom_op/fake_quant_perlayer.py +2 -2
- mindspore/ops/_op_impl/_custom_op/fake_quant_perlayer_grad.py +2 -2
- mindspore/ops/_op_impl/_custom_op/fused_abs_max1_impl.py +1 -1
- mindspore/ops/_op_impl/_custom_op/img2col_impl.py +1 -1
- mindspore/ops/_op_impl/_custom_op/matmul_cube_dense_left_impl.py +2 -2
- mindspore/ops/_op_impl/_custom_op/matmul_cube_dense_right_impl.py +1 -1
- mindspore/ops/_op_impl/_custom_op/matmul_cube_fracz_left_cast_impl.py +1 -1
- mindspore/ops/_op_impl/_custom_op/matmul_cube_fracz_right_mul_impl.py +1 -1
- mindspore/ops/_op_impl/_custom_op/matmul_cube_impl.py +2 -2
- mindspore/ops/_op_impl/_custom_op/matmul_dds_impl.py +0 -4
- mindspore/ops/_op_impl/_custom_op/matrix_combine_impl.py +1 -1
- mindspore/ops/_op_impl/_custom_op/minmax_update_perchannel.py +2 -2
- mindspore/ops/_op_impl/_custom_op/minmax_update_perlayer.py +2 -2
- mindspore/ops/_op_impl/_custom_op/transpose02314_impl.py +1 -1
- mindspore/ops/_op_impl/aicpu/__init__.py +236 -4
- mindspore/ops/_op_impl/aicpu/abs.py +36 -0
- mindspore/ops/_op_impl/aicpu/{adaptive_avg_pool_2d_v1.py → adaptive_avg_pool_2d.py} +6 -5
- mindspore/ops/_op_impl/aicpu/adaptive_avg_pool_2d_grad.py +34 -0
- mindspore/ops/_op_impl/aicpu/add.py +43 -0
- mindspore/ops/_op_impl/aicpu/addcdiv.py +0 -32
- mindspore/ops/_op_impl/aicpu/addcmul.py +0 -84
- mindspore/ops/_op_impl/aicpu/affine_grid_grad.py +35 -0
- mindspore/ops/_op_impl/aicpu/batch_matmul.py +43 -43
- mindspore/ops/_op_impl/aicpu/bernoulli.py +48 -0
- mindspore/{compression/common/__init__.py → ops/_op_impl/aicpu/bessel_i0.py} +15 -8
- mindspore/ops/_op_impl/aicpu/channel_shuffle.py +40 -0
- mindspore/ops/_op_impl/aicpu/conj.py +11 -0
- mindspore/ops/_op_impl/aicpu/cumulative_logsumexp.py +0 -3
- mindspore/ops/_op_impl/aicpu/deformable_offsets.py +38 -0
- mindspore/ops/_op_impl/aicpu/deformable_offsets_grad.py +43 -0
- mindspore/ops/_op_impl/aicpu/{adaptive_avg_pool_2d_grad_v1.py → digamma.py} +7 -9
- mindspore/ops/_op_impl/aicpu/flatten.py +1 -0
- mindspore/ops/_op_impl/aicpu/fmax.py +36 -0
- mindspore/ops/_op_impl/aicpu/fmin.py +37 -0
- mindspore/ops/_op_impl/aicpu/fractional_max_pool3d_with_fixed_ksize.py +1 -1
- mindspore/ops/_op_impl/aicpu/fse_decode.py +43 -0
- mindspore/ops/_op_impl/aicpu/greater.py +41 -0
- mindspore/ops/_op_impl/aicpu/greater_equal.py +41 -0
- mindspore/ops/_op_impl/aicpu/index_put.py +50 -0
- mindspore/ops/_op_impl/aicpu/less.py +41 -0
- mindspore/{nn/probability/infer/variational/__init__.py → ops/_op_impl/aicpu/lgamma.py} +16 -10
- mindspore/ops/_op_impl/aicpu/mirror_pad.py +0 -4
- mindspore/ops/_op_impl/aicpu/mirror_pad_grad.py +0 -4
- mindspore/ops/_op_impl/aicpu/mul.py +3 -1
- mindspore/ops/_op_impl/aicpu/multinomial.py +14 -6
- mindspore/ops/_op_impl/aicpu/nllloss.py +38 -0
- mindspore/ops/_op_impl/aicpu/nllloss_grad.py +39 -0
- mindspore/ops/_op_impl/aicpu/ones_like.py +0 -2
- mindspore/ops/_op_impl/aicpu/polar.py +32 -0
- mindspore/ops/_op_impl/aicpu/polygamma.py +34 -0
- mindspore/ops/_op_impl/aicpu/quant_dtype_cast.py +40 -0
- mindspore/ops/_op_impl/aicpu/quantile.py +35 -0
- mindspore/ops/_op_impl/aicpu/ragged_tensor_to_sparse.py +73 -0
- mindspore/ops/_op_impl/aicpu/randperm_v2.py +41 -0
- mindspore/ops/_op_impl/aicpu/resize_bicubic.py +2 -8
- mindspore/ops/_op_impl/aicpu/resize_bicubic_grad.py +1 -1
- mindspore/ops/_op_impl/aicpu/resize_v2.py +68 -0
- mindspore/ops/_op_impl/aicpu/resize_v2_grad.py +68 -0
- mindspore/ops/_op_impl/aicpu/scatter_elements.py +4 -0
- mindspore/ops/_op_impl/aicpu/scatter_nd_update.py +2 -0
- mindspore/ops/_op_impl/aicpu/sequence_add.py +34 -0
- mindspore/ops/_op_impl/aicpu/sequence_add_offset.py +34 -0
- mindspore/ops/_op_impl/aicpu/sequence_addn.py +38 -0
- mindspore/ops/_op_impl/aicpu/smooth_l1_loss.py +35 -0
- mindspore/ops/_op_impl/aicpu/smooth_l1_loss_grad.py +37 -0
- mindspore/ops/_op_impl/aicpu/sparse_apply_adagrad_da.py +0 -24
- mindspore/ops/_op_impl/aicpu/sparse_cross.py +42 -0
- mindspore/ops/_op_impl/aicpu/sparse_slice.py +4 -0
- mindspore/ops/_op_impl/aicpu/sparse_slice_grad.py +6 -0
- mindspore/ops/_op_impl/aicpu/tensor_scatter_update.py +59 -0
- mindspore/ops/_op_impl/aicpu/trans_data.py +1 -0
- mindspore/ops/_op_impl/aicpu/tril_indices.py +34 -0
- mindspore/ops/_op_impl/aicpu/uniform.py +34 -0
- mindspore/ops/_op_impl/aicpu/uniform_candidate_sampler.py +1 -0
- mindspore/ops/_op_impl/aicpu/unique_consecutive.py +10 -2
- mindspore/ops/_op_impl/cpu/dynamic_shape.py +5 -1
- mindspore/ops/_op_impl/cpu/sparse_slice.py +4 -0
- mindspore/ops/_op_impl/cpu/sparse_slice_grad.py +6 -0
- mindspore/ops/_op_impl/cpu/tensor_shape.py +5 -1
- mindspore/ops/_op_impl/tbe/__init__.py +27 -611
- mindspore/ops/_op_impl/tbe/assign_add_ds.py +1 -0
- mindspore/ops/_op_impl/tbe/atomic_addr_clean.py +1 -1
- mindspore/ops/_op_impl/tbe/avg_pool_3d_grad.py +1 -1
- mindspore/ops/_op_impl/tbe/batch_matmul_ds.py +1 -0
- mindspore/ops/_op_impl/tbe/batch_to_space.py +1 -1
- mindspore/ops/_op_impl/tbe/batch_to_space_nd.py +1 -1
- mindspore/ops/_op_impl/tbe/bn_infer_grad.py +4 -2
- mindspore/ops/_op_impl/tbe/bn_training_update.py +0 -1
- mindspore/ops/_op_impl/tbe/bn_training_update_ds.py +0 -1
- mindspore/ops/_op_impl/tbe/broadcast_to_ds.py +6 -4
- mindspore/ops/_op_impl/tbe/cast.py +0 -2
- mindspore/ops/_op_impl/tbe/cast_ds.py +3 -3
- mindspore/ops/_op_impl/tbe/data_format_dim_map_ds.py +1 -0
- mindspore/ops/_op_impl/tbe/depthwise_conv2d.py +2 -2
- mindspore/ops/_op_impl/tbe/dynamic_atomic_addr_clean.py +1 -1
- mindspore/ops/_op_impl/tbe/gather_nd.py +1 -0
- mindspore/ops/_op_impl/tbe/{index_add.py → inplace_index_add.py} +3 -6
- mindspore/ops/_op_impl/tbe/matmul_ds.py +2 -0
- mindspore/ops/_op_impl/tbe/npu_clear_float_status_v2.py +35 -0
- mindspore/ops/_op_impl/tbe/npu_get_float_status_v2.py +35 -0
- mindspore/ops/_op_impl/tbe/scatter_mul.py +2 -0
- mindspore/ops/_op_impl/tbe/scatter_nd_add.py +0 -2
- mindspore/ops/_op_impl/tbe/space_to_batch.py +1 -1
- mindspore/ops/_op_impl/tbe/space_to_batch_nd.py +1 -1
- mindspore/ops/_op_impl/tbe/trans_data_ds.py +15 -5
- mindspore/ops/_register_for_op.py +1 -0
- mindspore/ops/_utils/__init__.py +1 -2
- mindspore/ops/_utils/utils.py +19 -40
- mindspore/ops/_vmap/vmap_array_ops.py +116 -38
- mindspore/ops/_vmap/vmap_base.py +16 -9
- mindspore/ops/_vmap/vmap_convolution_ops.py +7 -10
- mindspore/ops/_vmap/vmap_grad_math_ops.py +4 -4
- mindspore/ops/_vmap/vmap_grad_nn_ops.py +7 -5
- mindspore/ops/_vmap/vmap_image_ops.py +12 -5
- mindspore/ops/_vmap/vmap_math_ops.py +46 -5
- mindspore/ops/_vmap/vmap_nn_ops.py +15 -21
- mindspore/ops/_vmap/vmap_random_ops.py +1 -1
- mindspore/ops/bprop_mindir/AdaptiveAvgPool2D_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/AdaptiveMaxPool2D_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/AvgPool3D_bprop.mindir +150 -0
- mindspore/ops/bprop_mindir/AvgPool_bprop.mindir +66 -0
- mindspore/ops/bprop_mindir/BCEWithLogitsLoss_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/BatchNormGrad_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/BiasAddGrad_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/BinaryCrossEntropy_bprop.mindir +33 -0
- mindspore/ops/bprop_mindir/BroadcastTo_bprop.mindir +220 -106
- mindspore/ops/bprop_mindir/CTCLoss_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/Conv2DBackpropFilter_bprop.mindir +240 -0
- mindspore/ops/bprop_mindir/Conv2DBackpropInput_bprop.mindir +247 -0
- mindspore/ops/bprop_mindir/Conv2DTranspose_bprop.mindir +247 -0
- mindspore/ops/bprop_mindir/Conv3DTranspose_bprop.mindir +315 -0
- mindspore/ops/bprop_mindir/Conv3D_bprop.mindir +278 -0
- mindspore/ops/bprop_mindir/DeformableOffsets_bprop.mindir +58 -0
- mindspore/ops/bprop_mindir/DepthwiseConv2dNative_bprop.mindir +138 -0
- 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 +22 -23
- mindspore/ops/bprop_mindir/DropoutGenMask_bprop.mindir +16 -17
- mindspore/ops/bprop_mindir/DropoutGrad_bprop.mindir +27 -0
- 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/Elu_bprop.mindir +16 -0
- mindspore/ops/bprop_mindir/EmbeddingLookup_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/ExpandDims_bprop.mindir +39 -41
- mindspore/ops/bprop_mindir/FastGeLU_bprop.mindir +16 -0
- mindspore/ops/bprop_mindir/Flatten_bprop.mindir +41 -43
- mindspore/ops/bprop_mindir/GatherNd_bprop.mindir +51 -57
- mindspore/ops/bprop_mindir/Gather_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/HSigmoid_bprop.mindir +16 -0
- mindspore/ops/bprop_mindir/HSwish_bprop.mindir +16 -0
- mindspore/ops/bprop_mindir/InstanceNorm_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/KLDivLoss_bprop.mindir +126 -0
- mindspore/ops/bprop_mindir/L2Loss_bprop.mindir +15 -0
- mindspore/ops/bprop_mindir/L2Normalize_bprop.mindir +30 -0
- mindspore/ops/bprop_mindir/LRN_bprop.mindir +43 -0
- mindspore/ops/bprop_mindir/LayerNormGrad_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/LogSoftmax_bprop.mindir +23 -0
- mindspore/ops/bprop_mindir/MaxPool3DGradGrad_bprop.mindir +74 -0
- mindspore/ops/bprop_mindir/MaxPool3DGrad_bprop.mindir +74 -0
- mindspore/ops/bprop_mindir/MaxPool3D_bprop.mindir +75 -0
- mindspore/ops/bprop_mindir/MaxPoolGradGrad_bprop.mindir +65 -0
- mindspore/ops/bprop_mindir/MaxPoolWithArgmax_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/MirrorPad_bprop.mindir +27 -0
- mindspore/ops/bprop_mindir/Mish_bprop.mindir +35 -0
- mindspore/ops/bprop_mindir/MulNoNan_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/NLLLoss_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/OneHot_bprop.mindir +24 -25
- 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 +29 -0
- mindspore/ops/bprop_mindir/ROIAlign_bprop.mindir +82 -0
- mindspore/ops/bprop_mindir/ReLU6_bprop.mindir +16 -0
- mindspore/ops/bprop_mindir/ReLUV2_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/ReluGrad_bprop.mindir +18 -19
- mindspore/ops/bprop_mindir/Reshape_bprop.mindir +53 -53
- mindspore/ops/bprop_mindir/ResizeBilinear_bprop.mindir +29 -0
- mindspore/ops/bprop_mindir/ResizeNearestNeighbor_bprop.mindir +77 -85
- mindspore/ops/bprop_mindir/SeLU_bprop.mindir +21 -0
- mindspore/ops/bprop_mindir/SigmoidCrossEntropyWithLogits_bprop.mindir +21 -0
- mindspore/ops/bprop_mindir/SigmoidGrad_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/Sigmoid_bprop.mindir +16 -0
- mindspore/ops/bprop_mindir/SmoothL1Loss_bprop.mindir +36 -0
- mindspore/ops/bprop_mindir/SoftmaxCrossEntropyWithLogits_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/Softplus_bprop.mindir +16 -0
- mindspore/ops/bprop_mindir/Softsign_bprop.mindir +33 -0
- mindspore/ops/bprop_mindir/SparseSoftmaxCrossEntropyWithLogits_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/Squeeze_bprop.mindir +37 -39
- mindspore/ops/bprop_mindir/StridedSlice_bprop.mindir +70 -72
- mindspore/ops/bprop_mindir/TanhGrad_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/Tanh_bprop.mindir +66 -0
- mindspore/ops/bprop_mindir/Tile_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/TopK_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/TupleGetItem_bprop.mindir +17 -17
- mindspore/ops/bprop_mindir/UpsampleNearest3D_bprop.mindir +32 -0
- mindspore/ops/bprop_mindir/UpsampleTrilinear3D_bprop.mindir +38 -0
- mindspore/ops/bprop_mindir/generate_mindir.py +2 -0
- mindspore/ops/composite/__init__.py +7 -8
- mindspore/ops/composite/base.py +101 -47
- mindspore/ops/composite/math_ops.py +188 -158
- mindspore/ops/composite/multitype_ops/_compile_utils.py +415 -170
- mindspore/ops/composite/multitype_ops/_constexpr_utils.py +142 -87
- mindspore/ops/composite/multitype_ops/add_impl.py +6 -1
- mindspore/ops/composite/multitype_ops/div_impl.py +2 -3
- mindspore/ops/composite/multitype_ops/getitem_impl.py +31 -3
- mindspore/ops/composite/multitype_ops/greater_equal_impl.py +31 -0
- mindspore/ops/composite/multitype_ops/greater_impl.py +31 -0
- mindspore/ops/composite/multitype_ops/in_impl.py +9 -0
- mindspore/ops/composite/multitype_ops/less_equal_impl.py +31 -0
- mindspore/ops/composite/multitype_ops/less_impl.py +31 -0
- mindspore/ops/composite/multitype_ops/mul_impl.py +21 -5
- mindspore/ops/composite/multitype_ops/not_in_impl.py +9 -0
- mindspore/ops/composite/multitype_ops/ones_like_impl.py +2 -4
- mindspore/ops/composite/multitype_ops/setitem_impl.py +21 -3
- mindspore/ops/composite/multitype_ops/sub_impl.py +1 -1
- mindspore/ops/composite/multitype_ops/zeros_like_impl.py +35 -4
- mindspore/ops/function/__init__.py +152 -8
- mindspore/ops/function/array_func.py +2555 -674
- mindspore/ops/function/clip_func.py +209 -13
- mindspore/ops/function/debug_func.py +2 -2
- mindspore/ops/function/grad/__init__.py +2 -1
- mindspore/ops/function/grad/grad_func.py +147 -62
- mindspore/ops/function/image_func.py +54 -38
- mindspore/ops/function/linalg_func.py +167 -16
- mindspore/ops/function/math_func.py +4849 -1492
- mindspore/ops/function/nn_func.py +2573 -988
- mindspore/ops/function/other_func.py +115 -0
- mindspore/ops/function/parameter_func.py +3 -3
- mindspore/ops/function/random_func.py +790 -73
- mindspore/ops/function/sparse_func.py +98 -78
- mindspore/ops/function/sparse_unary_func.py +54 -53
- mindspore/ops/function/spectral_func.py +27 -24
- mindspore/ops/function/vmap_func.py +22 -2
- mindspore/ops/functional.py +97 -37
- mindspore/ops/op_info_register.py +70 -28
- mindspore/ops/operations/__init__.py +47 -14
- mindspore/ops/operations/_csr_ops.py +7 -7
- mindspore/ops/operations/_embedding_cache_ops.py +5 -5
- mindspore/ops/operations/_grad_ops.py +276 -187
- mindspore/ops/operations/_inner_ops.py +319 -113
- mindspore/ops/operations/_ms_kernel.py +10 -8
- mindspore/ops/operations/_ocr_ops.py +9 -9
- mindspore/ops/operations/_opaque_predicate_registry.py +4 -0
- mindspore/ops/operations/_quant_ops.py +137 -102
- mindspore/ops/operations/_rl_inner_ops.py +121 -60
- mindspore/ops/operations/_scalar_ops.py +466 -0
- mindspore/ops/operations/_sequence_ops.py +1004 -2
- mindspore/ops/operations/_tensor_array.py +10 -11
- mindspore/ops/operations/_thor_ops.py +1 -1
- mindspore/ops/operations/array_ops.py +801 -466
- mindspore/ops/operations/comm_ops.py +51 -49
- mindspore/ops/operations/control_ops.py +2 -2
- mindspore/ops/operations/custom_ops.py +123 -44
- mindspore/ops/operations/debug_ops.py +24 -24
- mindspore/ops/operations/image_ops.py +240 -153
- mindspore/ops/operations/inner_ops.py +34 -50
- mindspore/ops/operations/linalg_ops.py +31 -9
- mindspore/ops/operations/math_ops.py +988 -757
- mindspore/ops/operations/nn_ops.py +965 -819
- mindspore/ops/operations/other_ops.py +51 -40
- mindspore/ops/operations/random_ops.py +204 -122
- mindspore/ops/operations/rl_ops.py +8 -9
- mindspore/ops/operations/sparse_ops.py +254 -93
- mindspore/ops/operations/spectral_ops.py +35 -3
- mindspore/ops/primitive.py +111 -9
- mindspore/parallel/_auto_parallel_context.py +189 -83
- mindspore/parallel/_offload_context.py +185 -0
- mindspore/parallel/_parallel_serialization.py +99 -7
- mindspore/parallel/_ps_context.py +9 -5
- mindspore/parallel/_recovery_context.py +1 -1
- mindspore/parallel/_tensor.py +7 -1
- mindspore/{nn/transformer → parallel/_transformer}/__init__.py +6 -6
- mindspore/{nn/transformer → parallel/_transformer}/layers.py +6 -37
- mindspore/{nn/transformer → parallel/_transformer}/loss.py +4 -7
- mindspore/{nn/transformer → parallel/_transformer}/moe.py +20 -16
- mindspore/{nn/transformer → parallel/_transformer}/op_parallel_config.py +3 -3
- mindspore/{nn/transformer → parallel/_transformer}/transformer.py +48 -111
- mindspore/parallel/_utils.py +1 -2
- mindspore/parallel/algo_parameter_config.py +1 -1
- mindspore/parallel/checkpoint_transform.py +37 -34
- mindspore/parallel/shard.py +17 -18
- mindspore/profiler/common/validator/validate_path.py +2 -2
- mindspore/profiler/envprofiling.py +69 -47
- mindspore/profiler/parser/ascend_timeline_generator.py +49 -42
- mindspore/profiler/parser/base_timeline_generator.py +49 -56
- mindspore/profiler/parser/cpu_gpu_timeline_generator.py +98 -78
- mindspore/profiler/parser/hwts_log_parser.py +1 -1
- mindspore/profiler/parser/integrator.py +15 -14
- mindspore/profiler/parser/minddata_analyzer.py +2 -2
- mindspore/profiler/parser/msadvisor_analyzer.py +12 -25
- mindspore/profiler/parser/msadvisor_parser.py +2 -4
- mindspore/profiler/parser/optime_parser.py +17 -18
- mindspore/profiler/parser/profiler_info.py +2 -1
- mindspore/profiler/profiling.py +218 -186
- mindspore/rewrite/__init__.py +3 -1
- mindspore/rewrite/api/node.py +1 -114
- mindspore/rewrite/api/node_type.py +3 -0
- mindspore/rewrite/api/pattern_engine.py +31 -1
- mindspore/rewrite/api/scoped_value.py +4 -4
- mindspore/rewrite/api/symbol_tree.py +3 -78
- mindspore/rewrite/api/tree_node_helper.py +1 -1
- mindspore/rewrite/ast_creator_register.py +1 -0
- mindspore/rewrite/ast_helpers/__init__.py +2 -2
- mindspore/rewrite/ast_helpers/ast_creator.py +1 -2
- mindspore/rewrite/ast_helpers/ast_finder.py +65 -0
- mindspore/rewrite/ast_helpers/ast_modifier.py +11 -3
- mindspore/rewrite/ast_transformers/flatten_recursive_stmt.py +18 -2
- mindspore/rewrite/namespace.py +0 -2
- mindspore/rewrite/node.py +157 -11
- mindspore/rewrite/parsers/assign_parser.py +231 -53
- mindspore/rewrite/parsers/class_def_parser.py +187 -109
- mindspore/rewrite/parsers/for_parser.py +24 -14
- mindspore/rewrite/parsers/function_def_parser.py +21 -4
- mindspore/rewrite/parsers/if_parser.py +6 -2
- mindspore/rewrite/sparsify/__init__.py +0 -0
- mindspore/rewrite/sparsify/sparse_transformer.py +448 -0
- mindspore/rewrite/sparsify/sparsify.py +109 -0
- mindspore/rewrite/sparsify/utils.py +173 -0
- mindspore/rewrite/symbol_tree.py +256 -133
- mindspore/rewrite/symbol_tree_builder.py +38 -1
- mindspore/run_check/_check_version.py +69 -63
- mindspore/run_check/run_check.py +2 -1
- mindspore/tinyxml2.dll +0 -0
- mindspore/train/__init__.py +1 -1
- mindspore/train/_utils.py +28 -5
- mindspore/train/amp.py +273 -102
- mindspore/train/callback/_backup_and_restore.py +5 -5
- mindspore/train/callback/_callback.py +2 -2
- mindspore/train/callback/_checkpoint.py +3 -3
- mindspore/train/callback/_early_stop.py +3 -3
- mindspore/train/callback/_lambda_callback.py +2 -2
- mindspore/train/callback/_landscape.py +29 -31
- mindspore/train/callback/_loss_monitor.py +3 -3
- mindspore/train/callback/_on_request_exit.py +3 -3
- mindspore/train/callback/_reduce_lr_on_plateau.py +4 -4
- mindspore/train/callback/_summary_collector.py +23 -16
- mindspore/train/callback/_time_monitor.py +3 -3
- mindspore/train/checkpoint_pb2.py +68 -8
- mindspore/train/data_sink.py +15 -3
- mindspore/train/dataset_helper.py +10 -15
- mindspore/train/loss_scale_manager.py +8 -11
- mindspore/train/metrics/__init__.py +1 -1
- mindspore/train/metrics/bleu_score.py +1 -1
- mindspore/train/metrics/confusion_matrix.py +1 -1
- mindspore/train/metrics/cosine_similarity.py +1 -1
- mindspore/train/metrics/dice.py +2 -2
- mindspore/train/metrics/fbeta.py +1 -1
- mindspore/train/metrics/hausdorff_distance.py +4 -3
- mindspore/train/metrics/mean_surface_distance.py +2 -2
- mindspore/train/metrics/occlusion_sensitivity.py +1 -1
- mindspore/train/metrics/perplexity.py +1 -1
- mindspore/train/metrics/precision.py +1 -1
- mindspore/train/metrics/recall.py +1 -1
- mindspore/train/metrics/roc.py +2 -2
- mindspore/train/metrics/root_mean_square_surface_distance.py +2 -2
- mindspore/train/mind_ir_pb2.py +116 -37
- mindspore/train/model.py +45 -28
- mindspore/train/serialization.py +295 -188
- mindspore/train/summary/_summary_adapter.py +1 -1
- mindspore/train/summary/summary_record.py +43 -13
- mindspore/train/train_thor/convert_utils.py +2 -2
- mindspore/train/train_thor/dataset_helper.py +3 -3
- mindspore/turbojpeg.dll +0 -0
- mindspore/version.py +1 -1
- {mindspore-2.0.0a0.dist-info → mindspore-2.0.0rc1.dist-info}/METADATA +3 -2
- {mindspore-2.0.0a0.dist-info → mindspore-2.0.0rc1.dist-info}/RECORD +610 -541
- mindspore/compression/__init__.py +0 -19
- mindspore/compression/common/constant.py +0 -124
- mindspore/compression/export/__init__.py +0 -19
- mindspore/compression/export/quant_export.py +0 -515
- mindspore/compression/quant/__init__.py +0 -28
- mindspore/compression/quant/qat.py +0 -634
- mindspore/compression/quant/quant_utils.py +0 -462
- mindspore/compression/quant/quantizer.py +0 -68
- mindspore/nn/layer/quant.py +0 -1868
- mindspore/nn/layer/rnn_utils.py +0 -90
- mindspore/nn/probability/dpn/__init__.py +0 -22
- mindspore/nn/probability/dpn/vae/__init__.py +0 -25
- mindspore/nn/probability/dpn/vae/cvae.py +0 -140
- mindspore/nn/probability/dpn/vae/vae.py +0 -124
- mindspore/nn/probability/infer/__init__.py +0 -22
- mindspore/nn/probability/infer/variational/elbo.py +0 -70
- mindspore/nn/probability/infer/variational/svi.py +0 -84
- mindspore/nn/probability/toolbox/__init__.py +0 -22
- mindspore/nn/probability/toolbox/anomaly_detection.py +0 -99
- mindspore/nn/probability/toolbox/uncertainty_evaluation.py +0 -364
- mindspore/nn/probability/transforms/__init__.py +0 -22
- mindspore/nn/probability/transforms/transform_bnn.py +0 -262
- mindspore/nn/probability/zhusuan/__init__.py +0 -18
- mindspore/nn/probability/zhusuan/framework/__init__.py +0 -18
- mindspore/nn/probability/zhusuan/framework/bn.py +0 -95
- mindspore/nn/probability/zhusuan/variational/__init__.py +0 -18
- mindspore/nn/probability/zhusuan/variational/elbo.py +0 -46
- mindspore/ops/_op_impl/aicpu/parallel_concat.py +0 -42
- mindspore/ops/_op_impl/tbe/gather_v2.py +0 -56
- mindspore/ops/bprop_mindir/AssignAdd_bprop.mindir +0 -19
- mindspore/ops/bprop_mindir/Cast_bprop.mindir +0 -19
- mindspore/ops/bprop_mindir/LogicalOr_bprop.mindir +0 -19
- mindspore/ops/bprop_mindir/MatMul_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/ReLU_bprop.mindir +0 -17
- mindspore/ops/bprop_mindir/Transpose_bprop.mindir +0 -0
- mindspore/ops/bprop_mindir/UpdateState_bprop.mindir +0 -15
- mindspore/ops/composite/array_ops.py +0 -241
- mindspore/ops/composite/clip_ops.py +0 -134
- mindspore/ops/composite/random_ops.py +0 -426
- mindspore/ops/composite/vmap_ops.py +0 -38
- mindspore/parallel/nn/__init__.py +0 -42
- mindspore/parallel/nn/loss.py +0 -22
- mindspore/parallel/nn/moe.py +0 -21
- mindspore/parallel/nn/op_parallel_config.py +0 -22
- mindspore/parallel/nn/transformer.py +0 -31
- {mindspore-2.0.0a0.dist-info → mindspore-2.0.0rc1.dist-info}/WHEEL +0 -0
- {mindspore-2.0.0a0.dist-info → mindspore-2.0.0rc1.dist-info}/entry_points.txt +0 -0
- {mindspore-2.0.0a0.dist-info → mindspore-2.0.0rc1.dist-info}/top_level.txt +0 -0
|
@@ -21,7 +21,7 @@ from multiprocessing import Pool, cpu_count
|
|
|
21
21
|
from mindspore import log as logger
|
|
22
22
|
from mindspore._extends.parallel_compile.akg_compiler.get_file_path import get_akg_path
|
|
23
23
|
from mindspore._extends.parallel_compile.akg_compiler.util import get_ascend_compile_dirs, create_compile_dirs, \
|
|
24
|
-
get_log_level, update_attr, select_best, print_compile_log, check_tbe_support
|
|
24
|
+
get_log_level, update_attr, select_best, print_compile_log, check_tbe_support, get_kernel_meta_parent_dir
|
|
25
25
|
|
|
26
26
|
|
|
27
27
|
def _compile_akg_task_default(json_strs, attrs):
|
|
@@ -35,6 +35,7 @@ def _compile_akg_task_default(json_strs, attrs):
|
|
|
35
35
|
sys.path.insert(0, get_akg_path())
|
|
36
36
|
p = __import__("akg", globals(), locals(), ['ms'], 0)
|
|
37
37
|
func = getattr(p.ms, "compilewithjson")
|
|
38
|
+
os.environ["MS_COMPILER_CACHE_PATH"] = get_kernel_meta_parent_dir(attrs)
|
|
38
39
|
|
|
39
40
|
for json_str in json_strs:
|
|
40
41
|
res = func(json_str, attrs)
|
|
@@ -66,7 +67,7 @@ def _compile_akg_task_ascend(json_strs, attrs):
|
|
|
66
67
|
return
|
|
67
68
|
log_level = get_log_level(attrs)
|
|
68
69
|
compiler = os.path.join(os.path.split(os.path.realpath(__file__))[0], "compiler.py")
|
|
69
|
-
compile_dirs = get_ascend_compile_dirs()
|
|
70
|
+
compile_dirs = get_ascend_compile_dirs(attrs)
|
|
70
71
|
kernel_meta_dir = compile_dirs.get("kernel_meta_dir")
|
|
71
72
|
akg_compile_dir = compile_dirs.get("akg_compile_dir")
|
|
72
73
|
tbe_compile_dir = compile_dirs.get("tbe_compile_dir")
|
|
@@ -151,7 +152,7 @@ class AkgProcess:
|
|
|
151
152
|
"not be zero.")
|
|
152
153
|
args = list((arg, attrs) for arg in self.args)
|
|
153
154
|
if self.platform == "ASCEND":
|
|
154
|
-
create_compile_dirs(get_ascend_compile_dirs())
|
|
155
|
+
create_compile_dirs(get_ascend_compile_dirs(attrs))
|
|
155
156
|
with Pool(processes=self.process_num) as pool:
|
|
156
157
|
res = pool.starmap_async(_compile_akg_task_ascend, args)
|
|
157
158
|
res.get(timeout=self.wait_time)
|
|
@@ -19,6 +19,8 @@ from enum import Enum
|
|
|
19
19
|
|
|
20
20
|
|
|
21
21
|
class OpPattern(Enum):
|
|
22
|
+
"""Pattern of operator."""
|
|
23
|
+
|
|
22
24
|
ELEMWISE = "ELEMWISE"
|
|
23
25
|
BROADCAST = "BROADCAST"
|
|
24
26
|
REDUCE = "REDUCE"
|
|
@@ -58,24 +60,24 @@ def get_op_reg_info(op_name, key, strict=True):
|
|
|
58
60
|
|
|
59
61
|
def _broadcast(lhs, rhs):
|
|
60
62
|
"""Broadcast inputs."""
|
|
61
|
-
|
|
62
|
-
from
|
|
63
|
-
|
|
64
|
-
if isinstance(lhs, tvm.
|
|
65
|
-
return lhs, tbe.broadcast(rhs, lhs.shape)
|
|
66
|
-
if isinstance(lhs, tvm.expr.ConstExpr) and isinstance(rhs, tvm.
|
|
67
|
-
return tbe.broadcast(lhs, rhs.shape), rhs
|
|
63
|
+
import tbe
|
|
64
|
+
from tbe import tvm
|
|
65
|
+
from tbe.common.utils import shape_to_list, broadcast_shapes
|
|
66
|
+
if isinstance(lhs, tvm.Tensor) and isinstance(rhs, tvm.expr.ConstExpr):
|
|
67
|
+
return lhs, tbe.dsl.broadcast(rhs, lhs.shape)
|
|
68
|
+
if isinstance(lhs, tvm.expr.ConstExpr) and isinstance(rhs, tvm.Tensor):
|
|
69
|
+
return tbe.dsl.broadcast(lhs, rhs.shape), rhs
|
|
68
70
|
if isinstance(lhs, tvm.expr.ConstExpr) and isinstance(rhs, tvm.expr.ConstExpr):
|
|
69
71
|
shape = [1]
|
|
70
|
-
return tbe.broadcast(lhs, shape), tbe.broadcast(rhs, shape)
|
|
71
|
-
if isinstance(lhs, tvm.
|
|
72
|
-
shape1 =
|
|
73
|
-
shape2 =
|
|
72
|
+
return tbe.dsl.broadcast(lhs, shape), tbe.dsl.broadcast(rhs, shape)
|
|
73
|
+
if isinstance(lhs, tvm.Tensor) and isinstance(rhs, tvm.Tensor):
|
|
74
|
+
shape1 = shape_to_list(lhs.shape)
|
|
75
|
+
shape2 = shape_to_list(rhs.shape)
|
|
74
76
|
if shape1 != shape2:
|
|
75
|
-
_, _, shape =
|
|
76
|
-
return tbe.broadcast(lhs, shape), tbe.broadcast(rhs, shape)
|
|
77
|
+
_, _, shape = broadcast_shapes(shape1, shape2, param_name_input1="lhs", param_name_input2="rhs")
|
|
78
|
+
return tbe.dsl.broadcast(lhs, shape), tbe.dsl.broadcast(rhs, shape)
|
|
77
79
|
return lhs, rhs
|
|
78
|
-
raise TypeError("Broadcast only supports tvm.
|
|
80
|
+
raise TypeError("Broadcast only supports tvm.Tensor or tvm.expr.ConstExpr, but got {}, {}"
|
|
79
81
|
.format(type(lhs), type(rhs)))
|
|
80
82
|
|
|
81
83
|
|
|
@@ -103,13 +105,13 @@ def _acosh(x, attrs=None):
|
|
|
103
105
|
@reg_op("Add", pattern=OpPattern.ELEMWISE)
|
|
104
106
|
def _add(x0, x1, attrs=None):
|
|
105
107
|
"""Add"""
|
|
106
|
-
|
|
107
|
-
|
|
108
|
+
import tbe
|
|
109
|
+
from tbe import tvm
|
|
108
110
|
is_float = x0.dtype in ["float16", "float32"]
|
|
109
|
-
if is_float and isinstance(x0, tvm.
|
|
110
|
-
return tbe.vadds(x0, x1)
|
|
111
|
-
if is_float and isinstance(x0, tvm.expr.ConstExpr) and isinstance(x1, tvm.
|
|
112
|
-
return tbe.vadds(x1, x0)
|
|
111
|
+
if is_float and isinstance(x0, tvm.Tensor) and isinstance(x1, tvm.expr.ConstExpr):
|
|
112
|
+
return tbe.dsl.vadds(x0, x1)
|
|
113
|
+
if is_float and isinstance(x0, tvm.expr.ConstExpr) and isinstance(x1, tvm.Tensor):
|
|
114
|
+
return tbe.dsl.vadds(x1, x0)
|
|
113
115
|
x0, x1 = _broadcast(x0, x1)
|
|
114
116
|
from impl.add import add_compute
|
|
115
117
|
return add_compute(x0, x1, None, kernel_name=attrs["fusion_op_name"])
|
|
@@ -149,7 +151,7 @@ def _cast(x, attrs=None):
|
|
|
149
151
|
src_type = x.dtype
|
|
150
152
|
dst_type = attrs["dst_type"]
|
|
151
153
|
if src_type == "int64":
|
|
152
|
-
from
|
|
154
|
+
from tbe import tvm
|
|
153
155
|
from impl.cast import _kernel_ir
|
|
154
156
|
res = tvm.extern([x.shape], [x], lambda ins, outs: _kernel_ir(outs, ins, dst_type, "int64"), name="res",
|
|
155
157
|
dtype=dst_type)
|
|
@@ -338,13 +340,13 @@ def _mod(x0, x1, attrs=None):
|
|
|
338
340
|
@reg_op("Mul", pattern=OpPattern.ELEMWISE)
|
|
339
341
|
def _mul(x0, x1, attrs=None):
|
|
340
342
|
"""Mul"""
|
|
341
|
-
|
|
342
|
-
|
|
343
|
+
import tbe
|
|
344
|
+
from tbe import tvm
|
|
343
345
|
is_float = x0.dtype in ["float16", "float32"]
|
|
344
|
-
if is_float and isinstance(x0, tvm.
|
|
345
|
-
return tbe.vmuls(x0, x1)
|
|
346
|
-
if is_float and isinstance(x0, tvm.expr.ConstExpr) and isinstance(x1, tvm.
|
|
347
|
-
return tbe.vmuls(x1, x0)
|
|
346
|
+
if is_float and isinstance(x0, tvm.Tensor) and isinstance(x1, tvm.expr.ConstExpr):
|
|
347
|
+
return tbe.dsl.vmuls(x0, x1)
|
|
348
|
+
if is_float and isinstance(x0, tvm.expr.ConstExpr) and isinstance(x1, tvm.Tensor):
|
|
349
|
+
return tbe.dsl.vmuls(x1, x0)
|
|
348
350
|
x0, x1 = _broadcast(x0, x1)
|
|
349
351
|
from impl.mul import mul_compute
|
|
350
352
|
return mul_compute(x0, x1, None, kernel_name=attrs["fusion_op_name"])
|
|
@@ -376,10 +378,10 @@ def _pow(x0, x1, attrs=None):
|
|
|
376
378
|
@reg_op("RealDiv", "real_div", OpPattern.ELEMWISE)
|
|
377
379
|
def _realdiv(x0, x1, attrs=None):
|
|
378
380
|
"""RealDiv"""
|
|
379
|
-
|
|
380
|
-
|
|
381
|
-
if x0.dtype in ["float16", "float32"] and isinstance(x0, tvm.
|
|
382
|
-
return tbe.vmuls(x0, tvm.const(1.0 / x1.value, x0.dtype))
|
|
381
|
+
import tbe
|
|
382
|
+
from tbe import tvm
|
|
383
|
+
if x0.dtype in ["float16", "float32"] and isinstance(x0, tvm.Tensor) and isinstance(x1, tvm.expr.ConstExpr):
|
|
384
|
+
return tbe.dsl.vmuls(x0, tvm.const(1.0 / x1.value, x0.dtype))
|
|
383
385
|
x0, x1 = _broadcast(x0, x1)
|
|
384
386
|
from impl.real_div import real_div_compute
|
|
385
387
|
return real_div_compute(x0, x1, None, kernel_name=attrs["fusion_op_name"])
|
|
@@ -437,14 +439,14 @@ def _square(x, attrs=None):
|
|
|
437
439
|
@reg_op("Sub", pattern=OpPattern.ELEMWISE)
|
|
438
440
|
def _sub(x0, x1, attrs=None):
|
|
439
441
|
"""Sub"""
|
|
440
|
-
|
|
441
|
-
|
|
442
|
+
import tbe
|
|
443
|
+
from tbe import tvm
|
|
442
444
|
is_float = x0.dtype in ["float16", "float32"]
|
|
443
|
-
if is_float and isinstance(x0, tvm.
|
|
444
|
-
return tbe.vadds(x0, tvm.const(-1.0 * x1.value, x0.dtype))
|
|
445
|
-
if is_float and isinstance(x0, tvm.expr.ConstExpr) and isinstance(x1, tvm.
|
|
446
|
-
tmp = tbe.vmuls(x1, tvm.const(-1, x1.dtype))
|
|
447
|
-
return tbe.vadds(tmp, tvm.const(x0.value, x0.dtype))
|
|
445
|
+
if is_float and isinstance(x0, tvm.Tensor) and isinstance(x1, tvm.expr.ConstExpr):
|
|
446
|
+
return tbe.dsl.vadds(x0, tvm.const(-1.0 * x1.value, x0.dtype))
|
|
447
|
+
if is_float and isinstance(x0, tvm.expr.ConstExpr) and isinstance(x1, tvm.Tensor):
|
|
448
|
+
tmp = tbe.dsl.vmuls(x1, tvm.const(-1, x1.dtype))
|
|
449
|
+
return tbe.dsl.vadds(tmp, tvm.const(x0.value, x0.dtype))
|
|
448
450
|
x0, x1 = _broadcast(x0, x1)
|
|
449
451
|
from impl.sub import sub_compute
|
|
450
452
|
return sub_compute(x0, x1, None, kernel_name=attrs["fusion_op_name"])
|
|
@@ -460,26 +462,26 @@ def _tanh(x, attrs=None):
|
|
|
460
462
|
@reg_op("BroadcastTo", "broadcast", OpPattern.BROADCAST)
|
|
461
463
|
def _broadcast_to(x, attrs=None):
|
|
462
464
|
"""BroadcastTo"""
|
|
463
|
-
|
|
464
|
-
|
|
465
|
+
import tbe
|
|
466
|
+
from tbe import tvm
|
|
465
467
|
shape = attrs["shape"]
|
|
466
|
-
if isinstance(x, tvm.
|
|
468
|
+
if isinstance(x, tvm.Tensor):
|
|
467
469
|
from impl.broadcast_to_d import broadcast_to_compute
|
|
468
470
|
return broadcast_to_compute(x, None, shape, kernel_name=attrs["fusion_op_name"])
|
|
469
|
-
return tbe.broadcast(x, shape, x.dtype)
|
|
471
|
+
return tbe.dsl.broadcast(x, shape, x.dtype)
|
|
470
472
|
|
|
471
473
|
|
|
472
474
|
@reg_op("ReduceSum", "reduce_sum", OpPattern.REDUCE)
|
|
473
475
|
def _reduce_sum(x, attrs=None):
|
|
474
476
|
"""ReduceSum"""
|
|
475
|
-
from
|
|
477
|
+
from tbe.common.utils import axis_check
|
|
476
478
|
axis = attrs["axis"]
|
|
477
479
|
keep_dims = attrs["keep_dims"]
|
|
478
480
|
if not axis:
|
|
479
481
|
axis = [i for i in range(len(x.shape))]
|
|
480
482
|
if not isinstance(axis, list):
|
|
481
483
|
axis = [axis]
|
|
482
|
-
axis =
|
|
484
|
+
axis = axis_check(len(x.shape), axis)
|
|
483
485
|
from impl.reduce_sum_d import reduce_sum_d_compute
|
|
484
486
|
return reduce_sum_d_compute(x, None, axis, keep_dims, kernel_name=attrs["fusion_op_name"])
|
|
485
487
|
|
|
@@ -487,14 +489,14 @@ def _reduce_sum(x, attrs=None):
|
|
|
487
489
|
@reg_op("ReduceMax", "reduce_max", OpPattern.REDUCE)
|
|
488
490
|
def _reduce_max(x, attrs=None):
|
|
489
491
|
"""ReduceMax"""
|
|
490
|
-
from
|
|
492
|
+
from tbe.common.utils import axis_check
|
|
491
493
|
axis = attrs["axis"]
|
|
492
494
|
keep_dims = attrs["keep_dims"]
|
|
493
495
|
if not axis:
|
|
494
496
|
axis = [i for i in range(len(x.shape))]
|
|
495
497
|
if not isinstance(axis, list):
|
|
496
498
|
axis = [axis]
|
|
497
|
-
axis =
|
|
499
|
+
axis = axis_check(len(x.shape), axis)
|
|
498
500
|
from impl.reduce_max_d import reduce_max_d_compute
|
|
499
501
|
return reduce_max_d_compute(x, None, axis, keep_dims, kernel_name=attrs["fusion_op_name"])
|
|
500
502
|
|
|
@@ -502,14 +504,14 @@ def _reduce_max(x, attrs=None):
|
|
|
502
504
|
@reg_op("ReduceMin", "reduce_min", OpPattern.REDUCE)
|
|
503
505
|
def _reduce_min(x, attrs=None):
|
|
504
506
|
"""ReduceMin"""
|
|
505
|
-
from
|
|
507
|
+
from tbe.common.utils import axis_check
|
|
506
508
|
axis = attrs["axis"]
|
|
507
509
|
keep_dims = attrs["keep_dims"]
|
|
508
510
|
if not axis:
|
|
509
511
|
axis = [i for i in range(len(x.shape))]
|
|
510
512
|
if not isinstance(axis, list):
|
|
511
513
|
axis = [axis]
|
|
512
|
-
axis =
|
|
514
|
+
axis = axis_check(len(x.shape), axis)
|
|
513
515
|
from impl.reduce_min_d import reduce_min_d_compute
|
|
514
516
|
return reduce_min_d_compute(x, None, axis, keep_dims, kernel_name=attrs["fusion_op_name"])
|
|
515
517
|
|
|
@@ -58,14 +58,19 @@ def print_compile_log(compile_log):
|
|
|
58
58
|
logger.info(log)
|
|
59
59
|
|
|
60
60
|
|
|
61
|
-
def get_kernel_meta_parent_dir():
|
|
61
|
+
def get_kernel_meta_parent_dir(attrs):
|
|
62
62
|
"""Get kernel_meta parent dir."""
|
|
63
|
-
|
|
63
|
+
attrs_dict = {}
|
|
64
|
+
if isinstance(attrs, str):
|
|
65
|
+
attrs_dict = json.loads(attrs)
|
|
66
|
+
elif isinstance(attrs, dict):
|
|
67
|
+
attrs_dict = attrs
|
|
68
|
+
return os.path.realpath(attrs_dict.get("compile_cache"))
|
|
64
69
|
|
|
65
70
|
|
|
66
|
-
def get_ascend_compile_dirs():
|
|
71
|
+
def get_ascend_compile_dirs(attrs):
|
|
67
72
|
"""Get several Ascend compile dirs."""
|
|
68
|
-
kernel_meta_dir = os.path.join(get_kernel_meta_parent_dir(), "akg_kernel_meta")
|
|
73
|
+
kernel_meta_dir = os.path.join(get_kernel_meta_parent_dir(attrs), "akg_kernel_meta")
|
|
69
74
|
compile_dirs = {"kernel_meta_dir": kernel_meta_dir,
|
|
70
75
|
"akg_compile_dir": os.path.join(kernel_meta_dir, "akg"),
|
|
71
76
|
"tbe_compile_dir": os.path.join(kernel_meta_dir, "tbe"),
|
|
@@ -310,10 +310,10 @@ def check_support(job: TbeJob):
|
|
|
310
310
|
if op_func_name in ("resize_nearest_neighbor_v2_grad_d", "resize_bilinear_v2_grad"):
|
|
311
311
|
attrs.pop(-2)
|
|
312
312
|
op_module_name = get_module_name(compute_op_info)
|
|
313
|
-
|
|
314
|
-
_normalize_module_name(op_module_name, py_module_path)
|
|
313
|
+
_normalize_module_name(op_module_name, compute_op_info["py_module_path"])
|
|
315
314
|
func_name = "check_supported"
|
|
316
|
-
|
|
315
|
+
op_type = compute_op_info["type"]
|
|
316
|
+
res = call_op_func((inputs, outputs, attrs), op_module_name, func_name, op_type, "high_performance")
|
|
317
317
|
if isinstance(res, tuple):
|
|
318
318
|
result, reason = res
|
|
319
319
|
result_str = str(result)
|
|
@@ -510,7 +510,7 @@ def parallel_compile_fusion_op(job: TbeJob):
|
|
|
510
510
|
relation = ""
|
|
511
511
|
fixpipe_ub_cfg = ""
|
|
512
512
|
dispatch_fusion_op_compile_task(job.source_id, job.id, l1_size, json.dumps(job.content), op_kernel_name, None, None,
|
|
513
|
-
options, None, job.pass_list, op_name, relation, fixpipe_ub_cfg)
|
|
513
|
+
options, None, job.pass_list, op_name, relation, fixpipe_ub_cfg, None)
|
|
514
514
|
return True
|
|
515
515
|
|
|
516
516
|
|
|
@@ -143,10 +143,12 @@ def get_soc_info(initialize_job_info):
|
|
|
143
143
|
soc_param = dict()
|
|
144
144
|
soc_param["op_impl_mode"] = initialize_job_info["SocInfo"]["op_impl_mode"]
|
|
145
145
|
soc_param["op_debug_level"] = reset_op_debug_level_in_soc_info(initialize_job_info["SocInfo"]["op_debug_level"])
|
|
146
|
+
soc_param["op_debug_config"] = initialize_job_info["SocInfo"]["op_debug_config"]
|
|
146
147
|
soc_param["op_impl_mode_list"] = initialize_job_info["SocInfo"]["op_impl_mode_list"]
|
|
147
148
|
soc_param["op_debug_dir"] = initialize_job_info["SocInfo"]["op_debug_dir"]
|
|
148
149
|
soc_param["vector_fp_ceiling"] = initialize_job_info["SocInfo"]["vector_fp_ceiling"]
|
|
149
150
|
soc_param['mdl_bank_path'] = initialize_job_info["SocInfo"]["mdl_bank_path"]
|
|
151
|
+
soc_param['te_version'] = initialize_job_info["SocInfo"]["te_version"]
|
|
150
152
|
soc_param['op_bank_path'] = initialize_job_info["SocInfo"]["op_bank_path"]
|
|
151
153
|
soc_param['kernel_meta_temp_dir'] = initialize_job_info["SocInfo"]["kernel_meta_temp_dir"]
|
|
152
154
|
|
|
@@ -247,7 +249,7 @@ def assemble_op_args(compute_op_info, is_single_op_build=False):
|
|
|
247
249
|
attrs = []
|
|
248
250
|
attrs_info = compute_op_info["attrs"] if "attrs" in compute_op_info.keys() else []
|
|
249
251
|
for item in attrs_info:
|
|
250
|
-
if item["valid"]
|
|
252
|
+
if item["valid"]:
|
|
251
253
|
attrs.append(item)
|
|
252
254
|
else:
|
|
253
255
|
attrs = compute_op_info["attr_desc"] if "attr_desc" in compute_op_info.keys() else []
|
|
@@ -285,15 +287,18 @@ def get_options_info(job_content):
|
|
|
285
287
|
options["l2Fusion"] = job_content["SocInfo"]["l2Fusion"]
|
|
286
288
|
options["l2Mode"] = job_content["SocInfo"]["l2Mode"]
|
|
287
289
|
options["op_debug_level"] = reset_op_debug_level_in_soc_info(job_content["SocInfo"]["op_debug_level"])
|
|
290
|
+
options["op_debug_config"] = job_content["SocInfo"]["op_debug_config"]
|
|
288
291
|
options["op_impl_mode"] = job_content["SocInfo"]["op_impl_mode"]
|
|
289
292
|
options["op_debug_dir"] = job_content["SocInfo"]["op_debug_dir"]
|
|
290
293
|
options["mdl_bank_path"] = job_content["SocInfo"]["mdl_bank_path"]
|
|
294
|
+
options["te_version"] = job_content["SocInfo"]["te_version"]
|
|
291
295
|
options["op_bank_path"] = job_content["SocInfo"]["op_bank_path"]
|
|
292
296
|
options["deviceId"] = job_content["SocInfo"]["deviceId"]
|
|
293
297
|
options["autoTilingMode"] = job_content["SocInfo"]["autoTilingMode"]
|
|
294
298
|
options["op_impl_mode_list"] = job_content["SocInfo"]["op_impl_mode_list"]
|
|
295
299
|
options["kernel_meta_temp_dir"] = job_content["SocInfo"]["kernel_meta_temp_dir"]
|
|
296
|
-
options["
|
|
300
|
+
options["deterministic"] = job_content["SocInfo"]["deterministic"]
|
|
301
|
+
options["status_check"] = job_content["SocInfo"]["status_check"]
|
|
297
302
|
return options
|
|
298
303
|
|
|
299
304
|
|
|
@@ -336,10 +341,10 @@ def get_module_name(compute_op_info):
|
|
|
336
341
|
:param compute_op_info:
|
|
337
342
|
:return:
|
|
338
343
|
"""
|
|
339
|
-
|
|
344
|
+
is_dynamic_impl = compute_op_info["is_dynamic_impl"]
|
|
340
345
|
unknown_shape = compute_op_info["unknown_shape"]
|
|
341
346
|
op_module_name = compute_op_info["module_name"]
|
|
342
|
-
if
|
|
347
|
+
if is_dynamic_impl or unknown_shape:
|
|
343
348
|
d = ".dynamic."
|
|
344
349
|
op_module_name = d.join((op_module_name.split(".")[0], op_module_name.split(".")[-1]))
|
|
345
350
|
return op_module_name
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
# Copyright 2020-
|
|
1
|
+
# Copyright 2020-2023 Huawei Technologies Co., Ltd
|
|
2
2
|
#
|
|
3
3
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
4
4
|
# you may not use this file except in compliance with the License.
|
|
@@ -26,7 +26,8 @@ from .parser import (Parser, create_instance, is_supported_create_instance_type,
|
|
|
26
26
|
convert_to_ms_tensor, get_object_description, get_class_attr_namespace_symbol, get_ms_class_name,
|
|
27
27
|
is_class_type, check_obj_bool, python_isinstance, ms_isinstance, convert_to_ms_csrtensor,
|
|
28
28
|
convert_to_ms_cootensor, convert_class_to_function, convert_cell_list_to_sequence, is_cell_list,
|
|
29
|
-
get_obj_from_sequence, get_type, is_class_member_recursive, merge_global_params, get_global_params
|
|
29
|
+
get_obj_from_sequence, get_type, is_class_member_recursive, merge_global_params, get_global_params,
|
|
30
|
+
get_adapter_tensor_attr, get_local_variable, set_local_variable, get_obj_defined_from_obj_type)
|
|
30
31
|
|
|
31
32
|
__all__ = ['Parser', 'create_instance', 'is_supported_create_instance_type', 'generate_scope',
|
|
32
33
|
'get_bprop_method_of_class', 'get_class_instance_type', 'get_class_member_namespace_symbol',
|
|
@@ -37,4 +38,5 @@ __all__ = ['Parser', 'create_instance', 'is_supported_create_instance_type', 'ge
|
|
|
37
38
|
'convert_to_ms_tensor', 'get_object_description', 'get_class_attr_namespace_symbol', 'get_ms_class_name',
|
|
38
39
|
'is_class_type', 'check_obj_bool', 'python_isinstance', 'ms_isinstance', 'convert_to_ms_csrtensor',
|
|
39
40
|
'convert_to_ms_cootensor', 'convert_class_to_function', 'convert_cell_list_to_sequence', 'is_cell_list',
|
|
40
|
-
'get_obj_from_sequence', 'get_type', 'is_class_member_recursive'
|
|
41
|
+
'get_obj_from_sequence', 'get_type', 'is_class_member_recursive', 'get_adapter_tensor_attr',
|
|
42
|
+
'get_local_variable', 'set_local_variable', 'get_obj_defined_from_obj_type']
|
|
@@ -123,6 +123,13 @@ class ClassMemberNamespace(Namespace):
|
|
|
123
123
|
cls = d.__class__
|
|
124
124
|
if hasattr(cls, '__ms_class__'):
|
|
125
125
|
raise NotImplementedError(f"'{cls.__name__ }' object has no attribute or method: '{name}'.")
|
|
126
|
+
# Class private attribute.
|
|
127
|
+
if name.startswith("__"):
|
|
128
|
+
private_member = "_" + cls.__name__ + name
|
|
129
|
+
if hasattr(d, private_member):
|
|
130
|
+
logger.warning(f"The private attribute or method '{name}' is used in '{cls.__name__}'. " + \
|
|
131
|
+
f"In graph mode, '{name}' will be adjusted to '{private_member}' for parsing.")
|
|
132
|
+
return getattr(d, private_member)
|
|
126
133
|
logger.info(f"'{cls.__name__ }' object has no attribute or method: '{name}', so will return None.")
|
|
127
134
|
raise AttributeError(name)
|
|
128
135
|
|
|
@@ -147,4 +154,12 @@ class ClassAttrNamespace(Namespace):
|
|
|
147
154
|
except ValueError:
|
|
148
155
|
raise UnboundLocalError(name)
|
|
149
156
|
except KeyError:
|
|
150
|
-
|
|
157
|
+
# Class private attribute.
|
|
158
|
+
cls = d.__class__
|
|
159
|
+
if name.startswith("__"):
|
|
160
|
+
private_attr = "_" + cls.__name__ + name
|
|
161
|
+
if hasattr(d, private_attr):
|
|
162
|
+
logger.warning(f"The private attribute or method '{name}' is used in '{cls.__name__}'. " + \
|
|
163
|
+
f"In graph mode, '{name}' will be adjusted to '{private_attr}' for parsing.")
|
|
164
|
+
return getattr(d, private_attr)
|
|
165
|
+
raise AttributeError(f"'{cls.__name__ }' object has no attribute or method: '{name}'.")
|