将分布式数组或gpuArray转移到本地工作区
X =收集(
可以对以下阵列数据进行操作:一个
)
在gpuArray上:传输的元素一个
从GPU到本地工作区,并将它们分配给X
.
在分布式数组上,在spmd
语句:集合元素一个
从多个工作人员到本地工作区,并将它们分配给X
.
在一个协分布数组中spmd
陈述或沟通工作:将下列要素集合在一起一个
并将它们复制成X
在每一个工人。
你可以叫收集
其他数据类型,如高数组(参见收集(高)
).如果数据类型不支持收集,则万博1manbetx收集
没有效果。
收集GPU阵列或分布式阵列成本很高,通常没有必要,除非您需要将结果与不支持这些类型阵列的函数一起使用。万博1manbetx有关函数支持的更多信息,请参见万博1manbetx在GPU上运行MATLAB函数或使用分布式数组运行MATLAB函数.
X =收集(gpuArray (X))
,X =收集(分布式(X))
,或X =收集(codistributed (X))
返回原始数组X
.
(X1, X2,…,Xn] = gather(A1,A2,...,,Xn)
收集多个数组A1, A2,…,,
输入相应的输出X1, X2,…,Xn
.输入参数和输出参数的数量必须匹配。
X =收集(C、实验室)
转换协分布数组C
到一个可变数组X
,这样所有的元素都包含在worker上实验室
,X
是所有其他工人的一个0乘0的空替身。
(X1, X2,…,Xn] = gather(C1,C2,...,Cn,lab)
收集codistributed数组C1, C2,…,Cn
到相应的输出X1, X2,…,Xn
,所有元素都在worker上实验室
.输入参数和输出参数的数量必须匹配。
请注意,收集
分别在它执行的所有工作人员的工作空间或MATLAB客户端上组装协同分布或分布式数组,但不是两者。如果你正在使用收集
在一个spmd
语句,则在客户机上通过其相应的复合
对象;看到使用composite访问Worker变量.如果你在跑步收集
在通信作业中,可以将收集的数组作为任务的输出参数返回给客户端。
随着收集
函数需要所有工作人员之间的通信,您不能通过将函数放在一个条件语句中(例如)来将所有工作人员的数据收集到单个工作人员上如果labindex == 1
.