forked from mindspore-Ecosystem/mindspore
register proximal adagrad ds
import proximal adaagrad ds tiling map style check bug add op set
This commit is contained in:
parent
81bdf61126
commit
3698b9fd54
|
@ -142,6 +142,7 @@ void OpTilingCalculater::Init() {
|
||||||
std::string GetRealOpType(const std::string &op_type) {
|
std::string GetRealOpType(const std::string &op_type) {
|
||||||
static const std::map<std::string, std::string> kOpTypeMap = {
|
static const std::map<std::string, std::string> kOpTypeMap = {
|
||||||
{"SparseApplyFtrl", "SparseApplyFtrlD"},
|
{"SparseApplyFtrl", "SparseApplyFtrlD"},
|
||||||
|
{"SparseApplyProximalAdagrad", "SparseApplyProximalAdagradD"},
|
||||||
};
|
};
|
||||||
auto iter = kOpTypeMap.find(op_type);
|
auto iter = kOpTypeMap.find(op_type);
|
||||||
if (iter == kOpTypeMap.end()) {
|
if (iter == kOpTypeMap.end()) {
|
||||||
|
|
|
@ -407,7 +407,8 @@ const std::set<std::string> kOptOperatorSet = {kMomentumOpName,
|
||||||
kLARSUpdateName,
|
kLARSUpdateName,
|
||||||
kPullOpName,
|
kPullOpName,
|
||||||
kCombineMomentumWeightOpName,
|
kCombineMomentumWeightOpName,
|
||||||
kCombineMomentumOpName};
|
kCombineMomentumOpName,
|
||||||
|
kSparseApplyProximalAdagradOpName};
|
||||||
|
|
||||||
const std::set<std::string> kHWSpecialFormatSet = {
|
const std::set<std::string> kHWSpecialFormatSet = {
|
||||||
kOpFormat_FRAC_Z, kOpFormat_NC1KHKWHWC0, kOpFormat_NC1HWC0, kOpFormat_FRAC_NZ,
|
kOpFormat_FRAC_Z, kOpFormat_NC1KHKWHWC0, kOpFormat_NC1HWC0, kOpFormat_FRAC_NZ,
|
||||||
|
|
|
@ -145,6 +145,7 @@ from .sqrt_ds import _sqrt_ds_tbe
|
||||||
from .sparse_apply_ftrl_d import _sparse_apply_ftrl_d
|
from .sparse_apply_ftrl_d import _sparse_apply_ftrl_d
|
||||||
from .sparse_apply_ftrl_d_ds import _sparse_apply_ftrl_d_ds
|
from .sparse_apply_ftrl_d_ds import _sparse_apply_ftrl_d_ds
|
||||||
from .sparse_apply_proximal_adagrad import _sparse_apply_proximal_adagrad
|
from .sparse_apply_proximal_adagrad import _sparse_apply_proximal_adagrad
|
||||||
|
from .sparse_apply_proximal_adagrad_ds import _sparse_apply_proximal_adagrad_ds
|
||||||
from .apply_proximal_adagrad import _apply_proximal_adagrad
|
from .apply_proximal_adagrad import _apply_proximal_adagrad
|
||||||
from .transpose_d import _transpose_d_tbe
|
from .transpose_d import _transpose_d_tbe
|
||||||
from .truncate_div import _truncate_div_tbe
|
from .truncate_div import _truncate_div_tbe
|
||||||
|
|
|
@ -0,0 +1,133 @@
|
||||||
|
# Copyright 2020 Huawei Technologies Co., Ltd
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
# you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
# See the License for the specific language governing permissions and
|
||||||
|
# limitations under the License.
|
||||||
|
# ============================================================================
|
||||||
|
|
||||||
|
"""SparseApplyProximalAdagrad op"""
|
||||||
|
from mindspore.ops.op_info_register import op_info_register, TBERegOp, DataType
|
||||||
|
|
||||||
|
sparse_apply_proximal_adagrad_d_ds_op_info = TBERegOp("SparseApplyProximalAdagrad") \
|
||||||
|
.fusion_type("OPAQUE") \
|
||||||
|
.async_flag(False) \
|
||||||
|
.binfile_name("sparse_apply_proximal_adagrad.so") \
|
||||||
|
.compute_cost(10) \
|
||||||
|
.kernel_name("sparse_apply_proximal_adagrad_d") \
|
||||||
|
.partial_flag(True) \
|
||||||
|
.attr("use_locking", "optional", "bool", "true,false", "false") \
|
||||||
|
.dynamic_shape(True) \
|
||||||
|
.input(0, "var", False, "required", "all") \
|
||||||
|
.input(1, "accum", False, "required", "all") \
|
||||||
|
.input(2, "lr", False, "required", "all") \
|
||||||
|
.input(3, "l1", False, "required", "all") \
|
||||||
|
.input(4, "l2", False, "required", "all") \
|
||||||
|
.input(5, "grad", False, "required", "all") \
|
||||||
|
.input(6, "indices", False, "required", "all") \
|
||||||
|
.output(0, "var", False, "required", "all") \
|
||||||
|
.output(1, "accum", False, "required", "all") \
|
||||||
|
.dtype_format(DataType.F32_NCHW, DataType.F32_NCHW, DataType.F32_NCHW, DataType.F32_NCHW,
|
||||||
|
DataType.F32_NCHW, DataType.F32_NCHW, DataType.I16_NCHW, DataType.F32_NCHW,
|
||||||
|
DataType.F32_NCHW) \
|
||||||
|
.dtype_format(DataType.F32_5HD, DataType.F32_5HD, DataType.F32_5HD, DataType.F32_5HD,
|
||||||
|
DataType.F32_5HD, DataType.F32_5HD, DataType.I16_5HD, DataType.F32_5HD,
|
||||||
|
DataType.F32_5HD) \
|
||||||
|
.dtype_format(DataType.F32_NHWC, DataType.F32_NHWC, DataType.F32_NHWC, DataType.F32_NHWC,
|
||||||
|
DataType.F32_NHWC, DataType.F32_NHWC, DataType.I16_NHWC, DataType.F32_NHWC,
|
||||||
|
DataType.F32_NHWC) \
|
||||||
|
.dtype_format(DataType.F32_Default, DataType.F32_Default, DataType.F32_Default, DataType.F32_Default,
|
||||||
|
DataType.F32_Default, DataType.F32_Default, DataType.I16_Default, DataType.F32_Default,
|
||||||
|
DataType.F32_Default) \
|
||||||
|
.dtype_format(DataType.F32_FracZ, DataType.F32_FracZ, DataType.F32_FracZ, DataType.F32_FracZ,
|
||||||
|
DataType.F32_FracZ, DataType.F32_FracZ, DataType.I16_FracZ, DataType.F32_FracZ,
|
||||||
|
DataType.F32_FracZ) \
|
||||||
|
.dtype_format(DataType.F32_NCHW, DataType.F32_NCHW, DataType.F32_NCHW, DataType.F32_NCHW,
|
||||||
|
DataType.F32_NCHW, DataType.F32_NCHW, DataType.I32_NCHW, DataType.F32_NCHW,
|
||||||
|
DataType.F32_NCHW) \
|
||||||
|
.dtype_format(DataType.F32_5HD, DataType.F32_5HD, DataType.F32_5HD, DataType.F32_5HD,
|
||||||
|
DataType.F32_5HD, DataType.F32_5HD, DataType.I32_5HD, DataType.F32_5HD,
|
||||||
|
DataType.F32_5HD) \
|
||||||
|
.dtype_format(DataType.F32_NHWC, DataType.F32_NHWC, DataType.F32_NHWC, DataType.F32_NHWC,
|
||||||
|
DataType.F32_NHWC, DataType.F32_NHWC, DataType.I32_NHWC, DataType.F32_NHWC,
|
||||||
|
DataType.F32_NHWC) \
|
||||||
|
.dtype_format(DataType.F32_Default, DataType.F32_Default, DataType.F32_Default, DataType.F32_Default,
|
||||||
|
DataType.F32_Default, DataType.F32_Default, DataType.I32_Default, DataType.F32_Default,
|
||||||
|
DataType.F32_Default) \
|
||||||
|
.dtype_format(DataType.F32_FracZ, DataType.F32_FracZ, DataType.F32_FracZ, DataType.F32_FracZ,
|
||||||
|
DataType.F32_FracZ, DataType.F32_FracZ, DataType.I32_FracZ, DataType.F32_FracZ,
|
||||||
|
DataType.F32_FracZ) \
|
||||||
|
.dtype_format(DataType.F32_NCHW, DataType.F32_NCHW, DataType.F32_NCHW, DataType.F32_NCHW,
|
||||||
|
DataType.F32_NCHW, DataType.F32_NCHW, DataType.I64_NCHW, DataType.F32_NCHW,
|
||||||
|
DataType.F32_NCHW) \
|
||||||
|
.dtype_format(DataType.F32_5HD, DataType.F32_5HD, DataType.F32_5HD, DataType.F32_5HD,
|
||||||
|
DataType.F32_5HD, DataType.F32_5HD, DataType.I64_5HD, DataType.F32_5HD,
|
||||||
|
DataType.F32_5HD) \
|
||||||
|
.dtype_format(DataType.F32_NHWC, DataType.F32_NHWC, DataType.F32_NHWC, DataType.F32_NHWC,
|
||||||
|
DataType.F32_NHWC, DataType.F32_NHWC, DataType.I64_NHWC, DataType.F32_NHWC,
|
||||||
|
DataType.F32_NHWC) \
|
||||||
|
.dtype_format(DataType.F32_Default, DataType.F32_Default, DataType.F32_Default, DataType.F32_Default,
|
||||||
|
DataType.F32_Default, DataType.F32_Default, DataType.I64_Default, DataType.F32_Default,
|
||||||
|
DataType.F32_Default) \
|
||||||
|
.dtype_format(DataType.F32_FracZ, DataType.F32_FracZ, DataType.F32_FracZ, DataType.F32_FracZ,
|
||||||
|
DataType.F32_FracZ, DataType.F32_FracZ, DataType.I64_FracZ, DataType.F32_FracZ,
|
||||||
|
DataType.F32_FracZ) \
|
||||||
|
.dtype_format(DataType.F32_NCHW, DataType.F32_NCHW, DataType.F32_NCHW, DataType.F32_NCHW,
|
||||||
|
DataType.F32_NCHW, DataType.F32_NCHW, DataType.U16_NCHW, DataType.F32_NCHW,
|
||||||
|
DataType.F32_NCHW) \
|
||||||
|
.dtype_format(DataType.F32_5HD, DataType.F32_5HD, DataType.F32_5HD, DataType.F32_5HD,
|
||||||
|
DataType.F32_5HD, DataType.F32_5HD, DataType.U16_5HD, DataType.F32_5HD,
|
||||||
|
DataType.F32_5HD) \
|
||||||
|
.dtype_format(DataType.F32_NHWC, DataType.F32_NHWC, DataType.F32_NHWC, DataType.F32_NHWC,
|
||||||
|
DataType.F32_NHWC, DataType.F32_NHWC, DataType.U16_NHWC, DataType.F32_NHWC,
|
||||||
|
DataType.F32_NHWC) \
|
||||||
|
.dtype_format(DataType.F32_Default, DataType.F32_Default, DataType.F32_Default, DataType.F32_Default,
|
||||||
|
DataType.F32_Default, DataType.F32_Default, DataType.U16_Default, DataType.F32_Default,
|
||||||
|
DataType.F32_Default) \
|
||||||
|
.dtype_format(DataType.F32_FracZ, DataType.F32_FracZ, DataType.F32_FracZ, DataType.F32_FracZ,
|
||||||
|
DataType.F32_FracZ, DataType.F32_FracZ, DataType.U16_FracZ, DataType.F32_FracZ,
|
||||||
|
DataType.F32_FracZ) \
|
||||||
|
.dtype_format(DataType.F32_NCHW, DataType.F32_NCHW, DataType.F32_NCHW, DataType.F32_NCHW,
|
||||||
|
DataType.F32_NCHW, DataType.F32_NCHW, DataType.U32_NCHW, DataType.F32_NCHW,
|
||||||
|
DataType.F32_NCHW) \
|
||||||
|
.dtype_format(DataType.F32_5HD, DataType.F32_5HD, DataType.F32_5HD, DataType.F32_5HD,
|
||||||
|
DataType.F32_5HD, DataType.F32_5HD, DataType.U32_5HD, DataType.F32_5HD,
|
||||||
|
DataType.F32_5HD) \
|
||||||
|
.dtype_format(DataType.F32_NHWC, DataType.F32_NHWC, DataType.F32_NHWC, DataType.F32_NHWC,
|
||||||
|
DataType.F32_NHWC, DataType.F32_NHWC, DataType.U32_NHWC, DataType.F32_NHWC,
|
||||||
|
DataType.F32_NHWC) \
|
||||||
|
.dtype_format(DataType.F32_Default, DataType.F32_Default, DataType.F32_Default, DataType.F32_Default,
|
||||||
|
DataType.F32_Default, DataType.F32_Default, DataType.U32_Default, DataType.F32_Default,
|
||||||
|
DataType.F32_Default) \
|
||||||
|
.dtype_format(DataType.F32_FracZ, DataType.F32_FracZ, DataType.F32_FracZ, DataType.F32_FracZ,
|
||||||
|
DataType.F32_FracZ, DataType.F32_FracZ, DataType.U32_FracZ, DataType.F32_FracZ,
|
||||||
|
DataType.F32_FracZ) \
|
||||||
|
.dtype_format(DataType.F32_NCHW, DataType.F32_NCHW, DataType.F32_NCHW, DataType.F32_NCHW,
|
||||||
|
DataType.F32_NCHW, DataType.F32_NCHW, DataType.U64_NCHW, DataType.F32_NCHW,
|
||||||
|
DataType.F32_NCHW) \
|
||||||
|
.dtype_format(DataType.F32_5HD, DataType.F32_5HD, DataType.F32_5HD, DataType.F32_5HD,
|
||||||
|
DataType.F32_5HD, DataType.F32_5HD, DataType.U64_5HD, DataType.F32_5HD,
|
||||||
|
DataType.F32_5HD) \
|
||||||
|
.dtype_format(DataType.F32_NHWC, DataType.F32_NHWC, DataType.F32_NHWC, DataType.F32_NHWC,
|
||||||
|
DataType.F32_NHWC, DataType.F32_NHWC, DataType.U64_NHWC, DataType.F32_NHWC,
|
||||||
|
DataType.F32_NHWC) \
|
||||||
|
.dtype_format(DataType.F32_Default, DataType.F32_Default, DataType.F32_Default, DataType.F32_Default,
|
||||||
|
DataType.F32_Default, DataType.F32_Default, DataType.U64_Default, DataType.F32_Default,
|
||||||
|
DataType.F32_Default) \
|
||||||
|
.dtype_format(DataType.F32_FracZ, DataType.F32_FracZ, DataType.F32_FracZ, DataType.F32_FracZ,
|
||||||
|
DataType.F32_FracZ, DataType.F32_FracZ, DataType.U64_FracZ, DataType.F32_FracZ,
|
||||||
|
DataType.F32_FracZ) \
|
||||||
|
.get_op_info()
|
||||||
|
|
||||||
|
|
||||||
|
@op_info_register(sparse_apply_proximal_adagrad_d_ds_op_info)
|
||||||
|
def _sparse_apply_proximal_adagrad_ds():
|
||||||
|
"""SparseApplyProximalAdagradD TBE register"""
|
||||||
|
return
|
Loading…
Reference in New Issue