Why does MPI_Init accept pointers to argc and argv?

后端 未结 5 869
深忆病人
深忆病人 2021-01-01 11:12

this is how we use MPI_Init function

int main(int argc, char **argv)
{
    MPI_Init(&argc, &argv);
…
}

why does MPI_Init use pointe

相关标签:
5条回答
  • 2021-01-01 11:49

    According to the answer stated here:

    Passing arguments via command line with MPI

    Most MPI implementations will remove all the mpirun-related arguments in this function so that, after calling it, you can address command line arguments as though it were a normal (non-mpirun) command execution.

    i.e. after

    mpirun -np 10 myapp myparam1 myparam2
    

    argc = 7(?) because of the mpirun parameters (it also seems to add some) and the indices of myparam1 and myparam2 are unknown

    but after

    MPI_Init(&argc, &argv)
    

    argc = 3 and myparam1 is at argv[1] and myparam2 is at argv[2]

    Apparently this is outside the standard, but I've tested it on linux mpich and it certainly seems to be the case. Without this behaviour it would be very difficult (impossible?) to distinguish application parameters from mpirun parameters.

    0 讨论(0)
  • 2021-01-01 11:50

    I'm not an expert but I believe the simple answer is that each node that you're working with is working with its own copy of the code. Passing these arguments allows each of the nodes to have access to argc and argv even though they were not passed them through the command line interface. The original or master node that calls MPI_Init is passed these arguments. MPI_Init allows the other nodes to access them as well.

    0 讨论(0)
  • 2021-01-01 12:08

    According to OpenMPI man pages: MPI_Init(3) man page

    Open MPI accepts the C/C++ argc and argv arguments to main, but neither modifies, interprets, nor distributes them.

    0 讨论(0)
  • 2021-01-01 12:09

    my guess to potentially allow to remove mpi arguments from commandline. passing argument count by pointer allows to modify its value from the point of main.

    0 讨论(0)
  • 2021-01-01 12:13

    It is less overhead to just pass two pointers.

    0 讨论(0)
提交回复
热议问题