MPI_Iscatterv関数
構文
int MPIAPI MPI_Iscatterv(
_In_opt_ const void *sendbuf,
_In_opt_ const int sendcounts[],
_In_opt_ const int displs[],
_In_ MPI_Datatype sendtype,
_Out_opt_ void *recvbuf,
_In_ int recvcount,
_In_ MPI_Datatype recvtype,
_In_ int root,
_In_ MPI_Comm comm,
_Out_ MPI_Request *request
);
パラメーター
sendbuf [in, optional]
ルート プロセスによって送信されるデータを含むバッファーへのポインター。このパラメーターは、ルート以外のすべてのプロセスでは無視されます。
comm パラメーターがコマンド内を参照している場合は、ルート プロセスで MPI_IN_PLACE を指定することでインプレース オプションを指定できます。 recvcount パラメーターと recvtype パラメーターは無視されます。 分散ベクトルは、n 個 のセグメントを 含んでいると見なされます。 ここで、n はグループ サイズです。ルート プロセスに対応するセグメントは移動されません。
sendcounts[] [in, optional]
各プロセスに送信する要素の数。 sendcounts[i] が 0 の場合、そのプロセスのメッセージのデータ部分は空です。このパラメーターは、ルート以外のすべてのプロセスでは無視されます。
displs[] [in, optional]
各コミュニケーター プロセスに送信するデータの場所。 配列内の各位置は、 sendbuf 配列の対応する要素に対する相対位置です。sendbuf、sendcounts、displs パラメーター配列では、各配列の n番目の要素は、n番目のコミュニケーター プロセスに送信されるデータを参照します。
このパラメーターは、ルート プロセスでのみ重要です。
sendtype [in]
バッファー内の各要素のデータ型。このパラメーターは、ルート以外のすべてのプロセスでは無視されます。
recvbuf [out, optional]
各プロセスで受信されるデータを含むバッファーへのポインター。 バッファー内の要素の数値とデータ型は、 recvcount パラメーターと recvtype パラメーターで指定されます。recvcount [in]
受信バッファー内の要素の数。 カウントが 0 の場合、メッセージのデータ部分は空です。recvtype [in]
受信バッファー内の要素のデータ型。root [in]
指定したコミュニケーター内の送信プロセスのランク。comm [in]
MPI_Comm コミュニケーター ハンドル。request [out]
通信操作を表す MPI_Request ハンドル。
戻り値
成功 したMPI_SUCCESS を返します。 それ以外の場合、戻り値はエラー コードです。
Fortran では、戻り値は IERROR パラメーターに格納されます。
Fortran
MPI_ISCATTERV(SENDBUF, SENDCOUNTS, DISPLS, SENDTYPE, RECVBUF, RECVCOUNT, RECVTYPE, ROOT, COMM, REQUEST, IERROR)
<type> SENDBUF(*), RECVBUF(*)
INTEGER SENDCOUNTS(*), DISPLS(*), SENDTYPE, RECVCOUNT, RECVTYPE, ROOT, COMM, REQUEST, IERROR
注釈
非ブロッキング呼び出しは、個別の完了呼び出しで完了する必要がある一括削減操作を開始します。 開始されると、操作は、参加プロセスでの計算やその他の通信とは無関係に進行する可能性があります。 この方法では、非ブロッキング削減操作は、"バックグラウンド" で実行することで、削減操作の同期効果を軽減できます。
非ブロッキング削減操作では、すべての完了呼び出し ( MPI_Waitなど) がサポートされています。
要件
製品 |
Microsoft MPI v7 |
ヘッダー |
Mpi.h;Mpif.h |
ライブラリ |
Msmpi.lib |
[DLL] |
Msmpi.dll |