相关疑难解决方法(0)

通过MPI命令行传递参数

我正在使用MPI调用使用c ++在多个进程上运行一个过程.我的Main函数中的前几行看起来像:

int main(int argc, char *argv[]){
int comm_sz;
int my_rank;

MPI_Init(&argc, &argv);
MPI_Comm_size(MPI_COMM_WORLD, &comm_sz);
MPI_Comm_rank(MPI_COMM_WORLD, &my_rank);

x = atoi(argv[4]);
y = atoi(argv[5]);
Run Code Online (Sandbox Code Playgroud)

现在当我执行并运行我的程序时

mpiexec -n 1 program 10 10
Run Code Online (Sandbox Code Playgroud)

我希望x和y被赋值为10和10,因为它们是传递的第4和第5个参数.但这不会发生,它会相应地将这些变量分配给0和0.并且我的程序没有按预期运行.

当我更改这些数字时,我的串行代码正在运行.它只是我是MPI的新手.

你能说明我哪里出错吗?

c++ mpi

18
推荐指数
1
解决办法
1万
查看次数

标签 统计

c++ ×1

mpi ×1