2

所以这是一个简单的代码片段,它对我来说不起作用,说明期望 4 个项目,得到 55 个。实际上,我想要一个字符串列表并将这个列表拆分到 n_processes 之间以对它们进行计算。分散怎么可能?

from mpi4py import MPI

comm = MPI.COMM_WORLD
size = comm.Get_size()
rank = comm.Get_rank()

if rank == 0:
   data = [(i+1)**2 for i in range(55)]
comm.Scatter(data, root=0)
print rank, data
4

1 回答 1

3

看一下底层的 Scatter API 调用:

http://www.open-mpi.org/doc/v1.5/man3/MPI_Scatter.3.php

Scatter 调用使用 list 参数将列表的一个元素发送到每个进程。您在列表中硬编码了 55 个元素,但听起来您只运行了 4 个进程。要么更改range(55)range(size)(更合适的解决方案),要么运行 55 个进程,以使现有代码正确。

于 2012-11-26T02:40:58.340 回答