如何使用MPI Allreduce添加armadillo矢量
How can I add armadillo vectors using MPI Allreduce?
我想对Armadllio向量执行MPI_Allreduce operation
,但我得到了0输出。本质上,我每个处理器都有arma向量v。使用MPI_Allreduce,我想添加w中的所有向量。我不确定是否必须添加一些同步。下面是我的代码。
#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数据类型,MPI_Op Op,MPI_Comm Comm)
所以你的命令应该是:
MPI_Allreduce(&v, &w, 2, MPI_DOUBLE, MPI_SUM, MPI_COMM_WORLD);
假设armadillo向量中的数据从类/结构本身的第一个字节开始连续存储,这应该可以正常工作。
编辑:我仔细看了一下armadillo文档。有一个函数memptr()
,它返回一个指向数据本身的指针。这是您应该用于MPI_Allreduce()
而不是&vector
的内容。因此,您的实际函数调用应该是:
MPI_Allreduce(v.memptr(), w.memptr(), 2, MPI_DOUBLE, MPI_SUM, MPI_COMM_WORLD);
相关文章:
- 分段故障(堆芯转储)矢量
- 为什么在popback()操作之后,它仍然打印完整的矢量
- 将二维矢量传递给类
- 读取文件并输入到矢量中
- 将Integer转换为4字节的unsined字符矢量(按大端字节顺序)
- 无法通过空白将文本文件行分隔为矢量
- C++-试图将函数指针推回到另一个CPP文件中的矢量时出错
- 正在将csv文件读取为双精度矢量
- 如何将两个不同矢量的同一位置的两个元素组合在一起
- 有可能在Armadillo中复制MATLAB circshift方法吗
- 如何通过 getter 函数删除矢量的元素?
- 如何在C++中将数组转换为矢量指针
- 在C++中将矢量转换为嵌套地图
- C++矢量迭代
- 从矢量<无符号字符>转换为字符* 包括垃圾数据
- 将矢量<T>转换为矢量<数组<T>>
- 指针或结构的矢量
- 为什么文件名被设置为一个点,而不是在读取矢量中的文件名时
- r-(C ,Armadillo)从矩阵中更换列矢量的一部分
- 如何使用MPI Allreduce添加armadillo矢量