次の方法で共有


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, optional]
    グループ内のすべてのプロセスに送信されるデータへのポインター。 バッファー内の要素の数値とデータ型は、 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 v7

ヘッダー

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