Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
magicwindyyd
mindspore
提交
97fbc92f
M
mindspore
项目概览
magicwindyyd
/
mindspore
与 Fork 源项目一致
Fork自
MindSpore / mindspore
通知
1
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
M
mindspore
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
97fbc92f
编写于
5月 26, 2020
作者:
M
mindspore-ci-bot
提交者:
Gitee
5月 26, 2020
浏览文件
操作
浏览文件
下载
差异文件
!1450 add scatter add vm
Merge pull request !1450 from zhaozhenlong/op/scatter-add-vm
上级
0aa95098
55d19275
变更
5
隐藏空白更改
内联
并排
Showing
5 changed file
with
119 addition
and
7 deletion
+119
-7
mindspore/ops/_op_impl/tbe/__init__.py
mindspore/ops/_op_impl/tbe/__init__.py
+1
-0
mindspore/ops/_op_impl/tbe/scatter_add.py
mindspore/ops/_op_impl/tbe/scatter_add.py
+40
-0
mindspore/ops/operations/__init__.py
mindspore/ops/operations/__init__.py
+2
-1
mindspore/ops/operations/array_ops.py
mindspore/ops/operations/array_ops.py
+52
-6
tests/ut/python/ops/test_ops.py
tests/ut/python/ops/test_ops.py
+24
-0
未找到文件。
mindspore/ops/_op_impl/tbe/__init__.py
浏览文件 @
97fbc92f
...
...
@@ -198,3 +198,4 @@ from .apply_rms_prop import _apply_rms_prop_tbe
from
.cumprod
import
_cumprop_tbe
from
.reduce_prod
import
_reduce_prod_tbe
from
.flatten_grad
import
_flatten_grad_tbe
from
.scatter_add
import
_scatter_add_tbe
mindspore/ops/_op_impl/tbe/scatter_add.py
0 → 100644
浏览文件 @
97fbc92f
# 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.
# ============================================================================
"""ScatterAdd op"""
from
mindspore.ops.op_info_register
import
op_info_register
,
TBERegOp
,
DataType
scatter_add_op_info
=
TBERegOp
(
"ScatterAdd"
)
\
.
fusion_type
(
"ELEMWISE"
)
\
.
async_flag
(
False
)
\
.
binfile_name
(
"scatter_add.so"
)
\
.
compute_cost
(
10
)
\
.
kernel_name
(
"scatter_add"
)
\
.
partial_flag
(
True
)
\
.
attr
(
"use_locking"
,
"optional"
,
"bool"
,
"all"
)
\
.
input
(
0
,
"var"
,
False
,
"required"
,
"all"
)
\
.
input
(
1
,
"indices"
,
False
,
"required"
,
"all"
)
\
.
input
(
2
,
"updates"
,
False
,
"required"
,
"all"
)
\
.
output
(
0
,
"var"
,
False
,
"required"
,
"all"
)
\
.
dtype_format
(
DataType
.
F16_Default
,
DataType
.
I32_Default
,
DataType
.
F16_Default
,
DataType
.
F16_Default
)
\
.
dtype_format
(
DataType
.
F32_Default
,
DataType
.
I32_Default
,
DataType
.
F32_Default
,
DataType
.
F32_Default
)
\
.
dtype_format
(
DataType
.
I32_Default
,
DataType
.
I32_Default
,
DataType
.
I32_Default
,
DataType
.
I32_Default
)
\
.
get_op_info
()
@
op_info_register
(
scatter_add_op_info
)
def
_scatter_add_tbe
():
"""ScatterAdd TBE register"""
return
mindspore/ops/operations/__init__.py
浏览文件 @
97fbc92f
...
...
@@ -24,7 +24,7 @@ from .array_ops import (Argmax, Argmin, Cast, Concat, Pack, Unpack,
Fill
,
GatherNd
,
GatherV2
,
InvertPermutation
,
IsInstance
,
IsSubClass
,
ArgMaxWithValue
,
OnesLike
,
ZerosLike
,
Rank
,
Reshape
,
ResizeNearestNeighbor
,
ArgMinWithValue
,
Range
,
SameTypeShape
,
ScatterMax
,
ScatterUpdate
,
SameTypeShape
,
Scatter
Add
,
Scatter
Max
,
ScatterUpdate
,
ScalarToArray
,
ScalarToTensor
,
ScatterNd
,
ScatterNdUpdate
,
Select
,
Shape
,
Size
,
Slice
,
Split
,
Squeeze
,
StridedSlice
,
Tile
,
...
...
@@ -190,6 +190,7 @@ __all__ = [
'BoundingBoxEncode'
,
'BoundingBoxDecode'
,
'L2Normalize'
,
'ScatterAdd'
,
'ScatterNd'
,
'ScatterMax'
,
'ResizeNearestNeighbor'
,
...
...
mindspore/ops/operations/array_ops.py
浏览文件 @
97fbc92f
...
...
@@ -2145,6 +2145,12 @@ class ScatterNdUpdate(PrimitiveWithInfer):
validator
.
check_tensor_type_same
(
args
,
(
mstype
.
bool_
,)
+
mstype
.
number_type
,
self
.
name
)
return
x_dtype
def
_check_scatter_shape
(
x_shape
,
indices_shape
,
updates_shape
,
prim_name
):
if
updates_shape
and
updates_shape
!=
indices_shape
+
x_shape
[
1
:]:
raise
ValueError
(
f
"For '
{
prim_name
}
', the shape of updates should be [] or "
f
"updates_shape = indices_shape + x_shape[1:], but got x_shape:
{
x_shape
}
, "
f
"indices_shape:
{
indices_shape
}
, updates_shape:
{
updates_shape
}
."
)
class
ScatterMax
(
PrimitiveWithInfer
):
"""
...
...
@@ -2158,8 +2164,8 @@ class ScatterMax(PrimitiveWithInfer):
Inputs:
- **input_x** (Parameter) - The target parameter.
- **indices** (Tensor) - The index to do max operation whose data type should be int.
- **updates** (Tensor) - The tensor doing the maximum operation with
'input_x'
,
the data type is same as
'input_x', the shape is 'indices_shape + x_shape[1:]'
.
- **updates** (Tensor) - The tensor doing the maximum operation with
`input_x`
,
the data type is same as
`input_x`, the shape is `indices_shape + x_shape[1:]`
.
Outputs:
Tensor, has the same shape and data type as `input_x`.
...
...
@@ -2180,10 +2186,7 @@ class ScatterMax(PrimitiveWithInfer):
validator
.
check_value_type
(
'use_locking'
,
use_locking
,
(
bool
,),
self
.
name
)
def
infer_shape
(
self
,
x_shape
,
indices_shape
,
updates_shape
):
if
updates_shape
and
updates_shape
!=
indices_shape
+
x_shape
[
1
:]:
raise
ValueError
(
f
"For '
{
self
.
name
}
', the shape of update should be [] or "
f
"update_shape = indices_shape + x_shape[1:], but got x_shape:
{
x_shape
}
, "
f
"indices_shape:
{
indices_shape
}
, update_shape:
{
updates_shape
}
."
)
_check_scatter_shape
(
x_shape
,
indices_shape
,
updates_shape
,
self
.
name
)
return
x_shape
def
infer_dtype
(
self
,
x_dtype
,
indices_dtype
,
updates_dtype
):
...
...
@@ -2193,6 +2196,49 @@ class ScatterMax(PrimitiveWithInfer):
return
x_dtype
class
ScatterAdd
(
PrimitiveWithInfer
):
"""
Update the value of the input tensor through the add operation.
Using given values to update tensor value through the add operation, along with the input indices.
Args:
use_locking (bool): Whether protect the assignment by a lock. Default: False.
Inputs:
- **input_x** (Parameter) - The target parameter.
- **indices** (Tensor) - The index to do add operation whose data type should be int.
- **updates** (Tensor) - The tensor doing the add operation with `input_x`,
the data type is same as `input_x`, the shape is `indices_shape + x_shape[1:]`.
Outputs:
Tensor, has the same shape and data type as `input_x`.
Examples:
>>> input_x = Parameter(Tensor(np.array([[0.0, 0.0, 0.0], [0.0, 0.0, 0.0]]), mindspore.float32), name="x")
>>> indices = Tensor(np.array([[0, 1], [1, 1]]), mindspore.int32)
>>> updates = Tensor(np.ones([2, 2, 3]), mindspore.float32)
>>> scatter_add = P.ScatterAdd()
>>> output = scatter_add(input_x, indices, updates)
[[1.0, 1.0, 1.0], [3.0, 3.0, 3.0]]
"""
@
prim_attr_register
def
__init__
(
self
,
use_locking
=
False
):
"""Init ScatterAdd"""
validator
.
check_value_type
(
'use_locking'
,
use_locking
,
(
bool
,),
self
.
name
)
def
infer_shape
(
self
,
x_shape
,
indices_shape
,
updates_shape
):
_check_scatter_shape
(
x_shape
,
indices_shape
,
updates_shape
,
self
.
name
)
return
x_shape
def
infer_dtype
(
self
,
x_dtype
,
indices_dtype
,
updates_dtype
):
validator
.
check_tensor_type_same
({
'indices'
:
indices_dtype
},
mstype
.
int_type
,
self
.
name
)
args
=
{
'x'
:
x_dtype
,
'updates'
:
updates_dtype
}
validator
.
check_tensor_type_same
(
args
,
mstype
.
number_type
,
self
.
name
)
return
x_dtype
class
SpaceToDepth
(
PrimitiveWithInfer
):
r
"""
Rearrange blocks of spatial data into depth.
...
...
tests/ut/python/ops/test_ops.py
浏览文件 @
97fbc92f
...
...
@@ -196,6 +196,19 @@ class ScatterMax(nn.Cell):
return
out
class
ScatterAdd
(
nn
.
Cell
):
"""ScatterAdd net definition"""
def
__init__
(
self
,
ref_shape
):
super
(
ScatterAdd
,
self
).
__init__
()
self
.
scatter_add
=
P
.
ScatterAdd
()
self
.
ref
=
Parameter
(
Tensor
(
np
.
ones
(
ref_shape
,
np
.
float32
)),
name
=
"ref"
)
def
construct
(
self
,
indices
,
updates
):
out
=
self
.
scatter_add
(
self
.
ref
,
indices
,
updates
)
return
out
class
ApplyFtrlNet
(
nn
.
Cell
):
def
__init__
(
self
):
super
(
ApplyFtrlNet
,
self
).
__init__
()
...
...
@@ -1257,6 +1270,17 @@ test_case_other_ops = [
'desc_inputs'
:
(
Tensor
(
np
.
array
([[
0
,
0
],
[
1
,
1
]],
np
.
int32
)),
Tensor
(
np
.
ones
([
2
,
2
,
3
],
np
.
float32
)
*
99
)),
'skip'
:
[
'backward'
]}),
(
'ScatterAdd'
,
{
'block'
:
ScatterAdd
((
6
,)),
'desc_inputs'
:
(
Tensor
(
np
.
array
([
2
,
0
,
5
],
np
.
int32
)),
Tensor
(
np
.
array
([
2.0
,
3.0
,
4.0
],
np
.
float32
))),
'skip'
:
[
'backward'
]}),
(
'ScatterAdd2d'
,
{
'block'
:
ScatterAdd
((
3
,
4
)),
'desc_inputs'
:
(
Tensor
(
np
.
array
([[
0
,
1
],
[
1
,
2
]],
np
.
int32
)),
Tensor
(
np
.
array
([[[
1
,
1
,
1
,
1
],
[
2
,
2
,
2
,
2
]],
[[
3
,
3
,
3
,
3
],
[
4
,
4
,
4
,
4
]]],
np
.
float32
))),
'skip'
:
[
'backward'
]}),
(
'SmoothL1Loss'
,
{
'block'
:
P
.
SmoothL1Loss
(),
'desc_inputs'
:
[[
256
,
4
],
[
256
,
4
]],
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录