MPI一个计数器用于所有进程

MPI one counter for all the process

本文关键字:用于 进程 计数器 一个 MPI      更新时间:2023-10-16

我正在试验MPI,到目前为止,我有一个小程序可以计算一个简单的和:

#include <mpi.h>
#include <stdio.h>
int main(int argc, char *argv[]){
int i=0, myid, nproc,N=5;
double result=0.0,res;
MPI_Init(&argc, &argv);
MPI_Comm_rank(MPI_COMM_WORLD, &myid);
MPI_Comm_size(MPI_COMM_WORLD, &nproc);
MPI_Bcast(&N, 1, MPI_INT, 0, MPI_COMM_WORLD);
while (i<N) { 
    result += i;
    i++;
    printf("process %d i %dn",myid,i);
    MPI_Reduce(&result, &res, 1, MPI_DOUBLE,MPI_SUM, 0, MPI_COMM_WORLD);
}
if (myid == 0)
{
    printf("result = %lfn", res);
}
MPI_Finalize();
}

根据打印的结果,我可以看到i在每个过程中都达到了极限(5)。如何将其配置为保留类似全局计数器的东西,以便所有进程的i只达到一次限制?

MPI没有自动全局计数器。我认为您将不得不手动将增量传达给计数器。