gpt4 book ai didi

c++ - 如何使用 MPI Allreduce 添加 Armadillo vector ?

转载 作者:行者123 更新时间:2023-11-30 02:34:50 38 4
gpt4 key购买 nike

我想对 Armadllio vector 执行 MPI_Allreduce 操作,但我得到 0 输出。本质上,我每个处理器都有 arma vector v。使用 MPI_Allreduce,我想添加 w 中的所有 vector 。我不确定是否必须添加一些同步。下面是我的代码。

#include <iostream>
#include <stdlib.h>
#include <mpi.h>
#include <math.h>
#include <assert.h>
#include<armadillo>

using namespace std;
using namespace arma;

int main(int argc, char** argv) {


MPI_Init(NULL, NULL);

int world_rank;
MPI_Comm_rank(MPI_COMM_WORLD, &world_rank);
int world_size;
MPI_Comm_size(MPI_COMM_WORLD, &world_size);

vec v(2,fill::randu);

vec w(2,fill::zeros);

MPI_Allreduce(&w, &v, 1, MPI_DOUBLE, MPI_SUM, MPI_COMM_WORLD);
if(world_rank==0)
cout<<"w: "<<w<<endl;
MPI_Finalize();
}

我的输出:

 w:     0
0

最佳答案

MPI_Allreduce 调用有两个问题。首先,您的 vec 中有 2 个 double,因此计数应该为 2。其次,您已经切换了发送和接收缓冲区。

int MPI_Allreduce ( void *sendbuf, void *recvbuf, int count, MPI_Datatype datatype, MPI_Op op, MPI_Comm comm )

所以你的命令应该是:

MPI_Allreduce(&v, &w, 2, MPI_DOUBLE, MPI_SUM, MPI_COMM_WORLD);

假设 Armadillo vector 中保存的数据从类/结构本身的第一个字节开始连续存储,这应该可以正常工作。

编辑:我仔细查看了 Armadillo 文档。有一个函数 memptr() 返回指向数据本身的指针。这是您应该用于 MPI_Allreduce() 而不是 &vector 的内容。因此,您的实际函数调用应该是:

MPI_Allreduce(v.memptr(), w.memptr(), 2, MPI_DOUBLE, MPI_SUM, MPI_COMM_WORLD);

关于c++ - 如何使用 MPI Allreduce 添加 Armadillo vector ?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34272356/

38 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com