Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
magicwindyyd
mindspore
提交
fe8b59f2
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看板
提交
fe8b59f2
编写于
5月 19, 2020
作者:
M
mindspore-ci-bot
提交者:
Gitee
5月 19, 2020
浏览文件
操作
浏览文件
下载
差异文件
!1111 support vm for pack and unpack
Merge pull request !1111 from jiangjinsheng/vm_pack
上级
2e9206e8
f9bd460c
变更
5
显示空白变更内容
内联
并排
Showing
5 changed file
with
150 addition
and
0 deletion
+150
-0
mindspore/ops/_op_impl/tbe/__init__.py
mindspore/ops/_op_impl/tbe/__init__.py
+2
-0
mindspore/ops/_op_impl/tbe/pack.py
mindspore/ops/_op_impl/tbe/pack.py
+57
-0
mindspore/ops/_op_impl/tbe/unpack.py
mindspore/ops/_op_impl/tbe/unpack.py
+56
-0
mindspore/ops/op_info_register.py
mindspore/ops/op_info_register.py
+12
-0
tests/ut/python/ops/test_array_ops.py
tests/ut/python/ops/test_array_ops.py
+23
-0
未找到文件。
mindspore/ops/_op_impl/tbe/__init__.py
浏览文件 @
fe8b59f2
...
...
@@ -182,3 +182,5 @@ from .sgd import sgd_op_info
from
.lars_update
import
lars_update_op_info
from
.bn_training_update_v2
import
_bn_training_update_v2_tbe
from
.square_sum_all
import
square_sum_all_op_info
from
.pack
import
_pack_tbe
from
.unpack
import
_unpack_tbe
mindspore/ops/_op_impl/tbe/pack.py
0 → 100644
浏览文件 @
fe8b59f2
# 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.
# ============================================================================
"""Pack op"""
from
mindspore.ops.op_info_register
import
op_info_register
,
TBERegOp
,
DataType
pack_op_info
=
TBERegOp
(
"Pack"
)
\
.
fusion_type
(
"OPAQUE"
)
\
.
async_flag
(
False
)
\
.
binfile_name
(
"pack.so"
)
\
.
compute_cost
(
10
)
\
.
kernel_name
(
"pack"
)
\
.
partial_flag
(
True
)
\
.
attr
(
"axis"
,
"optional"
,
"int"
,
"all"
)
\
.
input
(
0
,
"x"
,
False
,
"dynamic"
,
"all"
)
\
.
output
(
0
,
"y"
,
False
,
"required"
,
"all"
)
\
.
dtype_format
(
DataType
.
I8_Default
,
DataType
.
I8_Default
)
\
.
dtype_format
(
DataType
.
I16_Default
,
DataType
.
I16_Default
)
\
.
dtype_format
(
DataType
.
I32_Default
,
DataType
.
I32_Default
)
\
.
dtype_format
(
DataType
.
I64_Default
,
DataType
.
I64_Default
)
\
.
dtype_format
(
DataType
.
U8_Default
,
DataType
.
U8_Default
)
\
.
dtype_format
(
DataType
.
U16_Default
,
DataType
.
U16_Default
)
\
.
dtype_format
(
DataType
.
U32_Default
,
DataType
.
U32_Default
)
\
.
dtype_format
(
DataType
.
U64_Default
,
DataType
.
U64_Default
)
\
.
dtype_format
(
DataType
.
F16_Default
,
DataType
.
F16_Default
)
\
.
dtype_format
(
DataType
.
F32_Default
,
DataType
.
F32_Default
)
\
.
dtype_format
(
DataType
.
BOOL_Default
,
DataType
.
BOOL_Default
)
\
.
dtype_format
(
DataType
.
I8_NDHWC
,
DataType
.
I8_NDHWC
)
\
.
dtype_format
(
DataType
.
I16_NDHWC
,
DataType
.
I16_NDHWC
)
\
.
dtype_format
(
DataType
.
I32_NDHWC
,
DataType
.
I32_NDHWC
)
\
.
dtype_format
(
DataType
.
I64_NDHWC
,
DataType
.
I64_NDHWC
)
\
.
dtype_format
(
DataType
.
U8_NDHWC
,
DataType
.
U8_NDHWC
)
\
.
dtype_format
(
DataType
.
U16_NDHWC
,
DataType
.
U16_NDHWC
)
\
.
dtype_format
(
DataType
.
U32_NDHWC
,
DataType
.
U32_NDHWC
)
\
.
dtype_format
(
DataType
.
U64_NDHWC
,
DataType
.
U64_NDHWC
)
\
.
dtype_format
(
DataType
.
F16_NDHWC
,
DataType
.
F16_NDHWC
)
\
.
dtype_format
(
DataType
.
F32_NDHWC
,
DataType
.
F32_NDHWC
)
\
.
dtype_format
(
DataType
.
BOOL_NDHWC
,
DataType
.
BOOL_NDHWC
)
\
.
get_op_info
()
@
op_info_register
(
pack_op_info
)
def
_pack_tbe
():
"""Pack TBE register"""
return
mindspore/ops/_op_impl/tbe/unpack.py
0 → 100644
浏览文件 @
fe8b59f2
# 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.
# ============================================================================
"""Unpack op"""
from
mindspore.ops.op_info_register
import
op_info_register
,
TBERegOp
,
DataType
unpack_op_info
=
TBERegOp
(
"Unpack"
)
\
.
fusion_type
(
"OPAQUE"
)
\
.
async_flag
(
False
)
\
.
binfile_name
(
"unpack.so"
)
\
.
compute_cost
(
10
)
\
.
kernel_name
(
"unpack"
)
\
.
partial_flag
(
True
)
\
.
attr
(
"num"
,
"optional"
,
"int"
,
"all"
)
\
.
attr
(
"axis"
,
"required"
,
"int"
,
"all"
)
\
.
input
(
0
,
"x"
,
False
,
"required"
,
"all"
)
\
.
output
(
0
,
"y"
,
False
,
"dynamic"
,
"all"
)
\
.
dtype_format
(
DataType
.
I8_Default
,
DataType
.
I8_Default
)
\
.
dtype_format
(
DataType
.
I16_Default
,
DataType
.
I16_Default
)
\
.
dtype_format
(
DataType
.
I32_Default
,
DataType
.
I32_Default
)
\
.
dtype_format
(
DataType
.
I64_Default
,
DataType
.
I64_Default
)
\
.
dtype_format
(
DataType
.
U8_Default
,
DataType
.
U8_Default
)
\
.
dtype_format
(
DataType
.
U16_Default
,
DataType
.
U16_Default
)
\
.
dtype_format
(
DataType
.
U32_Default
,
DataType
.
U32_Default
)
\
.
dtype_format
(
DataType
.
U64_Default
,
DataType
.
U64_Default
)
\
.
dtype_format
(
DataType
.
F16_Default
,
DataType
.
F16_Default
)
\
.
dtype_format
(
DataType
.
F32_Default
,
DataType
.
F32_Default
)
\
.
dtype_format
(
DataType
.
I8_5HD
,
DataType
.
I8_5HD
)
\
.
dtype_format
(
DataType
.
I16_5HD
,
DataType
.
I16_5HD
)
\
.
dtype_format
(
DataType
.
I32_5HD
,
DataType
.
I32_5HD
)
\
.
dtype_format
(
DataType
.
I64_5HD
,
DataType
.
I64_5HD
)
\
.
dtype_format
(
DataType
.
U8_5HD
,
DataType
.
U8_5HD
)
\
.
dtype_format
(
DataType
.
U16_5HD
,
DataType
.
U16_5HD
)
\
.
dtype_format
(
DataType
.
U32_5HD
,
DataType
.
U32_5HD
)
\
.
dtype_format
(
DataType
.
U64_5HD
,
DataType
.
U64_5HD
)
\
.
dtype_format
(
DataType
.
F16_5HD
,
DataType
.
F16_5HD
)
\
.
dtype_format
(
DataType
.
F32_5HD
,
DataType
.
F32_5HD
)
\
.
get_op_info
()
@
op_info_register
(
unpack_op_info
)
def
_unpack_tbe
():
"""Unpack TBE register"""
return
mindspore/ops/op_info_register.py
浏览文件 @
fe8b59f2
...
...
@@ -499,6 +499,7 @@ class DataType:
BOOL_NCHW
=
(
"bool"
,
"NCHW"
)
BOOL_NHWC
=
(
"bool"
,
"NHWC"
)
BOOL_HWCN
=
(
"bool"
,
"HWCN"
)
BOOL_NDHWC
=
(
"bool"
,
"NDHWC"
)
I8_None
=
(
"int8"
,
""
)
I8_Default
=
(
"int8"
,
"DefaultFormat"
)
...
...
@@ -509,6 +510,7 @@ class DataType:
I8_NCHW
=
(
"int8"
,
"NCHW"
)
I8_NHWC
=
(
"int8"
,
"NHWC"
)
I8_HWCN
=
(
"int8"
,
"HWCN"
)
I8_NDHWC
=
(
"int8"
,
"NDHWC"
)
U8_None
=
(
"uint8"
,
""
)
U8_Default
=
(
"uint8"
,
"DefaultFormat"
)
...
...
@@ -519,6 +521,7 @@ class DataType:
U8_NCHW
=
(
"uint8"
,
"NCHW"
)
U8_NHWC
=
(
"uint8"
,
"NHWC"
)
U8_HWCN
=
(
"uint8"
,
"HWCN"
)
U8_NDHWC
=
(
"uint8"
,
"NDHWC"
)
I16_None
=
(
"int16"
,
""
)
I16_Default
=
(
"int16"
,
"DefaultFormat"
)
...
...
@@ -529,6 +532,7 @@ class DataType:
I16_NCHW
=
(
"int16"
,
"NCHW"
)
I16_NHWC
=
(
"int16"
,
"NHWC"
)
I16_HWCN
=
(
"int16"
,
"HWCN"
)
I16_NDHWC
=
(
"int16"
,
"NDHWC"
)
U16_None
=
(
"uint16"
,
""
)
U16_Default
=
(
"uint16"
,
"DefaultFormat"
)
...
...
@@ -539,6 +543,7 @@ class DataType:
U16_NCHW
=
(
"uint16"
,
"NCHW"
)
U16_NHWC
=
(
"uint16"
,
"NHWC"
)
U16_HWCN
=
(
"uint16"
,
"HWCN"
)
U16_NDHWC
=
(
"uint16"
,
"NDHWC"
)
I32_None
=
(
"int32"
,
""
)
I32_Default
=
(
"int32"
,
"DefaultFormat"
)
...
...
@@ -549,6 +554,7 @@ class DataType:
I32_NCHW
=
(
"int32"
,
"NCHW"
)
I32_NHWC
=
(
"int32"
,
"NHWC"
)
I32_HWCN
=
(
"int32"
,
"HWCN"
)
I32_NDHWC
=
(
"int32"
,
"NDHWC"
)
U32_None
=
(
"uint32"
,
""
)
U32_Default
=
(
"uint32"
,
"DefaultFormat"
)
...
...
@@ -559,6 +565,7 @@ class DataType:
U32_NCHW
=
(
"uint32"
,
"NCHW"
)
U32_NHWC
=
(
"uint32"
,
"NHWC"
)
U32_HWCN
=
(
"uint32"
,
"HWCN"
)
U32_NDHWC
=
(
"uint32"
,
"NDHWC"
)
I64_None
=
(
"int64"
,
""
)
I64_Default
=
(
"int64"
,
"DefaultFormat"
)
...
...
@@ -569,6 +576,7 @@ class DataType:
I64_NCHW
=
(
"int64"
,
"NCHW"
)
I64_NHWC
=
(
"int64"
,
"NHWC"
)
I64_HWCN
=
(
"int64"
,
"HWCN"
)
I64_NDHWC
=
(
"int64"
,
"NDHWC"
)
U64_None
=
(
"uint64"
,
""
)
U64_Default
=
(
"uint64"
,
"DefaultFormat"
)
...
...
@@ -579,6 +587,7 @@ class DataType:
U64_NCHW
=
(
"uint64"
,
"NCHW"
)
U64_NHWC
=
(
"uint64"
,
"NHWC"
)
U64_HWCN
=
(
"uint64"
,
"HWCN"
)
U64_NDHWC
=
(
"uint64"
,
"NDHWC"
)
F16_None
=
(
"float16"
,
""
)
F16_Default
=
(
"float16"
,
"DefaultFormat"
)
...
...
@@ -589,6 +598,7 @@ class DataType:
F16_NCHW
=
(
"float16"
,
"NCHW"
)
F16_NHWC
=
(
"float16"
,
"NHWC"
)
F16_HWCN
=
(
"float16"
,
"HWCN"
)
F16_NDHWC
=
(
"float16"
,
"NDHWC"
)
F32_None
=
(
"float32"
,
""
)
F32_Default
=
(
"float32"
,
"DefaultFormat"
)
...
...
@@ -599,6 +609,7 @@ class DataType:
F32_NCHW
=
(
"float32"
,
"NCHW"
)
F32_NHWC
=
(
"float32"
,
"NHWC"
)
F32_HWCN
=
(
"float32"
,
"HWCN"
)
F32_NDHWC
=
(
"float32"
,
"NDHWC"
)
F64_None
=
(
"float64"
,
""
)
F64_Default
=
(
"float64"
,
"DefaultFormat"
)
...
...
@@ -609,3 +620,4 @@ class DataType:
F64_NCHW
=
(
"float64"
,
"NCHW"
)
F64_NHWC
=
(
"float64"
,
"NHWC"
)
F64_HWCN
=
(
"float64"
,
"HWCN"
)
F64_NDHWC
=
(
"float64"
,
"NDHWC"
)
tests/ut/python/ops/test_array_ops.py
浏览文件 @
fe8b59f2
...
...
@@ -227,6 +227,23 @@ class SpaceToBatchNet(Cell):
return
self
.
space_to_batch
(
x
)
class
PackNet
(
Cell
):
def
__init__
(
self
):
super
(
PackNet
,
self
).
__init__
()
self
.
pack
=
P
.
Pack
()
def
construct
(
self
,
x
):
return
self
.
pack
((
x
,
x
))
class
UnpackNet
(
Cell
):
def
__init__
(
self
):
super
(
UnpackNet
,
self
).
__init__
()
self
.
unpack
=
P
.
Unpack
()
def
construct
(
self
,
x
):
return
self
.
unpack
(
x
)
test_case_array_ops
=
[
(
'CustNet1'
,
{
'block'
:
CustNet1
(),
...
...
@@ -249,6 +266,12 @@ test_case_array_ops = [
(
'SpaceToBatchNet'
,
{
'block'
:
SpaceToBatchNet
(),
'desc_inputs'
:
[
Tensor
(
np
.
array
([[[[
1
,
2
],
[
3
,
4
]]]]).
astype
(
np
.
float16
))]}),
(
'PackNet'
,
{
'block'
:
PackNet
(),
'desc_inputs'
:
[
Tensor
(
np
.
array
([[[
1
,
2
],
[
3
,
4
]]]).
astype
(
np
.
float16
))]}),
(
'UnpackNet'
,
{
'block'
:
UnpackNet
(),
'desc_inputs'
:
[
Tensor
(
np
.
array
([[
1
,
2
],
[
3
,
4
]]).
astype
(
np
.
float16
))]}),
]
test_case_lists
=
[
test_case_array_ops
]
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录