Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
机器未来
Paddle
提交
f2db475a
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看板
未验证
提交
f2db475a
编写于
5月 06, 2019
作者:
C
chengduo
提交者:
GitHub
5月 06, 2019
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
update ParallelExecutor (#17204)
test=develop
上级
950aec55
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
16 addition
and
4 deletion
+16
-4
python/paddle/fluid/parallel_executor.py
python/paddle/fluid/parallel_executor.py
+16
-4
未找到文件。
python/paddle/fluid/parallel_executor.py
浏览文件 @
f2db475a
...
@@ -96,19 +96,31 @@ class ParallelExecutor(object):
...
@@ -96,19 +96,31 @@ class ParallelExecutor(object):
if
build_strategy
is
None
:
if
build_strategy
is
None
:
build_strategy
=
BuildStrategy
()
build_strategy
=
BuildStrategy
()
build_strategy
.
num_trainers
=
num_trainers
build_strategy
.
trainer_id
=
trainer_id
# TODO(paddle-dev): trainer_id and num_trainers should be removed from parameter list.
if
num_trainers
!=
1
and
build_strategy
.
num_trainers
!=
num_trainers
:
sys
.
stderr
.
write
(
'The value of build_strategy.num_trainers[%d] is overwritten '
'by the passed num_trainers[%d].
\n
'
%
(
build_strategy
.
num_trainers
,
num_trainers
))
build_strategy
.
num_trainers
=
num_trainers
if
trainer_id
!=
0
and
build_strategy
.
trainer_id
!=
trainer_id
:
sys
.
stderr
.
write
(
'The value of build_strategy.trainer_id[%d] is overwritten '
'by the passed trainer_id[%d].
\n
'
%
(
build_strategy
.
trainer_id
,
trainer_id
))
build_strategy
.
trainer_id
=
trainer_id
self
.
_places
=
framework
.
cuda_places
(
self
.
_places
=
framework
.
cuda_places
(
)
if
use_cuda
else
framework
.
cpu_places
()
)
if
use_cuda
else
framework
.
cpu_places
()
self
.
_scope
=
scope
if
scope
is
not
None
else
executor
.
global_scope
()
self
.
_scope
=
scope
if
scope
is
not
None
else
executor
.
global_scope
()
if
main_program
is
not
None
and
main_program
.
_enable_dgc
:
if
main_program
is
not
None
and
main_program
.
_enable_dgc
:
assert
num_trainers
>
1
,
"dgc is not useful when num_trainers <= 1"
assert
build_strategy
.
num_trainers
>
1
,
"dgc is not useful when num_trainers <= 1"
assert
build_strategy
.
reduce_strategy
==
BuildStrategy
.
ReduceStrategy
.
AllReduce
,
"dgc
\
assert
build_strategy
.
reduce_strategy
==
BuildStrategy
.
ReduceStrategy
.
AllReduce
,
"dgc
\
only used for allreduce"
only used for allreduce"
assert
num_trainers
*
len
(
assert
build_strategy
.
num_trainers
*
len
(
self
.
_places
)
>
1
,
"dgc is not useful for single card training"
self
.
_places
)
>
1
,
"dgc is not useful for single card training"
assert
use_cuda
,
"dgc only used under cuda"
assert
use_cuda
,
"dgc only used under cuda"
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录