Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
机器未来
Paddle
提交
ba1bbe8e
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看板
未验证
提交
ba1bbe8e
编写于
9月 27, 2022
作者:
R
Ruibiao Chen
提交者:
GitHub
9月 27, 2022
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Fix op_happen_before_ update bug for AddDownstreamOp (#46486)
上级
38e82868
变更
2
显示空白变更内容
内联
并排
Showing
2 changed file
with
12 addition
and
11 deletion
+12
-11
paddle/fluid/framework/new_executor/interpreter/dependency_builder.cc
.../framework/new_executor/interpreter/dependency_builder.cc
+11
-10
paddle/fluid/framework/new_executor/interpretercore_util.cc
paddle/fluid/framework/new_executor/interpretercore_util.cc
+1
-1
未找到文件。
paddle/fluid/framework/new_executor/interpreter/dependency_builder.cc
浏览文件 @
ba1bbe8e
...
@@ -70,15 +70,15 @@ const std::map<int, std::set<int>>& DependencyBuilder::Build(
...
@@ -70,15 +70,15 @@ const std::map<int, std::set<int>>& DependencyBuilder::Build(
BuildOpHappensBefore
();
BuildOpHappensBefore
();
ShrinkDownstreamMap
();
ShrinkDownstreamMap
();
if
(
is_sequential_run
)
{
AddDependencyForSequentialRun
();
}
AddDependencyForCoalesceTensorOp
();
AddDependencyForCoalesceTensorOp
();
AddDependencyForCommunicationOp
();
AddDependencyForCommunicationOp
();
AddDependencyForRandomOp
();
AddDependencyForRandomOp
();
AddDependencyForReadOp
();
AddDependencyForReadOp
();
if
(
is_sequential_run
)
{
AddDependencyForSequentialRun
();
}
is_build_
=
true
;
is_build_
=
true
;
VLOG
(
8
)
<<
"Finish build dependency"
;
VLOG
(
8
)
<<
"Finish build dependency"
;
...
@@ -335,6 +335,10 @@ void DependencyBuilder::AddDownstreamOp(int prior_op_idx,
...
@@ -335,6 +335,10 @@ void DependencyBuilder::AddDownstreamOp(int prior_op_idx,
if
(
op_happens_before_
.
size
()
!=
0
)
{
if
(
op_happens_before_
.
size
()
!=
0
)
{
for
(
size_t
op_idx
=
0
;
op_idx
<
op_num_
;
++
op_idx
)
{
for
(
size_t
op_idx
=
0
;
op_idx
<
op_num_
;
++
op_idx
)
{
if
(
op_happens_before_
[
op_idx
][
prior_op_idx
])
{
op_happens_before_
[
op_idx
][
posterior_op_idx
]
=
true
;
}
if
(
op_happens_before_
[
posterior_op_idx
][
op_idx
])
{
if
(
op_happens_before_
[
posterior_op_idx
][
op_idx
])
{
op_happens_before_
[
prior_op_idx
][
op_idx
]
=
true
;
op_happens_before_
[
prior_op_idx
][
op_idx
]
=
true
;
}
}
...
@@ -461,10 +465,6 @@ void DependencyBuilder::BuildDownstreamMap() {
...
@@ -461,10 +465,6 @@ void DependencyBuilder::BuildDownstreamMap() {
AddDownstreamOp
(
dep_op
,
op
);
AddDownstreamOp
(
dep_op
,
op
);
}
}
}
}
VLOG
(
6
)
<<
"downstream count: "
<<
CountDownstreamMap
(
op_downstream_map_
);
VLOG
(
6
)
<<
"downstream_map: "
<<
std
::
endl
<<
StringizeDownstreamMap
(
op_downstream_map_
);
}
}
void
DependencyBuilder
::
BuildOpHappensBefore
()
{
void
DependencyBuilder
::
BuildOpHappensBefore
()
{
...
@@ -542,8 +542,9 @@ void DependencyBuilder::ShrinkDownstreamMap() {
...
@@ -542,8 +542,9 @@ void DependencyBuilder::ShrinkDownstreamMap() {
}
}
op_downstream_map_
.
at
(
i
)
=
minumum_nexts
;
op_downstream_map_
.
at
(
i
)
=
minumum_nexts
;
}
}
VLOG
(
6
)
<<
"downstream count: "
<<
CountDownstreamMap
(
op_downstream_map_
);
VLOG
(
8
)
<<
"Finish shrink downstream map"
;
VLOG
(
6
)
<<
"downstream_map: "
<<
std
::
endl
VLOG
(
8
)
<<
"downstream count: "
<<
CountDownstreamMap
(
op_downstream_map_
);
VLOG
(
8
)
<<
"downstream_map: "
<<
std
::
endl
<<
StringizeDownstreamMap
(
op_downstream_map_
);
<<
StringizeDownstreamMap
(
op_downstream_map_
);
}
}
...
...
paddle/fluid/framework/new_executor/interpretercore_util.cc
浏览文件 @
ba1bbe8e
...
@@ -268,7 +268,7 @@ void create_all_ops(const framework::BlockDesc& block,
...
@@ -268,7 +268,7 @@ void create_all_ops(const framework::BlockDesc& block,
std
::
vector
<
std
::
unique_ptr
<
OperatorBase
>>*
ops
)
{
std
::
vector
<
std
::
unique_ptr
<
OperatorBase
>>*
ops
)
{
for
(
auto
&
op
:
block
.
AllOps
())
{
for
(
auto
&
op
:
block
.
AllOps
())
{
auto
op_type
=
op
->
Type
();
auto
op_type
=
op
->
Type
();
VLOG
(
1
)
<<
"CreateOp from : "
<<
op_type
;
VLOG
(
8
)
<<
"CreateOp from : "
<<
op_type
;
auto
&
info
=
OpInfoMap
::
Instance
().
Get
(
op_type
);
auto
&
info
=
OpInfoMap
::
Instance
().
Get
(
op_type
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录