MPI_Irecv问题

时间:2018-10-05 01:08:30

标签: c mpi hpc

我正在编写一个简单的MPI程序,该程序允许进程使用无阻塞通信将随机数发送到下一个等级,并且还接收下一个等级的随机数。

例如:

Process 0 sends 1 to process 1
Process 1 received 1 from Process 0
Process 1 sends 3 to process 0
Process 0 received 3 from Process 1

我尝试过:

#include <stdio.h>
#include "mpi.h"
#include <time.h>
#include <stdlib.h>

int main(int argc, char *argv[])
{
    int rank,size; //rank and size of the process.
    int value; //the random value generated.

    int nreq;
    int buf[1]; //receiving buffer

    MPI_Init(&argc,&argv); //initialize MPI environment

    MPI_Request req[2];
    MPI_Status stat[2];

    MPI_Comm_rank(MPI_COMM_WORLD,&rank); //processes rank
    MPI_Comm_size(MPI_COMM_WORLD,&size); //total size of process

    if (rank < 2) { //if process rank is less than 2, means we want those to generate random numbers.
        nreq = 0;
        srand(time(NULL)+rank); //seed for the random number generator.
        value = rand() % 10; //generate the random number based of the seed value
        //printf("Process of rank %d generated the value 
          //%d\n",rank,value);

      MPI_Isend(&value,1,MPI_INT,rank+1,0,MPI_COMM_WORLD,&req[nreq++]);
      printf("Node %d sent %d to node %d\n",rank,value,rank+1);

     MPI_Irecv(&buf[0],1,MPI_INT,rank+1,1,MPI_COMM_WORLD,&req[nreq++]);
     printf("Node %d received %d from node %d\n",rank+1,buf[0],rank);

     MPI_Waitall(nreq,req,stat);
 }

MPI_Finalize();
return 0;

}

但是我收到错误提示

mpirun detected that one or more processes exited with non-zero status,thus causing the job to be terminated.

0 个答案:

没有答案