c - 数组接收的 MPI 总和仅适用于一个级别

标签 c mpi distributed-computing

我正在尝试使用 MPI 查找长度为 100 个元素的数组的总和,在仅使用 MPI_Send 和 MPI_receive 的限制下,我编写的代码找到了每个处理器的总和,但是在重新发送到主处理器(rank=0)我的代码只从一个处理器接收

我的代码

#include "stdafx.h"
#include <stdio.h>
#include <string.h>
#include "mpi.h"
#include "math.h"

int val = 1;
int main(int argc, char* argv[]) {

    int my_rank;
    int p;
    int ierr;
    int i;
    int a[100];
    int q=0;
    for (i = 0; i <100; i++)
    {
        a[i] = i+1;
    }
    int send,recv;
    MPI_Status status;
    MPI_Init(&argc, &argv);
    MPI_Comm_rank(MPI_COMM_WORLD, &my_rank);
    MPI_Comm_size(MPI_COMM_WORLD, &p);
    int part = 100 /(p-1);
    if (my_rank == 0)
    {
        for (i = 1; i < p; i++)
        {
            send = part * (i-1);
            MPI_Send(&send, 1, MPI_INT, i, 0, MPI_COMM_WORLD);
        }

    }
    else
    {
        MPI_Recv(&recv, 1, MPI_INT, 0, 0, MPI_COMM_WORLD, &status);
        for (i = recv; i < recv + part; i++)
        {
            val = val+a[i];

        }
        printf("%d\n", val);
        MPI_Send(&val, 1, MPI_INT, 0, 0, MPI_COMM_WORLD);
    }
    if (my_rank == 0)
    {
        MPI_Recv(&val, 1, MPI_INT, MPI_ANY_SOURCE, 0, MPI_COMM_WORLD, &status);
        printf("%d", val);
        q = q + val;

    }
    MPI_Finalize();
    if (my_rank == 0)
    {
        printf("The output is %d\n", q);
    }
    return 0;
}

我的输出 enter image description here

我哪里错了

最佳答案

因为您只收到一个过程的结果。要接收所有结果,迭代进程等级:

if (my_rank == 0)
{
    for (rank = 1; rank < proc_cnt; rank++)
    {
        MPI_Recv(&val, 1, MPI_INT, rank, 0, MPI_COMM_WORLD, &status);
        printf("value of rank %d is %d", rank, val);
        q = q + val;
    }

}

通常,这是一种不好的做法,可能会导致死锁。如果允许,请使用 mpi_gather()

关于c - 数组接收的 MPI 总和仅适用于一个级别,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52456238/

相关文章:

c - 带有 MPI_Comm_spawn 的参数 -NP

Matlab的日记+作业调度器

linux - 在我的机器上抵制 Condor 的脚本,没有 root 权限

C/Bison语法错误

c - 关于 "->"和 "."的真实情况

c++ - MPI_Recv - 如何确定计数?

linux - 如何在 Linux 中使用多 CPU 来加快计算速度

不断分配内存使系统崩溃以及如何为标准用户阻止它

c++ - C99 风格的 VLA 有哪些技术缺点?

web - SOA 和微服务有什么区别