C语言gather结束循环,c/c++开发分享如何在循环中重用MPI_Scatter和MPI_Gather

我试图学习如何多次使用MPI_Scatter和MPI_Gather ,并在等待这两个MPI函数完成后打印出结果。 在进程0,程序的顶部,我想使用一个调用Scatter和Gather的while循环。 完成所有计算后,我想将此数组发送回这些函数以进行更多计算。 我在下面的代码中解释了我想要做什么。 /*.....*/中的注释是我想要实现的任务。

以下代码使用4个处理器运行。

:$ mpicc test.c -o test

:$ mpirun -np 4 test

#include #include #include int main(int argc, char **argv) { int size, rank; MPI_Init(&argc, &argv); MPI_Comm_size(MPI_COMM_WORLD, &size); MPI_Comm_rank(MPI_COMM_WORLD, &rank); int globaldata[8]; int localdata[2]; int counter, i; if (rank == 0) { for (i=0; i

关于我上面尝试做什么的更多解释:我想将globaldata数组发送到所有处理器。 然后获取更新的globaldata数组。 一旦我得到更新的数组,我想再次将此数组重新发送回所有其他进程以进行更多计算。 我编写了以下代码,使用MPI_Send和MPI_Recv执行类似的工作。 这里我使用MPI_Send将我的arrays发送到所有处理器。 然后这个数组将改变它并发送回根/进程0.一旦我得到修改后的数组, do while循环将再次运行并执行更多计算。 我想要做的是:以类似的方式使用MPI_Scatter和MPI_Gather。 我在哪里获得更新的globaldata数组并将其发送回MPI_Scatter和MPI_Gather以再次更改该数组

#include #include #include int main(int argc, char **argv) { int size, rank; MPI_Init(&argc, &argv); MPI_Comm_size(MPI_COMM_WORLD, &size); MPI_Comm_rank(MPI_COMM_WORLD, &rank); int globaldata[8]; int counter, i; if (rank == 0) { for (i=0; i

只需将散布和聚集与循环中的本地处理放在一起:

if (rank == 0) { for (i = 0; i < size*2; i++) globaldata[i] = 0; } for (counter = 0; counter < 2; counter++) { // if (rank == 0) // { // pre-process globaldata // } MPI_Scatter(globaldata, 2, MPI_INT, localdata, 2, MPI_INT, 0, MPI_COMM_WORLD); localdata[0] += rank; localdata[1] += rank; MPI_Gather(localdata, 2, MPI_INT, globaldata, 2, MPI_INT, 0, MPI_COMM_WORLD); // if (rank == 0) // { // post-process globaldata // } } if (rank == 0) { printf("Finally at Processor %d has data: ", rank); for (i=0; i

或者,如果您希望将“主”流程的逻辑分开:

if (rank == 0) { for (i = 0; i < size*2; i++) globaldata[i] = 0; for (counter = 0; counter < 2; counter++) { // pre-process globaldata MPI_Scatter(globaldata, 2, MPI_INT, localdata, 2, MPI_INT, 0, MPI_COMM_WORLD); // Not really useful as rank == 0 and it changes nothing localdata[0] += rank; localdata[1] += rank; MPI_Gather(localdata, 2, MPI_INT, globaldata, 2, MPI_INT, 0, MPI_COMM_WORLD); // post-process globaldata } printf("Finally at Processor %d has data: ", rank); for (i=0; i

确保代码的两个部分中的循环具有相同的迭代次数。 另请注意, MPI_Scatter将一大块MPI_Scatter发送到根级别,并且globaldata会从根级收集一大块数据,因此主进程也需要执行一些数据处理。

以上就是c/c++开发分享如何在循环中重用MPI_Scatter和MPI_Gather相关内容,想了解更多

本文来自网络收集,不代表猴子技术宅立场,如涉及侵权请点击右边联系管理员删除。

如若转载,请注明出处:https://www.ssfiction.com/c-cyuyankaifa/549381.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值