我正在使用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的新手.
你能说明我哪里出错吗?