Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
magicwindyyd
mindspore
提交
8674e0ad
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看板
提交
8674e0ad
编写于
4月 14, 2020
作者:
M
mindspore-ci-bot
提交者:
Gitee
4月 14, 2020
浏览文件
操作
浏览文件
下载
差异文件
!288 fix nopnode output bug
Merge pull request !288 from kisnwang/fix-nopnode-output-bug
上级
94589ce6
ae675c5c
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
9 addition
and
6 deletion
+9
-6
mindspore/ccsrc/device/kernel_runtime.cc
mindspore/ccsrc/device/kernel_runtime.cc
+1
-1
mindspore/ccsrc/session/anf_runtime_algorithm.cc
mindspore/ccsrc/session/anf_runtime_algorithm.cc
+7
-5
mindspore/ccsrc/session/anf_runtime_algorithm.h
mindspore/ccsrc/session/anf_runtime_algorithm.h
+1
-0
未找到文件。
mindspore/ccsrc/device/kernel_runtime.cc
浏览文件 @
8674e0ad
...
...
@@ -250,7 +250,7 @@ void KernelRuntime::AssignStaticMemoryOutput(const session::KernelGraph *graph)
MS_EXCEPTION_IF_NULL
(
graph
);
auto
nodes
=
AnfAlgo
::
GetAllOutput
(
graph
->
output
(),
{
prim
::
kPrimTupleGetItem
});
for
(
const
auto
&
node
:
nodes
)
{
auto
item_with_index
=
AnfAlgo
::
VisitKernelWithReturnType
(
node
,
0
);
auto
item_with_index
=
AnfAlgo
::
VisitKernelWithReturnType
(
node
,
0
,
true
);
MS_EXCEPTION_IF_NULL
(
item_with_index
.
first
);
if
(
!
item_with_index
.
first
->
isa
<
CNode
>
()
||
!
AnfAlgo
::
IsRealKernel
(
item_with_index
.
first
))
{
continue
;
...
...
mindspore/ccsrc/session/anf_runtime_algorithm.cc
浏览文件 @
8674e0ad
...
...
@@ -84,6 +84,7 @@ KernelWithIndex AnfRuntimeAlgorithm::VisitKernel(const AnfNodePtr &anf_node, siz
}
KernelWithIndex
AnfRuntimeAlgorithm
::
VisitKernelWithReturnType
(
const
AnfNodePtr
&
anf_node
,
size_t
index
,
bool
visit_nop_node
,
const
std
::
vector
<
PrimitivePtr
>
&
return_types
)
{
MS_EXCEPTION_IF_NULL
(
anf_node
);
for
(
const
auto
&
prim_type
:
return_types
)
{
...
...
@@ -109,12 +110,13 @@ KernelWithIndex AnfRuntimeAlgorithm::VisitKernelWithReturnType(const AnfNodePtr
auto
value_node
=
input2
->
cast
<
ValueNodePtr
>
();
MS_EXCEPTION_IF_NULL
(
value_node
);
int
item_idx
=
GetValue
<
int
>
(
value_node
->
value
());
return
VisitKernelWithReturnType
(
cnode
->
input
(
kRealInputNodeIndexInTupleGetItem
),
IntToSize
(
item_idx
));
return
VisitKernelWithReturnType
(
cnode
->
input
(
kRealInputNodeIndexInTupleGetItem
),
IntToSize
(
item_idx
),
visit_nop_node
);
}
else
if
(
IsPrimitive
(
input0
,
prim
::
kPrimDepend
)
||
IsPrimitive
(
input0
,
prim
::
kPrimControlDepend
))
{
return
VisitKernelWithReturnType
(
cnode
->
input
(
kRealInputIndexInDepend
),
0
);
}
else
if
(
opt
::
IsNopNode
(
cnode
))
{
return
VisitKernelWithReturnType
(
cnode
->
input
(
kRealInputIndexInDepend
),
0
,
visit_nop_node
);
}
else
if
(
opt
::
IsNopNode
(
cnode
)
&&
visit_nop_node
)
{
if
(
cnode
->
inputs
().
size
()
==
2
)
{
return
VisitKernelWithReturnType
(
cnode
->
input
(
1
),
0
);
return
VisitKernelWithReturnType
(
cnode
->
input
(
1
),
0
,
visit_nop_node
);
}
else
{
MS_LOG
(
EXCEPTION
)
<<
cnode
->
DebugString
()
<<
"Invalid nop node"
;
}
...
...
@@ -132,7 +134,7 @@ std::vector<AnfNodePtr> AnfRuntimeAlgorithm::GetAllOutput(const AnfNodePtr &node
auto
return_prim_type
=
return_types
;
// if visited make_tuple should return back
return_prim_type
.
push_back
(
prim
::
kPrimMakeTuple
);
auto
item_with_index
=
AnfAlgo
::
VisitKernelWithReturnType
(
node
,
0
,
return_prim_type
);
auto
item_with_index
=
AnfAlgo
::
VisitKernelWithReturnType
(
node
,
0
,
false
,
return_prim_type
);
if
(
AnfAlgo
::
CheckPrimitiveType
(
item_with_index
.
first
,
prim
::
kPrimMakeTuple
))
{
MS_EXCEPTION_IF_NULL
(
item_with_index
.
first
);
auto
make_tuple
=
item_with_index
.
first
->
cast
<
CNodePtr
>
();
...
...
mindspore/ccsrc/session/anf_runtime_algorithm.h
浏览文件 @
8674e0ad
...
...
@@ -41,6 +41,7 @@ class AnfRuntimeAlgorithm {
// get input_anf_node's real kernel by recurse
static
KernelWithIndex
VisitKernel
(
const
AnfNodePtr
&
input_anf_node
,
size_t
output_index
);
static
KernelWithIndex
VisitKernelWithReturnType
(
const
AnfNodePtr
&
input_anf_node
,
size_t
output_index
,
bool
visit_nop_node
=
false
,
const
std
::
vector
<
PrimitivePtr
>
&
return_types
=
{
prim
::
kPrimMakeTuple
});
static
std
::
vector
<
AnfNodePtr
>
GetAllOutput
(
const
AnfNodePtr
&
node
,
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录