Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
机器未来
Paddle
提交
d4ca7ffb
P
Paddle
项目概览
机器未来
/
Paddle
与 Fork 源项目一致
Fork自
PaddlePaddle / Paddle
通知
1
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
P
Paddle
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
未验证
提交
d4ca7ffb
编写于
8月 05, 2022
作者:
Z
Zhen Wang
提交者:
GitHub
8月 05, 2022
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Add feed&fetch as default deny ops. (#44708)
上级
d0cf9d9d
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
10 addition
and
6 deletion
+10
-6
paddle/fluid/framework/paddle2cinn/build_cinn_pass.cc
paddle/fluid/framework/paddle2cinn/build_cinn_pass.cc
+10
-6
未找到文件。
paddle/fluid/framework/paddle2cinn/build_cinn_pass.cc
浏览文件 @
d4ca7ffb
...
@@ -62,6 +62,8 @@ const std::unordered_map<std::string, std::unordered_set<std::string>>
...
@@ -62,6 +62,8 @@ const std::unordered_map<std::string, std::unordered_set<std::string>>
kDenyParamMap
=
{{
"batch_norm"
,
{
"ReserveSpace"
}},
kDenyParamMap
=
{{
"batch_norm"
,
{
"ReserveSpace"
}},
{
"batch_norm_grad"
,
{
"ReserveSpace"
}}};
{
"batch_norm_grad"
,
{
"ReserveSpace"
}}};
const
std
::
unordered_set
<
std
::
string
>
kDefaultDenyOps
=
{
"feed"
,
"fetch"
};
std
::
unordered_set
<
std
::
string
>
GetDenyVarNames
(
const
GraphNodeSet
&
cluster
)
{
std
::
unordered_set
<
std
::
string
>
GetDenyVarNames
(
const
GraphNodeSet
&
cluster
)
{
std
::
unordered_set
<
std
::
string
>
deny_var_set
;
std
::
unordered_set
<
std
::
string
>
deny_var_set
;
...
@@ -560,22 +562,24 @@ void SearchAllSubgraphs(Graph* graph) {
...
@@ -560,22 +562,24 @@ void SearchAllSubgraphs(Graph* graph) {
auto
allow_ops
=
StringSplit
(
FLAGS_allow_cinn_ops
,
kDelim
);
auto
allow_ops
=
StringSplit
(
FLAGS_allow_cinn_ops
,
kDelim
);
auto
deny_ops
=
StringSplit
(
FLAGS_deny_cinn_ops
,
kDelim
);
auto
deny_ops
=
StringSplit
(
FLAGS_deny_cinn_ops
,
kDelim
);
auto
teller
=
[
&
allow_ops
,
&
deny_ops
](
const
Node
*
node
)
{
auto
teller
=
[
&
allow_ops
,
&
deny_ops
](
const
Node
*
node
)
{
const
auto
&
node_name
=
node
->
Name
();
bool
registered
=
::
cinn
::
frontend
::
OpMapperRegistry
::
Global
()
->
Find
(
bool
registered
=
::
cinn
::
frontend
::
OpMapperRegistry
::
Global
()
->
Find
(
node
->
Name
()
)
!=
nullptr
;
node
_name
)
!=
nullptr
;
// if the op type is registered in CINN and allow_ops is not empty, return
// if the op type is registered in CINN and allow_ops is not empty, return
// true only when it is in allow_ops
// true only when it is in allow_ops
if
(
allow_ops
.
size
())
{
if
(
!
allow_ops
.
empty
())
{
return
registered
&&
allow_ops
.
count
(
node
->
Name
()
);
return
registered
&&
allow_ops
.
count
(
node
_name
);
}
}
// if the op type is registered in CINN and deny_ops is not empty, return
// if the op type is registered in CINN and deny_ops is not empty, return
// true only when it is not in deny_ops
// true only when it is not in deny_ops
if
(
deny_ops
.
size
())
{
if
(
!
deny_ops
.
empty
())
{
return
registered
&&
!
deny_ops
.
count
(
node
->
Name
()
);
return
registered
&&
!
deny_ops
.
count
(
node
_name
);
}
}
// if the user doesn't set FLAGS_allow_cinn_ops and FLAGS_deny_cinn_ops,
// if the user doesn't set FLAGS_allow_cinn_ops and FLAGS_deny_cinn_ops,
// return true only when it is registered in CINN
// return true only when it is registered in CINN
return
registered
&&
(
node
->
IsOp
()
&&
!
IsInplaceOp
(
*
node
->
Op
()));
return
registered
&&
!
kDefaultDenyOps
.
count
(
node_name
)
&&
(
node
->
IsOp
()
&&
!
IsInplaceOp
(
*
node
->
Op
()));
};
};
VLOG
(
4
)
<<
"The allowed Cinn Ops: "
<<
FLAGS_allow_cinn_ops
;
VLOG
(
4
)
<<
"The allowed Cinn Ops: "
<<
FLAGS_allow_cinn_ops
;
VLOG
(
4
)
<<
"The denied Cinn Ops: "
<<
FLAGS_deny_cinn_ops
;
VLOG
(
4
)
<<
"The denied Cinn Ops: "
<<
FLAGS_deny_cinn_ops
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录