Compartilhar via


função MPI_Ibcast

Transmite uma mensagem do processo com a classificação "raiz" para todos os outros processos do comunicador de maneira não bloqueada.

Sintaxe

int MPIAPI MPI_Ibcast(
  _Inout_  void        *buffer,
  _In_    int          count,
  _In_    MPI_Datatype datatype,
  _In_    int          root,
  _In_    MPI_Comm     comm,
  _Out_   MPI_Request  *request
);

Parâmetros

  • buffer [entrada, saída]
    O ponteiro para o buffer de dados. No processo especificado pelo parâmetro raiz do , o buffer contém os dados a serem difundidos. Em todos os outros processos no comunicador especificado pelo parâmetro comm, o buffer recebe os dados transmitidos pelo processo raiz. de buffer consiste em contagem elementos sucessivos do MPI_Datatype indicado pelo identificador de de tipo de dados . O comprimento da mensagem é especificado em termos de número de elementos, não número de bytes.

  • contagem [in]
    O número de elementos de dados no buffer. Se a contagem de parâmetro for zero, a parte de dados da mensagem estará vazia.

  • de tipo de dados [in]
    O identificador MPI_Datatype que representa o tipo de dados de cada elemento nodo buffer .

  • raiz [in]
    A classificação do processo no MPI_Commcomm enviar buffer.

  • comm [in]
    O identificador do MPI_Comm comunicador.

  • solicitação [out]
    MPI_Request identificador que representa a operação de comunicação..

Valor de retorno

Retorna MPI_SUCCESS com êxito. Caso contrário, o valor retornado é um código de erro.

No Fortran, o valor retornado é armazenado no parâmetro IERROR.

Fortran

    MPI_IBCAST(BUFFER, COUNT, DATATYPE, ROOT, COMM, REQUEST, IERROR)
        <type> BUFFER(*)  
        INTEGER COUNT, DATATYPE, ROOT, COMM, REQUEST, IERROR

Observações

Uma chamada sem bloqueio inicia uma operação de transmissão coletiva que deve ser concluída em uma chamada de conclusão separada. Uma vez iniciada, a operação pode progredir independentemente de qualquer computação ou outra comunicação nos processos participantes. Dessa maneira, operações de transmissão sem bloqueio podem atenuar possíveis efeitos de sincronização de operações de difusão executando-as em "segundo plano".

Todas as chamadas de conclusão (por exemplo, MPI_Wait) têm suporte para operações de transmissão sem bloqueio.

Requisitos

Produto

Microsoft MPI v6

Cabeçalho

Mpi.h; Mpif.h

Biblioteca

Msmpi.lib

DLL

Msmpi.dll

Consulte também

de funções coletivas de MPI

MPI_Bcast

MPI_Datatype

MPI_Test

MPI_Testall

MPI_Testany

MPI_Testsome

MPI_Wait

MPI_Waitall

MPI_Waitany

MPI_Waitsome

MPI_Comm