|
Packit Service |
c5cf8c |
.TH MPI_Get_accumulate 3 "11/12/2019" " " "MPI"
|
|
Packit Service |
c5cf8c |
.SH NAME
|
|
Packit Service |
c5cf8c |
MPI_Get_accumulate \- Perform an atomic, one-sided read-and-accumulate operation.
|
|
Packit Service |
c5cf8c |
.SH SYNOPSIS
|
|
Packit Service |
c5cf8c |
.nf
|
|
Packit Service |
c5cf8c |
int MPI_Get_accumulate(const void *origin_addr, int origin_count,
|
|
Packit Service |
c5cf8c |
MPI_Datatype origin_datatype, void *result_addr, int result_count,
|
|
Packit Service |
c5cf8c |
MPI_Datatype result_datatype, int target_rank, MPI_Aint target_disp,
|
|
Packit Service |
c5cf8c |
int target_count, MPI_Datatype target_datatype, MPI_Op op, MPI_Win win)
|
|
Packit Service |
c5cf8c |
.fi
|
|
Packit Service |
c5cf8c |
|
|
Packit Service |
c5cf8c |
Accumulate origin_count elements of type origin_datatype from the origin buffer
|
|
Packit Service |
c5cf8c |
(origin_addr) to the buffer at offset target_disp, in the target window
|
|
Packit Service |
c5cf8c |
specified by target_rank and win, using the operation op and return in the
|
|
Packit Service |
c5cf8c |
result buffer result_addr the content of the target buffer before the
|
|
Packit Service |
c5cf8c |
accumulation.
|
|
Packit Service |
c5cf8c |
|
|
Packit Service |
c5cf8c |
.SH INPUT PARAMETERS
|
|
Packit Service |
c5cf8c |
.PD 0
|
|
Packit Service |
c5cf8c |
.TP
|
|
Packit Service |
c5cf8c |
.B origin_addr
|
|
Packit Service |
c5cf8c |
- initial address of buffer (choice)
|
|
Packit Service |
c5cf8c |
.PD 1
|
|
Packit Service |
c5cf8c |
.PD 0
|
|
Packit Service |
c5cf8c |
.TP
|
|
Packit Service |
c5cf8c |
.B origin_count
|
|
Packit Service |
c5cf8c |
- number of entries in buffer (nonnegative integer)
|
|
Packit Service |
c5cf8c |
.PD 1
|
|
Packit Service |
c5cf8c |
.PD 0
|
|
Packit Service |
c5cf8c |
.TP
|
|
Packit Service |
c5cf8c |
.B origin_datatype
|
|
Packit Service |
c5cf8c |
- datatype of each buffer entry (handle)
|
|
Packit Service |
c5cf8c |
.PD 1
|
|
Packit Service |
c5cf8c |
.PD 0
|
|
Packit Service |
c5cf8c |
.TP
|
|
Packit Service |
c5cf8c |
.B result_addr
|
|
Packit Service |
c5cf8c |
- initial address of result buffer (choice)
|
|
Packit Service |
c5cf8c |
.PD 1
|
|
Packit Service |
c5cf8c |
.PD 0
|
|
Packit Service |
c5cf8c |
.TP
|
|
Packit Service |
c5cf8c |
.B result_count
|
|
Packit Service |
c5cf8c |
- number of entries in result buffer (non-negative integer)
|
|
Packit Service |
c5cf8c |
.PD 1
|
|
Packit Service |
c5cf8c |
.PD 0
|
|
Packit Service |
c5cf8c |
.TP
|
|
Packit Service |
c5cf8c |
.B result_datatype
|
|
Packit Service |
c5cf8c |
- datatype of each entry in result buffer (handle)
|
|
Packit Service |
c5cf8c |
.PD 1
|
|
Packit Service |
c5cf8c |
.PD 0
|
|
Packit Service |
c5cf8c |
.TP
|
|
Packit Service |
c5cf8c |
.B target_rank
|
|
Packit Service |
c5cf8c |
- rank of target (nonnegative integer)
|
|
Packit Service |
c5cf8c |
.PD 1
|
|
Packit Service |
c5cf8c |
.PD 0
|
|
Packit Service |
c5cf8c |
.TP
|
|
Packit Service |
c5cf8c |
.B target_disp
|
|
Packit Service |
c5cf8c |
- displacement from start of window to beginning of target
|
|
Packit Service |
c5cf8c |
buffer (nonnegative integer)
|
|
Packit Service |
c5cf8c |
.PD 1
|
|
Packit Service |
c5cf8c |
.PD 0
|
|
Packit Service |
c5cf8c |
.TP
|
|
Packit Service |
c5cf8c |
.B target_count
|
|
Packit Service |
c5cf8c |
- number of entries in target buffer (nonnegative integer)
|
|
Packit Service |
c5cf8c |
.PD 1
|
|
Packit Service |
c5cf8c |
.PD 0
|
|
Packit Service |
c5cf8c |
.TP
|
|
Packit Service |
c5cf8c |
.B target_datatype
|
|
Packit Service |
c5cf8c |
- datatype of each entry in target buffer (handle)
|
|
Packit Service |
c5cf8c |
.PD 1
|
|
Packit Service |
c5cf8c |
.PD 0
|
|
Packit Service |
c5cf8c |
.TP
|
|
Packit Service |
c5cf8c |
.B op
|
|
Packit Service |
c5cf8c |
- predefined reduce operation (handle)
|
|
Packit Service |
c5cf8c |
.PD 1
|
|
Packit Service |
c5cf8c |
.PD 0
|
|
Packit Service |
c5cf8c |
.TP
|
|
Packit Service |
c5cf8c |
.B win
|
|
Packit Service |
c5cf8c |
- window object (handle)
|
|
Packit Service |
c5cf8c |
.PD 1
|
|
Packit Service |
c5cf8c |
|
|
Packit Service |
c5cf8c |
.SH NOTES
|
|
Packit Service |
c5cf8c |
This operations is atomic with respect to other "accumulate" operations.
|
|
Packit Service |
c5cf8c |
|
|
Packit Service |
c5cf8c |
The get and accumulate steps are executed atomically for each basic element in
|
|
Packit Service |
c5cf8c |
the datatype (see MPI 3.0 Section 11.7 for details). The predefined operation
|
|
Packit Service |
c5cf8c |
.I MPI_REPLACE
|
|
Packit Service |
c5cf8c |
provides fetch-and-set behavior.
|
|
Packit Service |
c5cf8c |
|
|
Packit Service |
c5cf8c |
The origin and result buffers (origin_addr and result_addr) must be disjoint.
|
|
Packit Service |
c5cf8c |
Each datatype argument must be a predefined datatype or a derived datatype
|
|
Packit Service |
c5cf8c |
where all basic components are of the same predefined datatype. All datatype
|
|
Packit Service |
c5cf8c |
arguments must be constructed from the same predefined datatype. The
|
|
Packit Service |
c5cf8c |
operation op applies to elements of that predefined type. target_datatype must
|
|
Packit Service |
c5cf8c |
not specify overlapping entries, and the target buffer must fit in the target
|
|
Packit Service |
c5cf8c |
window or in attached memory in a dynamic window.
|
|
Packit Service |
c5cf8c |
|
|
Packit Service |
c5cf8c |
Any of the predefined operations for
|
|
Packit Service |
c5cf8c |
.I MPI_Reduce
|
|
Packit Service |
c5cf8c |
, as well as
|
|
Packit Service |
c5cf8c |
.I MPI_NO_OP
|
|
Packit Service |
c5cf8c |
or
|
|
Packit Service |
c5cf8c |
.I MPI_REPLACE
|
|
Packit Service |
c5cf8c |
can be specified as op. User-defined functions cannot be used. A
|
|
Packit Service |
c5cf8c |
new predefined operation,
|
|
Packit Service |
c5cf8c |
.I MPI_NO_OP
|
|
Packit Service |
c5cf8c |
, is defined. It corresponds to the
|
|
Packit Service |
c5cf8c |
associative function f (a, b) = a; i.e., the current value in the target memory
|
|
Packit Service |
c5cf8c |
is returned in the result buffer at the origin and no operation is performed on
|
|
Packit Service |
c5cf8c |
the target buffer.
|
|
Packit Service |
c5cf8c |
.I MPI_NO_OP
|
|
Packit Service |
c5cf8c |
can be used only in
|
|
Packit Service |
c5cf8c |
.I MPI_Get_accumulate
|
|
Packit Service |
c5cf8c |
,
|
|
Packit Service |
c5cf8c |
.I MPI_Rget_accumulate
|
|
Packit Service |
c5cf8c |
, and
|
|
Packit Service |
c5cf8c |
.I MPI_Fetch_and_op
|
|
Packit Service |
c5cf8c |
\&.
|
|
Packit Service |
c5cf8c |
.I MPI_NO_OP
|
|
Packit Service |
c5cf8c |
cannot be used in
|
|
Packit Service |
c5cf8c |
.I MPI_Accumulate
|
|
Packit Service |
c5cf8c |
,
|
|
Packit Service |
c5cf8c |
.I MPI_Raccumulate
|
|
Packit Service |
c5cf8c |
, or collective reduction operations, such as
|
|
Packit Service |
c5cf8c |
.I MPI_Reduce
|
|
Packit Service |
c5cf8c |
and others.
|
|
Packit Service |
c5cf8c |
|
|
Packit Service |
c5cf8c |
.SH NOTES FOR FORTRAN
|
|
Packit Service |
c5cf8c |
All MPI routines in Fortran (except for
|
|
Packit Service |
c5cf8c |
.I MPI_WTIME
|
|
Packit Service |
c5cf8c |
and
|
|
Packit Service |
c5cf8c |
.I MPI_WTICK
|
|
Packit Service |
c5cf8c |
) have
|
|
Packit Service |
c5cf8c |
an additional argument
|
|
Packit Service |
c5cf8c |
.I ierr
|
|
Packit Service |
c5cf8c |
at the end of the argument list.
|
|
Packit Service |
c5cf8c |
.I ierr
|
|
Packit Service |
c5cf8c |
is an integer and has the same meaning as the return value of the routine
|
|
Packit Service |
c5cf8c |
in C. In Fortran, MPI routines are subroutines, and are invoked with the
|
|
Packit Service |
c5cf8c |
.I call
|
|
Packit Service |
c5cf8c |
statement.
|
|
Packit Service |
c5cf8c |
|
|
Packit Service |
c5cf8c |
All MPI objects (e.g.,
|
|
Packit Service |
c5cf8c |
.I MPI_Datatype
|
|
Packit Service |
c5cf8c |
,
|
|
Packit Service |
c5cf8c |
.I MPI_Comm
|
|
Packit Service |
c5cf8c |
) are of type
|
|
Packit Service |
c5cf8c |
.I INTEGER
|
|
Packit Service |
c5cf8c |
in Fortran.
|
|
Packit Service |
c5cf8c |
|
|
Packit Service |
c5cf8c |
.SH ERRORS
|
|
Packit Service |
c5cf8c |
|
|
Packit Service |
c5cf8c |
All MPI routines (except
|
|
Packit Service |
c5cf8c |
.I MPI_Wtime
|
|
Packit Service |
c5cf8c |
and
|
|
Packit Service |
c5cf8c |
.I MPI_Wtick
|
|
Packit Service |
c5cf8c |
) return an error value;
|
|
Packit Service |
c5cf8c |
C routines as the value of the function and Fortran routines in the last
|
|
Packit Service |
c5cf8c |
argument. Before the value is returned, the current MPI error handler is
|
|
Packit Service |
c5cf8c |
called. By default, this error handler aborts the MPI job. The error handler
|
|
Packit Service |
c5cf8c |
may be changed with
|
|
Packit Service |
c5cf8c |
.I MPI_Comm_set_errhandler
|
|
Packit Service |
c5cf8c |
(for communicators),
|
|
Packit Service |
c5cf8c |
.I MPI_File_set_errhandler
|
|
Packit Service |
c5cf8c |
(for files), and
|
|
Packit Service |
c5cf8c |
.I MPI_Win_set_errhandler
|
|
Packit Service |
c5cf8c |
(for
|
|
Packit Service |
c5cf8c |
RMA windows). The MPI-1 routine
|
|
Packit Service |
c5cf8c |
.I MPI_Errhandler_set
|
|
Packit Service |
c5cf8c |
may be used but
|
|
Packit Service |
c5cf8c |
its use is deprecated. The predefined error handler
|
|
Packit Service |
c5cf8c |
.I MPI_ERRORS_RETURN
|
|
Packit Service |
c5cf8c |
may be used to cause error values to be returned.
|
|
Packit Service |
c5cf8c |
Note that MPI does
|
|
Packit Service |
c5cf8c |
.B not
|
|
Packit Service |
c5cf8c |
guarentee that an MPI program can continue past
|
|
Packit Service |
c5cf8c |
an error; however, MPI implementations will attempt to continue whenever
|
|
Packit Service |
c5cf8c |
possible.
|
|
Packit Service |
c5cf8c |
|
|
Packit Service |
c5cf8c |
.PD 0
|
|
Packit Service |
c5cf8c |
.TP
|
|
Packit Service |
c5cf8c |
.B MPI_SUCCESS
|
|
Packit Service |
c5cf8c |
- No error; MPI routine completed successfully.
|
|
Packit Service |
c5cf8c |
.PD 1
|
|
Packit Service |
c5cf8c |
.PD 0
|
|
Packit Service |
c5cf8c |
.TP
|
|
Packit Service |
c5cf8c |
.B MPI_ERR_ARG
|
|
Packit Service |
c5cf8c |
- Invalid argument. Some argument is invalid and is not
|
|
Packit Service |
c5cf8c |
identified by a specific error class (e.g.,
|
|
Packit Service |
c5cf8c |
.I MPI_ERR_RANK
|
|
Packit Service |
c5cf8c |
).
|
|
Packit Service |
c5cf8c |
.PD 1
|
|
Packit Service |
c5cf8c |
.PD 0
|
|
Packit Service |
c5cf8c |
.TP
|
|
Packit Service |
c5cf8c |
.B MPI_ERR_COUNT
|
|
Packit Service |
c5cf8c |
- Invalid count argument. Count arguments must be
|
|
Packit Service |
c5cf8c |
non-negative; a count of zero is often valid.
|
|
Packit Service |
c5cf8c |
.PD 1
|
|
Packit Service |
c5cf8c |
.PD 0
|
|
Packit Service |
c5cf8c |
.TP
|
|
Packit Service |
c5cf8c |
.B MPI_ERR_RANK
|
|
Packit Service |
c5cf8c |
- Invalid source or destination rank. Ranks must be between
|
|
Packit Service |
c5cf8c |
zero and the size of the communicator minus one; ranks in a receive
|
|
Packit Service |
c5cf8c |
(
|
|
Packit Service |
c5cf8c |
.I MPI_Recv
|
|
Packit Service |
c5cf8c |
,
|
|
Packit Service |
c5cf8c |
.I MPI_Irecv
|
|
Packit Service |
c5cf8c |
,
|
|
Packit Service |
c5cf8c |
.I MPI_Sendrecv
|
|
Packit Service |
c5cf8c |
, etc.) may also be
|
|
Packit Service |
c5cf8c |
.I MPI_ANY_SOURCE
|
|
Packit Service |
c5cf8c |
\&.
|
|
Packit Service |
c5cf8c |
|
|
Packit Service |
c5cf8c |
.PD 1
|
|
Packit Service |
c5cf8c |
.PD 0
|
|
Packit Service |
c5cf8c |
.TP
|
|
Packit Service |
c5cf8c |
.B MPI_ERR_TYPE
|
|
Packit Service |
c5cf8c |
- Invalid datatype argument. Additionally, this error can
|
|
Packit Service |
c5cf8c |
occur if an uncommitted MPI_Datatype (see
|
|
Packit Service |
c5cf8c |
.I MPI_Type_commit
|
|
Packit Service |
c5cf8c |
) is used
|
|
Packit Service |
c5cf8c |
in a communication call.
|
|
Packit Service |
c5cf8c |
.PD 1
|
|
Packit Service |
c5cf8c |
.PD 0
|
|
Packit Service |
c5cf8c |
.TP
|
|
Packit Service |
c5cf8c |
.B MPI_ERR_WIN
|
|
Packit Service |
c5cf8c |
- Invalid MPI window object
|
|
Packit Service |
c5cf8c |
.PD 1
|
|
Packit Service |
c5cf8c |
|
|
Packit Service |
c5cf8c |
.SH SEE ALSO
|
|
Packit Service |
c5cf8c |
MPI_Rget_accumulate MPI_Fetch_and_op
|
|
Packit Service |
c5cf8c |
.br
|