Dela via


funktionen MPI_Ireduce

Utför en global reduce-åtgärd (till exempel summa, maximum eller logisk och) för alla medlemmar i en grupp på ett icke-blockerande sätt.

Syntax

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

Parametrar

  • sendbuf [in]
    Pekaren till en buffert som innehåller data från den här rangordningen som ska användas i reduceringen. Bufferten består av antal efterföljande element i MPI_Datatype som anges av datatypshandtaget . Meddelandelängden anges i termer av antal element, inte antal byte.

  • recvbuf [ut, valfritt]
    Pekaren till en buffert för att ta emot resultatet av reduce-åtgärden. Den här parametern är bara viktig i rotprocessen.

  • count [in]
    Antalet element som ska skickas från den här processen.

  • datatype [in]
    Det MPI_Datatype hantera som representerar datatypen för varje element i sendbuf.

  • op [in]
    Den MPI_Op hantera som anger den globala minskningsåtgärd som ska utföras. Handtaget kan indikera en inbyggd åtgärd eller en programdefinierad åtgärd. En lista över fördefinierade åtgärder finns i avsnittet MPI_Op .

  • root [in]
    Rangordningen för den mottagande processen inom MPI_Commkommatecken.

  • comm [in]
    MPI_Comm communicator-handtaget.

  • begäran [ut]
    Den MPI_Request hantera som representerar kommunikationsåtgärden..

Returvärde

Returnerar MPI_SUCCESS vid lyckat resultat. Annars är returvärdet en felkod.

I Fortran lagras returvärdet i parametern IERROR .

Fortran

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

Kommentarer

Ett icke-blockerande anrop initierar en kollektiv minskningsåtgärd som måste slutföras i ett separat slutförandeanrop. När åtgärden har initierats kan den fortsätta oberoende av beräkningen eller annan kommunikation i deltagande processer. På så sätt kan icke-blockerande minskningsåtgärder minimera möjliga synkroniseringseffekter av minskningsåtgärder genom att köra dem i "bakgrunden".

Alla slutförandeanrop (t.ex. MPI_Wait) stöds för icke-blockerande minskningsåtgärder.

Krav

Produkt

Microsoft MPI v6

Huvud

Mpi.h; Mpif.h

Bibliotek

Msmpi.lib

DLL

Msmpi.dll

Se även

Kollektiva MPI-funktioner

MPI_Datatype

MPI_Op

MPI_Reduce

MPI_Test

MPI_Testall

MPI_Testany

MPI_Testsome

MPI_Wait

MPI_Waitall

MPI_Waitany

MPI_Waitsome