Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
机器未来
Paddle
提交
030b298e
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看板
未验证
提交
030b298e
编写于
9月 02, 2020
作者:
L
lilong12
提交者:
GitHub
9月 02, 2020
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix sample codes in collective.py (#26787)
* fix sample codes, test=develop
上级
435ab2aa
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
92 addition
and
87 deletion
+92
-87
python/paddle/distributed/collective.py
python/paddle/distributed/collective.py
+92
-87
未找到文件。
python/paddle/distributed/collective.py
浏览文件 @
030b298e
...
@@ -73,20 +73,21 @@ def broadcast(tensor, src, group=0):
...
@@ -73,20 +73,21 @@ def broadcast(tensor, src, group=0):
Examples:
Examples:
.. code-block:: python
.. code-block:: python
import paddle
import numpy as np
import paddle.prepare_context as prepare_context
import paddle
from paddle.distributed import init_parallel_env
paddle.disable_static()
paddle.set_device('gpu:%d'%paddle.ParallelEnv().dev_id)
paddle.disable_static()
prepare_context()
paddle.set_device('gpu:%d'%paddle.distributed.ParallelEnv().dev_id)
if paddle.ParallelEnv().local_rank == 0:
init_parallel_env()
np_data = np.array([[4, 5, 6], [4, 5, 6]])
if paddle.distributed.ParallelEnv().local_rank == 0:
else:
np_data = np.array([[4, 5, 6], [4, 5, 6]])
np_data = np.array([[1, 2, 3], [1, 2, 3]])
else:
data = paddle.to_tensor(np_data)
np_data = np.array([[1, 2, 3], [1, 2, 3]])
paddle.distributed.broadcast(data, 1)
data = paddle.to_tensor(np_data)
out = data.numpy()
paddle.distributed.broadcast(data, 1)
# [[1, 2, 3], [1, 2, 3]]
out = data.numpy()
# [[1, 2, 3], [1, 2, 3]]
"""
"""
if
in_dygraph_mode
():
if
in_dygraph_mode
():
return
core
.
ops
.
c_broadcast
(
tensor
,
tensor
,
'root'
,
src
,
return
core
.
ops
.
c_broadcast
(
tensor
,
tensor
,
'root'
,
src
,
...
@@ -129,21 +130,22 @@ def all_reduce(tensor, op=ReduceOp.SUM, group=0):
...
@@ -129,21 +130,22 @@ def all_reduce(tensor, op=ReduceOp.SUM, group=0):
Examples:
Examples:
.. code-block:: python
.. code-block:: python
import paddle
import numpy as np
from paddle.distributed import ReduceOp
import paddle
import paddle.prepare_context as prepare_context
from paddle.distributed import ReduceOp
from paddle.distributed import init_parallel_env
paddle.disable_static()
paddle.set_device('gpu:%d'%paddle.ParallelEnv().dev_id)
paddle.disable_static()
prepare_context()
paddle.set_device('gpu:%d'%paddle.distributed.ParallelEnv().dev_id)
if paddle.ParallelEnv().local_rank == 0:
init_parallel_env()
np_data = np.array([[4, 5, 6], [4, 5, 6]])
if paddle.distributed.ParallelEnv().local_rank == 0:
else:
np_data = np.array([[4, 5, 6], [4, 5, 6]])
np_data = np.array([[1, 2, 3], [1, 2, 3]])
else:
data = paddle.to_tensor(np_data)
np_data = np.array([[1, 2, 3], [1, 2, 3]])
paddle.distributed.all_reduce(data)
data = paddle.to_tensor(np_data)
out = data.numpy()
paddle.distributed.all_reduce(data)
# [[5, 7, 9], [5, 7, 9]]
out = data.numpy()
# [[5, 7, 9], [5, 7, 9]]
"""
"""
if
in_dygraph_mode
():
if
in_dygraph_mode
():
if
op
==
ReduceOp
.
SUM
:
if
op
==
ReduceOp
.
SUM
:
...
@@ -204,20 +206,21 @@ def reduce(tensor, dst, op=ReduceOp.SUM, group=0):
...
@@ -204,20 +206,21 @@ def reduce(tensor, dst, op=ReduceOp.SUM, group=0):
Examples:
Examples:
.. code-block:: python
.. code-block:: python
import paddle
import numpy as np
import paddle.prepare_context as prepare_context
import paddle
from paddle.distributed import init_parallel_env
paddle.disable_static()
paddle.set_device('gpu:%d'%paddle.ParallelEnv().dev_id)
paddle.disable_static()
prepare_context()
paddle.set_device('gpu:%d'%paddle.distributed.ParallelEnv().dev_id)
if paddle.ParallelEnv().local_rank == 0:
init_parallel_env()
np_data = np.array([[4, 5, 6], [4, 5, 6]])
if paddle.distributed.ParallelEnv().local_rank == 0:
else:
np_data = np.array([[4, 5, 6], [4, 5, 6]])
np_data = np.array([[1, 2, 3], [1, 2, 3]])
else:
data = paddle.to_tensor(np_data)
np_data = np.array([[1, 2, 3], [1, 2, 3]])
paddle.distributed.reduce(data, 0)
data = paddle.to_tensor(np_data)
out = data.numpy()
paddle.distributed.reduce(data, 0)
# [[5, 7, 9], [5, 7, 9]]
out = data.numpy()
# [[5, 7, 9], [5, 7, 9]]
"""
"""
if
in_dygraph_mode
():
if
in_dygraph_mode
():
if
op
==
ReduceOp
.
SUM
:
if
op
==
ReduceOp
.
SUM
:
...
@@ -286,25 +289,26 @@ def all_gather(tensor_list, tensor, group=0):
...
@@ -286,25 +289,26 @@ def all_gather(tensor_list, tensor, group=0):
Examples:
Examples:
.. code-block:: python
.. code-block:: python
import paddle
import numpy as np
import paddle.prepare_context as prepare_context
import paddle
from paddle.distributed import init_parallel_env
paddle.disable_static()
paddle.set_device('gpu:%d'%paddle.ParallelEnv().dev_id)
paddle.disable_static()
prepare_context()
paddle.set_device('gpu:%d'%paddle.distributed.ParallelEnv().dev_id)
tensor_list = []
init_parallel_env()
if paddle.ParallelEnv().local_rank == 0:
tensor_list = []
np_data1 = np.array([[4, 5, 6], [4, 5, 6]])
if paddle.distributed.ParallelEnv().local_rank == 0:
np_data2 = np.array([[4, 5, 6], [4, 5, 6]])
np_data1 = np.array([[4, 5, 6], [4, 5, 6]])
data1 = paddle.to_tensor(np_data1)
np_data2 = np.array([[4, 5, 6], [4, 5, 6]])
data2 = paddle.to_tensor(np_data2)
data1 = paddle.to_tensor(np_data1)
paddle.distributed.all_gather(tensor_list, data1)
data2 = paddle.to_tensor(np_data2)
else:
paddle.distributed.all_gather(tensor_list, data1)
np_data1 = np.array([[1, 2, 3], [1, 2, 3]])
else:
np_data2 = np.array([[1, 2, 3], [1, 2, 3]])
np_data1 = np.array([[1, 2, 3], [1, 2, 3]])
data1 = paddle.to_tensor(np_data1)
np_data2 = np.array([[1, 2, 3], [1, 2, 3]])
data2 = paddle.to_tensor(np_data2)
data1 = paddle.to_tensor(np_data1)
out = paddle.distributed.all_gather(tensor_list, data2)
data2 = paddle.to_tensor(np_data2)
paddle.distributed.all_gather(tensor_list, data2)
"""
"""
op_type
=
'c_allgather'
op_type
=
'c_allgather'
helper
=
LayerHelper
(
op_type
,
**
locals
())
helper
=
LayerHelper
(
op_type
,
**
locals
())
...
@@ -359,25 +363,26 @@ def scatter(tensor, tensor_list=None, src=0, group=0):
...
@@ -359,25 +363,26 @@ def scatter(tensor, tensor_list=None, src=0, group=0):
Examples:
Examples:
.. code-block:: python
.. code-block:: python
import paddle
import numpy as np
import paddle.prepare_context as prepare_context
import paddle
from paddle.distributed import init_parallel_env
paddle.disable_static()
paddle.set_device('gpu:%d'%paddle.ParallelEnv().dev_id)
paddle.disable_static()
prepare_context()
paddle.set_device('gpu:%d'%paddle.distributed.ParallelEnv().dev_id)
if paddle.ParallelEnv().local_rank == 0:
init_parallel_env()
np_data1 = np.array([7, 8, 9])
if paddle.distributed.ParallelEnv().local_rank == 0:
np_data2 = np.array([10, 11, 12])
np_data1 = np.array([7, 8, 9])
else:
np_data2 = np.array([10, 11, 12])
np_data1 = np.array([1, 2, 3])
else:
np_data2 = np.array([4, 5, 6])
np_data1 = np.array([1, 2, 3])
data1 = paddle.to_tensor(np_data1)
np_data2 = np.array([4, 5, 6])
data2 = paddle.to_tensor(np_data2)
data1 = paddle.to_tensor(np_data1)
if paddle.ParallelEnv().local_rank == 0:
data2 = paddle.to_tensor(np_data2)
paddle.distributed.scatter(data1, src=1)
if paddle.distributed.ParallelEnv().local_rank == 0:
else:
paddle.distributed.scatter(data1, src=1)
paddle.distributed.scatter(data1, tensor_list=[data1, data2], src=1)
else:
out = data1.numpy()
paddle.distributed.scatter(data1, tensor_list=[data1, data2], src=1)
out = data1.numpy()
"""
"""
op_type
=
'c_scatter'
op_type
=
'c_scatter'
global
_default_group
global
_default_group
...
@@ -425,13 +430,13 @@ def barrier(group=0):
...
@@ -425,13 +430,13 @@ def barrier(group=0):
Examples:
Examples:
.. code-block:: python
.. code-block:: python
import paddle
import paddle
import paddle.prepare_context as prepare_context
from paddle.distributed import init_parallel_env
paddle.disable_static()
paddle.disable_static()
paddle.set_device('gpu:%d'%paddle
.ParallelEnv().dev_id)
paddle.set_device('gpu:%d'%paddle.distributed
.ParallelEnv().dev_id)
prepare_context
()
init_parallel_env
()
paddle.distributed.barrier()
paddle.distributed.barrier()
"""
"""
op_type
=
'barrier'
op_type
=
'barrier'
temp
=
paddle
.
fill_constant
([
1
],
dtype
=
"int32"
,
value
=
"1"
)
temp
=
paddle
.
fill_constant
([
1
],
dtype
=
"int32"
,
value
=
"1"
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录