c++ - MPI 一个计数器涵盖所有流程

标签 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所有进程仅达到一次限制?

最佳答案

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

关于c++ - MPI 一个计数器涵盖所有流程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37307026/

相关文章:

c++ - C++对象应该如何序列化?

c - MPI:如何将多个处理器中的子数组连接成一个更大的单个数组

c++ - Const 正确性——Const 指针作为函数参数

c++-设置一个接受值列表的数组

c - 为什么打印 255

c - 作为二元运算的数学函数

fortran - 如果使用不是直接从 MPI_COMM_WORLD 创建的组,则 Fortran MPI_COMM_CREATE_GROUP 中的段错误

c++ - 如何从路径加载 QImage?

python - 在 C++ 中使用 jinja2 时的无效结果

c - kernel/sched.c/context_switch() 是否保证每次进程切换时都会被调用?