Я работаю над программой отправки / получения MPI, и по какой-то причине цикл повторяется только один раз, а затем завершается. Кто-нибудь знает, почему?

Код:

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

int main(int argc, char *argv[]) {
    int rank;
    int b2, a1;
    MPI_Status status;
    MPI_Init(NULL, NULL);
    MPI_Comm_rank(MPI_COMM_WORLD, &rank);

    for (int j = 0; j < 100; j++) {
        if (rank == 0) {
            a1 = 10;
            MPI_Sendrecv(&a1, 1, MPI_INT, 1, 99,
                    &b2, 1, MPI_INT, 1, 99,
                    MPI_COMM_WORLD, MPI_STATUS_IGNORE);

        } else {
            a1 = 20;
            MPI_Sendrecv(&a1, 1, MPI_INT, 0, 99,
                    &b2, 1, MPI_INT, 0, 99,
                    MPI_COMM_WORLD, MPI_STATUS_IGNORE);
        }
    }

    printf("Process %d: received %d\n", rank, b2);
    MPI_Finalize();

}

Результат (это должно повторяться несколько раз, но это все, что я получаю):

Process 1: received 10
Process 0: received 20
0
the_martian 22 Сен 2018 в 07:54

1 ответ

Лучший ответ

Ваш printf() не в курсе. Неудивительно, что он печатается только один раз.

2
John Zwinck 22 Сен 2018 в 05:02