Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
PaddlePaddle
Paddle
提交
9ded7565
P
Paddle
项目概览
PaddlePaddle
/
Paddle
大约 1 年 前同步成功
通知
2299
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看板
未验证
提交
9ded7565
编写于
8月 31, 2020
作者:
T
tangwei12
提交者:
GitHub
8月 31, 2020
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
【paddle.fleet】FleetAPI 2.0 (#26772)
* add FleetAPI doc Co-authored-by:
N
liuyuhui
<
liuyuhui@baidu.com
>
上级
b0111778
变更
1
显示空白变更内容
内联
并排
Showing
1 changed file
with
334 addition
and
51 deletion
+334
-51
python/paddle/distributed/fleet/base/fleet_base.py
python/paddle/distributed/fleet/base/fleet_base.py
+334
-51
未找到文件。
python/paddle/distributed/fleet/base/fleet_base.py
浏览文件 @
9ded7565
...
@@ -22,8 +22,6 @@ from .runtime_factory import RuntimeFactory
...
@@ -22,8 +22,6 @@ from .runtime_factory import RuntimeFactory
from
.util_factory
import
UtilFactory
from
.util_factory
import
UtilFactory
from
paddle.fluid.wrapped_decorator
import
wrap_decorator
from
paddle.fluid.wrapped_decorator
import
wrap_decorator
#__all__ = ['Fleet']
def
_inited_runtime_handler_
(
func
):
def
_inited_runtime_handler_
(
func
):
def
__impl__
(
*
args
,
**
kwargs
):
def
__impl__
(
*
args
,
**
kwargs
):
...
@@ -43,65 +41,123 @@ inited_runtime_handler = wrap_decorator(_inited_runtime_handler_)
...
@@ -43,65 +41,123 @@ inited_runtime_handler = wrap_decorator(_inited_runtime_handler_)
class
Fleet
(
object
):
class
Fleet
(
object
):
"""
"""
Unified API for distributed training of PaddlePaddle
Unified API for distributed training of PaddlePaddle
Please reference the https://github.com/PaddlePaddle/Fleet for details
Please reference the https://github.com/PaddlePaddle/Fleet
X
for details
Returns:
Returns:
Fleet: A Fleet instance
Fleet: A Fleet instance
Example
s
:
Example
for collective training
:
.. code-block:: python
.. code-block:: python
import paddle.distributed.fleet as fleet
import paddle.distributed.fleet as fleet
role = fleet.role_maker.PaddleCloudRoleMaker(is_collective=True)
fleet.init(role)
fleet.init(is_collective=True)
strategy = fleet.DistributedStrategy()
strategy = fleet.DistributedStrategy()
optimizer = paddle.optimizer.SGD(learning_rate=0.001)
optimizer = paddle.optimizer.SGD(learning_rate=0.001)
optimizer = fleet.distributed_optimizer(optimizer, strategy=strategy)
optimizer = fleet.distributed_optimizer(optimizer, strategy=strategy)
# do distributed training
Example for parameter server training:
.. code-block:: python
import paddle.distributed.fleet as fleet
fleet.init()
strategy = fleet.DistributedStrategy()
optimizer = paddle.optimizer.SGD(learning_rate=0.001)
optimizer = fleet.distributed_optimizer(optimizer, strategy=strategy)
if fleet.is_first_worker():
if fleet.is_first_worker():
print("this is first worker")
print("this is first worker")
print("current node index: {}".format(fleet.worker_index()))
print("current node index: {}".format(fleet.worker_index()))
print("total number of worker num: {}".format(fleet.worker_num()))
print("total number of worker num: {}".format(fleet.worker_num()))
if fleet.is_worker():
if fleet.is_worker():
print("this is worker")
print("this is worker")
print("worker endpoints: {}".format(fleet.worker_endpoints(to_string=True)))
print("worker endpoints: {}".format(fleet.worker_endpoints(to_string=True)))
print("server num: {}".format(fleet.server_num()))
print("server num: {}".format(fleet.server_num()))
print("server endpoints: {}".format(fleet.server_endpoints(to_string=True)))
print("server endpoints: {}".format(fleet.server_endpoints(to_string=True)))
if fleet.is_server():
if fleet.is_server():
print("this is server")
print("this is server")
fleet.stop_worker()
fleet.stop_worker()
"""
"""
def
__init__
(
self
):
def
__init__
(
self
):
self
.
_runtime_handle
=
None
self
.
_util
=
None
self
.
_role_maker
=
None
self
.
_role_maker
=
None
self
.
strategy_compiler
=
None
self
.
_is_collective
=
False
self
.
_is_collective
=
False
self
.
_runtime_handle
=
None
self
.
_util
=
None
def
init
(
self
,
role_maker
=
None
,
is_collective
=
False
):
def
init
(
self
,
role_maker
=
None
,
is_collective
=
False
):
"""
"""
Initialize role_maker in Fleet.
Initialize role_maker in Fleet.
This function is responsible for the distributed architecture
This function is responsible for the distributed architecture
what you want to run your code behind,such as Transpiler,
what you want to run your code behind.
Collective in PaddleCloudRoleMaker or UserDefinedRoleMaker
Args:
role_maker (RoleMakerBase, optional): A ``RoleMakerBase`` containing the configuration
of environment variables related to distributed training.If you did not initialize
the rolemaker by yourself, it will be automatically initialized to PaddleRoleMaker.
The default value is None.
is_collective (Boolean, optional): A ``Boolean`` variable determines whether the program
runs on the CPU or GPU. False means set distributed training using CPU, and True means
GPU.The default value is False.The default value is False.
Returns:
None
Examples1:
.. code-block:: python
import paddle.distributed.fleet as fleet
fleet.init()
Examples2:
.. code-block:: python
import paddle.distributed.fleet as fleet
fleet.init(is_collective=True)
Examples3:
.. code-block:: python
import paddle.distributed.fleet as fleet
role = fleet.PaddleCloudRoleMaker
fleet.init(role)
"""
"""
if
isinstance
(
role_maker
,
RoleMakerBase
):
self
.
_role_maker
=
role_maker
if
role_maker
is
None
:
elif
role_maker
==
None
:
if
isinstance
(
is_collective
,
bool
):
if
isinstance
(
is_collective
,
bool
):
self
.
_is_collective
=
is_collective
self
.
_is_collective
=
is_collective
self
.
_role_maker
=
PaddleCloudRoleMaker
(
self
.
_role_maker
=
PaddleCloudRoleMaker
(
is_collective
=
self
.
_is_collective
)
is_collective
=
self
.
_is_collective
)
else
:
else
:
raise
ValueError
(
raise
ValueError
(
"Something wrong occurred, please check whether is_collective is bool value"
"`is_collective` should be instance of `bool`, but got {}"
.
)
format
(
type
(
is_collective
)))
else
:
if
isinstance
(
role_maker
,
RoleMakerBase
):
self
.
_role_maker
=
role_maker
else
:
else
:
raise
ValueError
(
raise
ValueError
(
"Something wrong occurred, please check whether rolemaker is instance of RoleMakerBase"
"`role_maker` should be subclass of `RoleMakerBase`, but got {}"
.
)
format
(
type
(
role_maker
))
)
self
.
strategy_compiler
=
StrategyCompiler
()
self
.
strategy_compiler
=
StrategyCompiler
()
return
None
return
None
...
@@ -113,6 +169,14 @@ class Fleet(object):
...
@@ -113,6 +169,14 @@ class Fleet(object):
bool: True if this is the first node of worker,
bool: True if this is the first node of worker,
False if not.
False if not.
Examples:
.. code-block:: python
import paddle.distributed.fleet as fleet
fleet.init()
fleet.is_first_worker()
"""
"""
return
self
.
_role_maker
.
is_first_worker
()
return
self
.
_role_maker
.
is_first_worker
()
...
@@ -122,6 +186,14 @@ class Fleet(object):
...
@@ -122,6 +186,14 @@ class Fleet(object):
Returns:
Returns:
int: node id
int: node id
Examples:
.. code-block:: python
import paddle.distributed.fleet as fleet
fleet.init()
fleet.worker_index()
"""
"""
return
self
.
_role_maker
.
worker_index
()
return
self
.
_role_maker
.
worker_index
()
...
@@ -131,6 +203,14 @@ class Fleet(object):
...
@@ -131,6 +203,14 @@ class Fleet(object):
Returns:
Returns:
int: worker numbers
int: worker numbers
Examples:
.. code-block:: python
import paddle.distributed.fleet as fleet
fleet.init()
fleet.worker_num()
"""
"""
return
self
.
_role_maker
.
worker_num
()
return
self
.
_role_maker
.
worker_num
()
...
@@ -141,15 +221,31 @@ class Fleet(object):
...
@@ -141,15 +221,31 @@ class Fleet(object):
Returns:
Returns:
bool: True if this is a node of worker,
bool: True if this is a node of worker,
False if not.
False if not.
Examples:
.. code-block:: python
import paddle.distributed.fleet as fleet
fleet.init()
fleet.is_worker()
"""
"""
return
self
.
_role_maker
.
is_worker
()
return
self
.
_role_maker
.
is_worker
()
def
worker_endpoints
(
self
,
to_string
=
False
):
def
worker_endpoints
(
self
,
to_string
=
False
):
"""
"""
Get current
serv
er endpoints, such as ["127.0.0.1:1001", "127.0.0.1:1002"].
Get current
work
er endpoints, such as ["127.0.0.1:1001", "127.0.0.1:1002"].
Returns:
Returns:
list/string: server endpoints
list/string: server endpoints
Examples:
.. code-block:: python
import paddle.distributed.fleet as fleet
fleet.init()
fleet.worker_endpoints()
"""
"""
'''
'''
if to_string:
if to_string:
...
@@ -165,6 +261,12 @@ class Fleet(object):
...
@@ -165,6 +261,12 @@ class Fleet(object):
Returns:
Returns:
int: server number
int: server number
Examples:
.. code-block:: python
import paddle.distributed.fleet as fleet
fleet.init()
fleet.server_num()
"""
"""
return
len
(
self
.
_role_maker
.
get_pserver_endpoints
())
return
len
(
self
.
_role_maker
.
get_pserver_endpoints
())
...
@@ -174,6 +276,14 @@ class Fleet(object):
...
@@ -174,6 +276,14 @@ class Fleet(object):
Returns:
Returns:
int: node id
int: node id
Examples:
.. code-block:: python
import paddle.distributed.fleet as fleet
fleet.init()
fleet.server_index()
"""
"""
return
self
.
_role_maker
.
server_index
()
return
self
.
_role_maker
.
server_index
()
...
@@ -183,14 +293,20 @@ class Fleet(object):
...
@@ -183,14 +293,20 @@ class Fleet(object):
Returns:
Returns:
list/string: server endpoints
list/string: server endpoints
Examples:
.. code-block:: python
import paddle.distributed.fleet as fleet
fleet.init()
fleet.server_endpoints()
"""
"""
'''
if
to_string
:
if
to_string
:
return
","
.
join
(
self
.
_role_maker
.
get_pserver_endpoints
())
return
","
.
join
(
self
.
_role_maker
.
get_pserver_endpoints
())
else
:
else
:
return
self
.
_role_maker
.
get_pserver_endpoints
()
return
self
.
_role_maker
.
get_pserver_endpoints
()
'''
return
[
"127.0.0.1:1001"
,
"127.0.0.1:1002"
]
def
is_server
(
self
):
def
is_server
(
self
):
"""
"""
...
@@ -199,6 +315,14 @@ class Fleet(object):
...
@@ -199,6 +315,14 @@ class Fleet(object):
Returns:
Returns:
bool: True if this is a node of server,
bool: True if this is a node of server,
False if not.
False if not.
Examples:
.. code-block:: python
import paddle.distributed.fleet as fleet
fleet.init()
fleet.is_server()
"""
"""
return
self
.
_role_maker
.
is_server
(
return
self
.
_role_maker
.
is_server
(
)
or
self
.
_role_maker
.
_is_heter_worker
()
)
or
self
.
_role_maker
.
_is_heter_worker
()
...
@@ -208,6 +332,19 @@ class Fleet(object):
...
@@ -208,6 +332,19 @@ class Fleet(object):
"""
"""
Utility functions that can be used under certain runtime
Utility functions that can be used under certain runtime
return util
return util
Returns:
UtilBase: instance of UtilBase, can use distributed ops/tools easily.
Examples:
.. code-block:: python
import paddle.distributed.fleet as fleet
fleet.init()
util = fleet.util
files = ["1.log", "2.log", "3.log", "4.log"]
files = util.get_file_shard()
"""
"""
return
self
.
_util
return
self
.
_util
...
@@ -215,41 +352,114 @@ class Fleet(object):
...
@@ -215,41 +352,114 @@ class Fleet(object):
def
util
(
self
,
util
):
def
util
(
self
,
util
):
"""
"""
Set Utility functions for userd-defined runtime
Set Utility functions for userd-defined runtime
set util
Returns:
None
"""
"""
self
.
_util
=
util
self
.
_util
=
util
def
barrier_worker
(
self
):
def
barrier_worker
(
self
):
"""
"""
barrier between workers
barrier all workers
Returns:
None
"""
"""
self
.
_role_maker
.
barrier_worker
()
self
.
_role_maker
.
barrier_worker
()
@
inited_runtime_handler
@
inited_runtime_handler
def
init_worker
(
self
):
def
init_worker
(
self
):
"""
"""
init worker
initialize `Communicator` for parameter server training.
Returns:
None
Examples:
.. code-block:: python
import paddle.distributed.fleet as fleet
fleet.init()
# build net
# fleet.distributed_optimizer(...)
fleet.init_worker()
"""
"""
self
.
_runtime_handle
.
_init_worker
()
self
.
_runtime_handle
.
_init_worker
()
@
inited_runtime_handler
@
inited_runtime_handler
def
init_server
(
self
,
*
args
,
**
kwargs
):
def
init_server
(
self
,
*
args
,
**
kwargs
):
"""
"""
init server
init_server executor to initialize startup program,
if the `args` is not empty, it will run load_persistables for increment training.
Returns:
None
Examples:
.. code-block:: python
import paddle.distributed.fleet as fleet
fleet.init()
# build net
# fleet.distributed_optimizer(...)
fleet.init_server()
"""
"""
self
.
_runtime_handle
.
_init_server
(
*
args
,
**
kwargs
)
self
.
_runtime_handle
.
_init_server
(
*
args
,
**
kwargs
)
@
inited_runtime_handler
@
inited_runtime_handler
def
run_server
(
self
):
def
run_server
(
self
):
"""
"""
run server
run server will run pserver main program with executor.
Returns:
None
Examples:
.. code-block:: python
import paddle.distributed.fleet as fleet
fleet.init()
# build net
# fleet.distributed_optimizer(...)
if fleet.is_server():
fleet.init_server()
"""
"""
self
.
_runtime_handle
.
_run_server
()
self
.
_runtime_handle
.
_run_server
()
@
inited_runtime_handler
@
inited_runtime_handler
def
stop_worker
(
self
):
def
stop_worker
(
self
):
"""
"""
stop worker
stop `Communicator` and give training complete notice to parameter server.
Returns:
None
Examples:
.. code-block:: python
import paddle.distributed.fleet as fleet
fleet.init()
# build net
# fleet.distributed_optimizer(...)
fleet.init_server()
"""
"""
self
.
_runtime_handle
.
_stop_worker
()
self
.
_runtime_handle
.
_stop_worker
()
...
@@ -260,27 +470,98 @@ class Fleet(object):
...
@@ -260,27 +470,98 @@ class Fleet(object):
target_vars
,
target_vars
,
main_program
=
None
,
main_program
=
None
,
export_for_deployment
=
True
):
export_for_deployment
=
True
):
"""
save inference model for inference.
Returns:
None
Examples:
.. code-block:: python
import paddle.distributed.fleet as fleet
fleet.init()
# build net
# fleet.distributed_optimizer(...)
fleet.init_server()
"""
self
.
_runtime_handle
.
_save_inference_model
(
self
.
_runtime_handle
.
_save_inference_model
(
executor
,
dirname
,
feeded_var_names
,
target_vars
,
main_program
,
executor
,
dirname
,
feeded_var_names
,
target_vars
,
main_program
,
export_for_deployment
)
export_for_deployment
)
def
save_persistables
(
self
,
executor
,
dirname
,
main_program
=
None
):
def
save_persistables
(
self
,
executor
,
dirname
,
main_program
=
None
):
"""
saves all persistable variables from :code:`main_program` to
the folder :code:`dirname`. You can refer to
The :code:`dirname` is used to specify the folder where persistable variables
are going to be saved. If you would like to save variables in separate
files, set :code:`filename` None.
Args:
executor(Executor): The executor to run for saving persistable variables.
You can refer to :ref:`api_guide_executor_en` for
more details.
dirname(str, optional): The saving directory path.
When you need to save the parameter to the memory, set it to None.
main_program(Program, optional): The program whose persistbale variables will
be saved. Default: None.
Returns:
None
Examples:
.. code-block:: text
import paddle.distributed.fleet as fleet
import paddle.fluid as fluid
fleet.init()
# build net
# fleet.distributed_optimizer(...)
exe = fluid.Executor(fluid.CPUPlace())
fleet.save_persistables(exe, "dirname", fluid.default_main_program())
"""
self
.
_runtime_handle
.
_save_persistables
(
executor
,
dirname
,
main_program
)
self
.
_runtime_handle
.
_save_persistables
(
executor
,
dirname
,
main_program
)
def
distributed_optimizer
(
self
,
optimizer
,
strategy
=
None
):
def
distributed_optimizer
(
self
,
optimizer
,
strategy
=
None
):
"""
"""
distirbuted_optimizer
Optimizer for distributed training.
For the distributed training, this method would rebuild a new instance of DistributedOptimizer.
Which has basic Optimizer function and special features for distributed training.
Args:
optimizer(Optimizer): The executor to run for init server.
strategy(DistributedStrategy): Extra properties for distributed optimizer.
Returns:
Returns:
Fleet
instance with minimize interface like optimizers
Fleet
: instance of fleet.
Examples:
Examples:
.. code-block:: python
.. code-block:: python
import paddle.distributed.fleet as fleet
import paddle.distributed.fleet as fleet
role = fleet.role_maker.PaddleCloudRoleMaker(is_collective=True)
role = fleet.role_maker.PaddleCloudRoleMaker(is_collective=True)
fleet.init(role)
fleet.init(role)
strategy = fleet.DistributedStrategy()
strategy = fleet.DistributedStrategy()
optimizer = paddle.optimizer.SGD(learning_rate=0.001)
optimizer = paddle.optimizer.SGD(learning_rate=0.001)
optimizer = fleet.distributed_optimizer(optimizer, strategy=strategy)
optimizer = fleet.distributed_optimizer(optimizer, strategy=strategy)
"""
"""
self
.
user_defined_optimizer
=
optimizer
self
.
user_defined_optimizer
=
optimizer
if
strategy
==
None
:
if
strategy
==
None
:
...
@@ -317,14 +598,16 @@ class Fleet(object):
...
@@ -317,14 +598,16 @@ class Fleet(object):
``fetch_list`` before run, see details in ``Executor``.
``fetch_list`` before run, see details in ``Executor``.
Examples:
Examples:
.. code-block:: python
import paddle
import paddle
import paddle.distributed.fleet as fleet
import paddle.distributed.fleet as fleet
fc_1 = paddle
.layers.fc(input=input_x, size=hid_dim, act='tanh')
fc_1 = paddle.fluid
.layers.fc(input=input_x, size=hid_dim, act='tanh')
fc_2 = paddlen
.layers.fc(input=fc_1, size=hid_dim, act='tanh')
fc_2 = paddle.fluid
.layers.fc(input=fc_1, size=hid_dim, act='tanh')
prediction = paddle
.layers.fc(input=[fc_2], size=label_dim, act='softmax')
prediction = paddle.fluid
.layers.fc(input=[fc_2], size=label_dim, act='softmax')
cost = paddle
.layers.cross_entropy(input=prediction, label=input_y)
cost = paddle.fluid
.layers.cross_entropy(input=prediction, label=input_y)
avg_cost = paddle
.layers.mean(x=cost)
avg_cost = paddle.fluid
.layers.mean(x=cost)
role = fleet.role_maker.PaddleCloudRoleMaker(is_collective=True)
role = fleet.role_maker.PaddleCloudRoleMaker(is_collective=True)
fleet.init(role)
fleet.init(role)
...
@@ -333,7 +616,7 @@ class Fleet(object):
...
@@ -333,7 +616,7 @@ class Fleet(object):
optimizer = fleet.distributed_optimizer(optimizer, strategy=strategy)
optimizer = fleet.distributed_optimizer(optimizer, strategy=strategy)
optimizer.minimize(avg_cost)
optimizer.minimize(avg_cost)
# for more examples, please reference https://github.com/PaddlePaddle/Fleet
# for more examples, please reference https://github.com/PaddlePaddle/FleetX
"""
"""
context
=
{}
context
=
{}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录