Поделиться через


функция MPI_Iallreduce

Объединяет значения из всех процессов и распределяет результат по всем процессам неблокирующим способом.

Синтаксис

int MPIAPI MPI_Iallreduce(
  _In_opt_  const void         *sendbuf,
  _Out_opt_       void         *recvbuf,
  _In_            int          count,
  _In_            MPI_Datatype datatype,
  _In_            MPI_Op       op,
  _In_            MPI_Comm     comm,
  _Out_           MPI_Request  *request
);

Параметры

  • sendbuf [in, необязательный]
    Указатель на данные, отправляемые всем процессам в группе. Число и тип данных элементов в буфере указываются в параметрах count и datatype .

    Если параметр comm ссылается на внутриобщий коммуникатор, можно указать параметр на месте, указав MPI_IN_PLACE во всех процессах. В этом случае входные данные берутся в каждом процессе из буфера получения, где они будут заменены выходными данными.

  • recvbuf [out, optional]
    Указатель на буфер для получения результата операции сокращения.

  • count [in]
    Количество элементов, отправляемых из этого процесса.

  • datatype [in]
    Тип данных каждого элемента в буфере. Этот параметр должен быть совместим с операцией, как указано в параметре op .

  • op [in]
    Операция глобального сокращения, выполняемая. Дескриптор может указывать на встроенную или определяемую приложением операцию. Список предопределенных операций см. в разделе MPI_Op.

  • comm [in]
    Дескриптор MPI_Comm .

  • request [out]
    Дескриптор MPI_Request , представляющий операцию взаимодействия.

Возвращаемое значение

Возвращает MPI_SUCCESS об успешном выполнении. В противном случае возвращаемое значение является кодом ошибки.

В Fortran возвращаемое значение хранится в параметре IERROR .

Fortran

    MPI_IALLREDUCE(SENDBUF, RECVBUF, COUNT, DATATYPE, OP, COMM, REQUEST, IERROR)
        <type> SENDBUF(*), RECVBUF(*)
        INTEGER COUNT, DATATYPE, OP, COMM, REQUEST, IERROR

Комментарии

Неблокирующий вызов инициирует коллективную операцию сокращения, которая должна быть завершена в отдельном вызове завершения. После запуска операция может выполняться независимо от любых вычислений или других взаимодействий в участвующих процессах. Таким образом, неблокирующие операции сокращения могут снизить возможные синхронные эффекты операций сокращения, выполняя их в фоновом режиме.

Все вызовы завершения (например, MPI_Wait) поддерживаются для неблокирующих операций сокращения.

Требования

Продукт

Microsoft MPI версии 7

Заголовок

Mpi.h; Mpif.h

Библиотека

Msmpi.lib

DLL

Msmpi.dll

См. также раздел

Коллективные функции MPI

MPI_Datatype

MPI_Op

MPI_Allreduce

MPI_Test

MPI_Testall

MPI_Testany

MPI_Testsome

MPI_Wait

MPI_Waitall

MPI_Waitany

MPI_Waitsome