Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
PaddlePaddle
Paddle
提交
7a2297de
P
Paddle
项目概览
PaddlePaddle
/
Paddle
1 年多 前同步成功
通知
2302
Star
20931
Fork
5422
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1423
列表
看板
标记
里程碑
合并请求
543
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
P
Paddle
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1,423
Issue
1,423
列表
看板
标记
里程碑
合并请求
543
合并请求
543
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
未验证
提交
7a2297de
编写于
4月 17, 2018
作者:
Y
Yancey
提交者:
GitHub
4月 17, 2018
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #9932 from Yancey1989/async_update_design
Add async update design doc
上级
64bf3df0
936dfcbe
变更
5
隐藏空白更改
内联
并排
Showing
5 changed file
with
58 addition
and
0 deletion
+58
-0
doc/fluid/design/dist_train/async_update.md
doc/fluid/design/dist_train/async_update.md
+58
-0
doc/fluid/design/dist_train/src/async_pserver.graffle
doc/fluid/design/dist_train/src/async_pserver.graffle
+0
-0
doc/fluid/design/dist_train/src/async_pserver.png
doc/fluid/design/dist_train/src/async_pserver.png
+0
-0
doc/fluid/design/dist_train/src/async_update.graffle
doc/fluid/design/dist_train/src/async_update.graffle
+0
-0
doc/fluid/design/dist_train/src/async_update.png
doc/fluid/design/dist_train/src/async_update.png
+0
-0
未找到文件。
doc/fluid/design/dist_train/async_update.md
0 → 100644
浏览文件 @
7a2297de
# Design Doc: Asynchronous Update With Distributed Training
## Background
For the typical synchronous distributed training, some significant steps are as follows:
1.
A Trainer will compute the gradients and SEND them to the Parameter Server(PServer) nodes.
1.
After the PServer node received gradients came from all the Trainers, It will aggregate the
gradient variables for the same parameter into one gradient variable and then apply the aggregated
gradient to the respective parameter, finally using an optimize algorithms(SGD, Monument...)
to update the parameters.
1.
The Trainer would wait for the PServers finished the optimize stage, and GET the parameters from PServer,
so all the Trainers would get the same parameters.
In the synchronously distributed training, there should be a
`Barrier`
to synchronise the
parameters after the optimizing stage. The performance of a distributed training job would
depend on the slowest node if there were hundreds or thousands of training nodes in a
Job, the performance of synchronously distributed training might be very poor because of
the slow node. So this design doc would introduce an approach to implement
*asynchronously*
distributed training in PaddlePaddle Fluid.
## Design
<img
src=
"./src/async_update.png"
width=
"600"
/>
As the figure above, we describe a global view of asynchronously update process and use
the parameter
`w1`
as an example to introduce the steps:
1.
For each gradient variables, they may distribute on different GPU card and aggregate
them while they are all calculated.
1.
Split the gradient variable into multiple blocks according to the number of PServer
instances and then send them.
1.
PServer would run an
`Optimize Block`
using a specified optimize algorithm to update
the specified parameter.
1.
The trainer will fetch latest parameter from PServer before running forward Op which depends
on the specified parameter.
1.
Broadcast the received variable into multiple GPU cards and continue to run the next
mini-batch.
### Trainer
-
For the multiple devices distributed training, we need to aggregate the gradient
variables which placed on different devices firstly and then schedule a
`SendVars`
Operator to
send the gradient variables to the multiple PServer instances.
-
Schedule
`FetchVars`
operator to fetch the latest parameter from PServer before running
the forward ops.
-
There could be a large number of gradient variables to be sent, so we need to use another
thread pool(IO Threadpool) whose a number of the schedulable threads is larger than the
computing thread pool to avoid competitive the thread resources with computing.
### Parameter Server
<img
src=
"./src/async_pserver.png"
width=
"750"
/>
-
There should be multiple trainer instances want to optimize the same parameter at
the same time, to avoid the racing, we need one
`BlockingQueue`
for each gradient
variable to process them one by one.
-
We need a
`Map`
structure to map a gradient variable name to the
`OptimizeBlock`
which
can optimize the respective parameter.
doc/fluid/design/dist_train/src/async_pserver.graffle
0 → 100644
浏览文件 @
7a2297de
文件已添加
doc/fluid/design/dist_train/src/async_pserver.png
0 → 100644
浏览文件 @
7a2297de
166.0 KB
doc/fluid/design/dist_train/src/async_update.graffle
0 → 100644
浏览文件 @
7a2297de
文件已添加
doc/fluid/design/dist_train/src/async_update.png
0 → 100644
浏览文件 @
7a2297de
179.6 KB
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录