Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
magicwindyyd
mindspore
提交
d3ea1e42
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看板
提交
d3ea1e42
编写于
6月 18, 2020
作者:
W
WilliamLian
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix code review
上级
60de9089
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
11 addition
and
3 deletion
+11
-3
mindspore/ccsrc/pre_activate/ascend/format_type/deal_ref_trans_and_cast.cc
...re_activate/ascend/format_type/deal_ref_trans_and_cast.cc
+11
-3
未找到文件。
mindspore/ccsrc/pre_activate/ascend/format_type/deal_ref_trans_and_cast.cc
浏览文件 @
d3ea1e42
...
...
@@ -31,8 +31,9 @@ session::KernelWithIndex FindRefOriginNode(const AnfNodePtr &node) {
session
::
KernelWithIndex
kernel_with_index
=
AnfAlgo
::
VisitKernel
(
node
,
0
);
AnfNodePtr
cur_node
=
kernel_with_index
.
first
;
size_t
cur_out_index
=
kernel_with_index
.
second
;
MS_EXCEPTION_IF_NULL
(
cur_node
);
if
(
cur_node
->
isa
<
CNode
>
())
{
auto
cnode
=
node
->
cast
<
CNodePtr
>
();
auto
cnode
=
cur_
node
->
cast
<
CNodePtr
>
();
MS_EXCEPTION_IF_NULL
(
cnode
);
std
::
string
op_name
=
AnfAlgo
::
GetCNodeName
(
cnode
);
auto
op_info
=
mindspore
::
kernel
::
OpLib
::
FindOp
(
op_name
,
kernel
::
kTBE
);
...
...
@@ -88,7 +89,7 @@ AnfNodePtr AddAdditionalToRefOutput(const FuncGraphPtr &func_graph, const CNodeP
size_t
input_index
,
const
AnfNodePtr
&
get_item
)
{
AnfNodePtr
final_node
=
(
get_item
==
nullptr
?
cnode
:
get_item
);
size_t
final_index
=
output_index
;
AnfNodePtr
input_node
=
cnode
->
input
(
input_index
+
1
);
AnfNodePtr
input_node
=
AnfAlgo
::
GetInputNode
(
cnode
,
input_index
);
session
::
KernelWithIndex
origin_pair
;
origin_pair
=
FindRefOriginNode
(
input_node
);
MS_EXCEPTION_IF_NULL
(
origin_pair
.
first
);
...
...
@@ -133,6 +134,7 @@ AnfNodePtr AddAdditionalToRefOutput(const FuncGraphPtr &func_graph, const CNodeP
}
AnfNodePtr
DealRefForMultipleOutput
(
const
FuncGraphPtr
&
func_graph
,
const
CNodePtr
&
cnode
,
const
std
::
shared_ptr
<
kernel
::
OpInfo
>
&
op_info
)
{
MS_EXCEPTION_IF_NULL
(
op_info
);
auto
ref_infos
=
op_info
->
ref_infos
();
std
::
vector
<
AnfNodePtr
>
make_tuple_inputs
;
AbstractBasePtrList
abstract_list
;
...
...
@@ -144,9 +146,11 @@ AnfNodePtr DealRefForMultipleOutput(const FuncGraphPtr &func_graph, const CNodeP
auto
input_index
=
ref_infos
.
at
(
output_index
);
final_node
=
AddAdditionalToRefOutput
(
func_graph
,
cnode
,
output_index
,
input_index
,
final_node
);
}
MS_EXCEPTION_IF_NULL
(
final_node
);
abstract_list
.
push_back
(
final_node
->
abstract
());
make_tuple_inputs
.
push_back
(
final_node
);
}
MS_EXCEPTION_IF_NULL
(
func_graph
);
AnfNodePtr
make_tuple
=
func_graph
->
NewCNode
(
make_tuple_inputs
);
MS_EXCEPTION_IF_NULL
(
make_tuple
);
make_tuple
->
set_abstract
(
std
::
make_shared
<
abstract
::
AbstractTuple
>
(
abstract_list
));
...
...
@@ -155,6 +159,8 @@ AnfNodePtr DealRefForMultipleOutput(const FuncGraphPtr &func_graph, const CNodeP
AnfNodePtr
DealRefSigleOutput
(
const
FuncGraphPtr
&
func_graph
,
const
CNodePtr
&
cnode
,
const
std
::
shared_ptr
<
kernel
::
OpInfo
>
&
op_info
)
{
MS_EXCEPTION_IF_NULL
(
cnode
);
MS_EXCEPTION_IF_NULL
(
op_info
);
auto
ref_infos
=
op_info
->
ref_infos
();
for
(
const
auto
&
ref_info
:
ref_infos
)
{
if
(
ref_info
.
second
>
cnode
->
inputs
().
size
())
{
...
...
@@ -206,7 +212,9 @@ const AnfNodePtr DealRefTransAndCast::Process(const FuncGraphPtr &graph, const A
return
nullptr
;
}
if
(
op_info
->
is_ref
())
{
if
(
!
cnode
->
Type
()
->
isa
<
Tuple
>
())
{
auto
type
=
cnode
->
Type
();
MS_EXCEPTION_IF_NULL
(
type
);
if
(
!
type
->
isa
<
Tuple
>
())
{
return
DealRefSigleOutput
(
graph
,
cnode
,
op_info
);
}
else
{
return
DealRefForMultipleOutput
(
graph
,
cnode
,
op_info
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录