Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Crayon鑫
Paddle
提交
6c329455
P
Paddle
项目概览
Crayon鑫
/
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看板
未验证
提交
6c329455
编写于
11月 13, 2018
作者:
T
Tao Luo
提交者:
GitHub
11月 13, 2018
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #14372 from luotao1/speedup_analysis
speedup DetectPatterns
上级
4a55fb5f
668ae523
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
11 addition
and
9 deletion
+11
-9
paddle/fluid/framework/ir/graph_pattern_detector.cc
paddle/fluid/framework/ir/graph_pattern_detector.cc
+11
-9
未找到文件。
paddle/fluid/framework/ir/graph_pattern_detector.cc
浏览文件 @
6c329455
...
...
@@ -167,10 +167,12 @@ struct HitGroup {
bool
Match
(
Node
*
node
,
PDNode
*
pat
)
{
if
(
nodes_
.
count
(
node
))
{
if
(
!
roles
.
count
(
pat
))
return
false
;
return
roles
[
pat
]
==
node
;
if
(
roles
.
count
(
pat
)
&&
roles
[
pat
]
==
node
)
return
true
;
return
false
;
}
else
{
if
(
roles
.
count
(
pat
)
&&
roles
[
pat
]
!=
node
)
return
false
;
return
true
;
}
return
!
roles
.
count
(
pat
)
||
roles
.
at
(
pat
)
==
node
;
}
void
Register
(
Node
*
node
,
PDNode
*
pat
)
{
...
...
@@ -198,7 +200,6 @@ GraphPatternDetector::DetectPatterns() {
std
::
vector
<
GraphPatternDetector
::
subgraph_t
>
result
;
std
::
vector
<
HitGroup
>
init_groups
;
std
::
array
<
std
::
vector
<
HitGroup
>
,
2
>
bi_records
;
// PADDLE_ENFORCE(!pattern_.edges().empty(), "At least one edge is needed");
auto
*
first_pnode
=
pattern_
.
edges
().
empty
()
?
pattern
().
nodes
().
front
().
get
()
:
pattern_
.
edges
().
front
().
first
;
if
(
!
pdnodes2nodes_
.
count
(
first_pnode
))
return
result
;
...
...
@@ -228,11 +229,12 @@ GraphPatternDetector::DetectPatterns() {
VLOG
(
80
)
<<
"check "
<<
source
->
id
()
<<
" -- "
<<
target
->
id
();
// TODO(Superjomn) add some prune strategies.
for
(
const
auto
&
group
:
pre_groups
)
{
HitGroup
new_group
=
group
;
if
(
IsNodesLink
(
source
,
target
)
&&
new_group
.
Match
(
source
,
edge
.
first
))
{
new_group
.
Register
(
source
,
edge
.
first
);
if
(
new_group
.
Match
(
target
,
edge
.
second
))
{
if
(
IsNodesLink
(
source
,
target
))
{
HitGroup
new_group
=
group
;
bool
flag
=
new_group
.
Match
(
source
,
edge
.
first
)
&&
new_group
.
Match
(
target
,
edge
.
second
);
if
(
flag
)
{
new_group
.
Register
(
source
,
edge
.
first
);
new_group
.
Register
(
target
,
edge
.
second
);
cur_groups
.
push_back
(
new_group
);
// TODO(Superjomn) need to unique
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录