使用NumPy在MPI4Py中发送和接收结构化数组数据

时间:2012-07-11 07:43:23

标签: python numpy mpi

我正在尝试使用NumPy中的结构化数组在MPI4Py中发送和接收数据。以下是我的数组结构:

numpy.zeros(FILE_LINES, dtype='i4,54b')

我使用Sendrecv方法交换数据,如下所示:

comm.Sendrecv(data_send, dest=partner_rank, sendtag=data_tag, \
        recvbuf=data_receive, source=partner_rank, recvtag=data_tag, status=None)

但是在调用通信方法时我得到一个例外:

Traceback (most recent call last):
  File "bipy.py", line 91, in <module>
  bitonic_sort()
File "bipy.py", line 72, in bitonic_sort
  bitonic_merge(i, ixj, (i & k) == 0)
File "bipy.py", line 51, in bitonic_merge
  recvbuf=data_receive, source=partner_rank, recvtag=data_tag, status=None)
File "Comm.pyx", line 166, in mpi4py.MPI.Comm.Sendrecv (src/mpi4py.MPI.c:58898)
File "message.pxi", line 318, in mpi4py.MPI.message_p2p_send (src/mpi4py.MPI.c:21422)
File "message.pxi", line 301, in mpi4py.MPI._p_msg_p2p.for_send (src/mpi4py.MPI.c:21285)
File "message.pxi", line 111, in mpi4py.MPI.message_simple (src/mpi4py.MPI.c:19256)
File "message.pxi", line 58, in mpi4py.MPI.message_basic (src/mpi4py.MPI.c:18509)
KeyError: 'T{=l:f0:(54)b:f1:}'

使用只有一种数据类型的数组(例如所有字节)时,它可以正常工作。 MPI4Py无法发送这些结构化数组,还是我做错了什么?

1 个答案:

答案 0 :(得分:3)

正如Jonathan Dursi在评论中已经提到的:具有大写首字母的通信例程(例如Sendrecv())只能传达“内存缓冲区”,即提供某个C API的数据结构。结构化数组似乎不是这样的数据结构。 无论如何要发送它,请使用sendrecv()

请参阅http://mpi4py.scipy.org/docs/usrman/mpi4py.html处的MPI4Py文档。