MPI是所有流程的一个柜台

时间:2016-05-18 18:00:30

标签: c++ c mpi

我正在尝试使用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 %d\n",myid,i);
    MPI_Reduce(&result, &res, 1, MPI_DOUBLE,MPI_SUM, 0, MPI_COMM_WORLD);
}
if (myid == 0)
{
    printf("result = %lf\n", res);
}
MPI_Finalize();

}

根据打印结果,我可以看到i达到每个进程的限制(5)。如何将其配置为保留类似全局计数器的内容,以使i仅对所有进程达到限制一次?

1 个答案:

答案 0 :(得分:0)

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