Для выхода из цикла после одного цикла - MPI - PullRequest
0 голосов
/ 22 сентября 2018

Я работаю над программой отправки / получения 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

1 Ответ

0 голосов
/ 22 сентября 2018

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

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...