/** * This is a simple program to demonstrate the correct usage of two MPI colletive operations, * i.e., they have to be executed in the same order for each process. */ #include #include #include #include int main(int argc, char * argv[]) { int rank; int procs; int* sendBuf; int* rcvBuf; MPI_Init(&argc,&argv); MPI_Comm_size(MPI_COMM_WORLD, &procs); MPI_Comm_rank(MPI_COMM_WORLD, &rank); if (rank == 0) { sendBuf = (int*)malloc(sizeof(int)*procs); //rcvBuf = (int*)malloc(sizeof(int)*procs); for(int i=0; i < procs; i++) sendBuf[i] = i; }else{ sendBuf = (int*)malloc(sizeof(int)); } rcvBuf = (int*)malloc(sizeof(int)*procs); MPI_Scatter(sendBuf, 1, MPI_INT, rcvBuf, 1, MPI_INT, 0, MPI_COMM_WORLD); *sendBuf = *rcvBuf + rank; MPI_Allgather(sendBuf, 1, MPI_INT, rcvBuf, 1, MPI_INT, MPI_COMM_WORLD); printf("receive buffer of process %d:\n", rank); for(int i=0; i