split¶
- paddle.distributed. split ( x, size, operation, axis=0, num_partitions=1, gather_out=True, weight_attr=None, bias_attr=None, name=None ) [源代码] ¶
切分指定操作的参数到多个设备,并且并行计算得到结果。
当前,支持一下三种情形。
- 情形1:并行Embedding
-
Embedding操作的参数是个NxM的矩阵,行数为N,列数为M。并行Embedding情形下,参数切分到num_partitions个设备,每个设备上的参数是 (N/num_partitions + 1)行、M列的矩阵。其中,最后一行作为padding idx。
假设将NxM的参数矩阵切分到两个设备device_0和device_1。那么每个设置上的参数矩阵为(N/2+1)行和M列。device_0上,输入x中的值如果介于[0, N/2-1],则其值保持不变;否则值变更为N/2,经过embedding映射为全0值。类似地,device_1上,输入x中的值V如果介于[N/2, N-1]之间,那么这些值将变更为(V-N/2);否则,值变更为N/2,经过embedding映射为全0值。最后,使用all_reduce_sum操作汇聚各个卡上的结果。
- 情形2:行并行Linear
-
Linear操作的参数是个NxM的矩阵,行数为N,列数为M。行并行Linear情形下,参数切分到num_partitions个设备,每个设备上的参数是N/num_partitions行、M列的矩阵。
- 情形3:列并行Linear
-
Linear操作的参数是个NxM的矩阵,行数为N,列数为M。列并行Linear情形下,参数切分到num_partitions个设备,每个设备上的参数是N行、M/num_partitions列的矩阵。
参数¶
x (Tensor) - 输入Tensor。Tensor的数据类型为:float16、float32、float64、int32、int64。
size (list|tuple) - 指定参数形状的列表或元组,包含2个元素。
operation (str) - 指定操作名称,当前支持的操作名称为'embedding'或'linear'。
axis (int,可选) - 指定沿哪个维度切分参数。默认值:0。
num_partitions (int,可选) - 指定参数的划分数。默认值:1。
gather_out (bool,可选) - 是否聚合所有设备的计算结果。默认地,聚合所有设备的计算结果。默认值:True。
weight_attr (ParamAttr,可选) - 指定参数的属性。默认值:None。
bias_attr (ParamAttr,可选) - 指定偏置的属性。默认值:None。
name (str,可选) - 默认值为None,通常用户不需要设置该属性。更多信息请参考 Name 。
返回¶
Tensor
代码示例¶
import paddle
from paddle.distributed import init_parallel_env
paddle.set_device('gpu:%d'%paddle.distributed.ParallelEnv().dev_id)
init_parallel_env()
data = paddle.randint(0, 8, shape=[10,4])
emb_out = padle.distributed.split(
data,
(8, 8),
operation="embedding",
num_partitions=2)