Вывод из большего числа процессов, чем указано в аргументах - PullRequest
0 голосов
/ 15 января 2019

Я новичок в mpi и перезапущу приведенный здесь код: http://mpitutorial.com/tutorials/mpi-hello-world/

#include <mpi.h>
#include <stdio.h>


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

// Initialize the MPI environment
MPI_Init(NULL, NULL);

// Get the number of processes
int world_size;
MPI_Comm_size(MPI_COMM_WORLD, &world_size);

// Get the rank of the process
int world_rank;
MPI_Comm_rank(MPI_COMM_WORLD, &world_rank);

// Get the name of the processor
char processor_name[MPI_MAX_PROCESSOR_NAME];
int name_len;
MPI_Get_processor_name(processor_name, &name_len);

// Print off a hello world message
printf("Hello world from processor %s, rank %d out of %d processors\n",
       processor_name, world_rank, world_size);

// Finalize the MPI environment.
MPI_Finalize();
}

Компиляция с использованием mpicc -o mpi_hello_world mpi_hello_world.c и запуск mpiexec -np 4 ./mpi_hello_world

Я ожидаю, что аналогичные результаты приведены на веб-странице

Hello world from processor cetus2, rank 1 out of 4 processors
Hello world from processor cetus1, rank 0 out of 4 processors
Hello world from processor cetus4, rank 3 out of 4 processors
Hello world from processor cetus3, rank 2 out of 4 processors

Но вместо того, чтобы получать выходные данные от 4 процессов, я получаю от 24. Это что-то вроде этого.

Hello world from processor cetus3, rank <n> out of 24 processors

n от 0 до 23. Я использую кластер Linux удаленно. Аналогичный результат, используя mpirun. Если я укажу np - 36, я получу тот же результат для 24 процессов. Может кто-нибудь сказать, что идет не так?

...