我希望使用MPI在两个节点之间发送连续的内存数组。为此,我使用以下非阻塞发送/接收命令(MPI_Isend,MPI_Irecv)。执行run命令时,我看到两个警告语句如下:
Warning: Program exiting with outstanding receive requests
基本上,我想看到来自“NorthEdge1”的数组数据传递给“NorthofNorthEdge3”。我怎么能解决这个问题?还有什么我可以尝试检查这种沟通?
以下是源代码的摘录:
#define Rows 48
...
double *northedge1 = new double[Rows];
double *northofnorthedge3 = new double[Rows];
...
...
int main (int argc, char *argv[])
{
....
....
MPI_Request send_request, recv_request;
...
...
{
MPI_Isend(northedge1, Rows, MPI_DOUBLE, my_rank+1, 0, MPI_COMM_WORLD, &send_request);
MPI_Irecv(northofnorthedge3, Rows, MPI_DOUBLE, my_rank+1, MPI_ANY_TAG, MPI_COMM_WORLD,
&recv_request);
}
答案 0 :(得分:3)
看起来你还没有打电话给MPI_Waitall()
。 “立即”发送和接收例程仅开始通信。您必须阻止您的流程以确保通信已完成。 MPI中的阻止使用MPI_Wait()
的变体;在您的情况下,您需要MPI_Waitall()
。