作者热门文章
- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我将来自每个进程的大量数组元素加在一起:
double rho[1024];
//Some operation to calculate rho for each process;
MPI_Allreduce(rho,rho,1024,MPI_DOUBLE,MPI_SUM,MPI_COMM_WORLD);
将 rho 作为 sendbuf 和 recvbuf 都有效吗?
最佳答案
您检查过 MPI_IN_PLACE
了吗?根据MPI_AllReduce man page和 MPI doc只要您在同一组内工作,它就可以用于为 sendbuf 和 recvbuf 指定相同的缓冲区。
调用看起来像:
MPI_Allreduce(MPI_IN_PLACE,rho,1024,MPI_DOUBLE,MPI_SUM,MPI_COMM_WORLD);
关于MPI sendbuf 和 recvbuf 可以是一回事吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16507865/
我是一名优秀的程序员,十分优秀!