|
Packit Service |
c5cf8c |
.TH MPI_Type_struct 3 "11/12/2019" " " "MPI"
|
|
Packit Service |
c5cf8c |
.SH NAME
|
|
Packit Service |
c5cf8c |
MPI_Type_struct \- Creates a struct datatype
|
|
Packit Service |
c5cf8c |
.SH SYNOPSIS
|
|
Packit Service |
c5cf8c |
.nf
|
|
Packit Service |
c5cf8c |
int MPI_Type_struct(int count,
|
|
Packit Service |
c5cf8c |
int *array_of_blocklengths,
|
|
Packit Service |
c5cf8c |
MPI_Aint * array_of_displacements,
|
|
Packit Service |
c5cf8c |
MPI_Datatype * array_of_types, MPI_Datatype * newtype)
|
|
Packit Service |
c5cf8c |
.fi
|
|
Packit Service |
c5cf8c |
.SH INPUT PARAMETERS
|
|
Packit Service |
c5cf8c |
.PD 0
|
|
Packit Service |
c5cf8c |
.TP
|
|
Packit Service |
c5cf8c |
.B count
|
|
Packit Service |
c5cf8c |
- number of blocks (integer) -- also number of
|
|
Packit Service |
c5cf8c |
entries in arrays array_of_types ,
|
|
Packit Service |
c5cf8c |
array_of_displacements and array_of_blocklengths
|
|
Packit Service |
c5cf8c |
.PD 1
|
|
Packit Service |
c5cf8c |
.PD 0
|
|
Packit Service |
c5cf8c |
.TP
|
|
Packit Service |
c5cf8c |
.B array_of_blocklengths
|
|
Packit Service |
c5cf8c |
- number of elements in each block (array)
|
|
Packit Service |
c5cf8c |
.PD 1
|
|
Packit Service |
c5cf8c |
.PD 0
|
|
Packit Service |
c5cf8c |
.TP
|
|
Packit Service |
c5cf8c |
.B array_of_displacements
|
|
Packit Service |
c5cf8c |
- byte displacement of each block (array)
|
|
Packit Service |
c5cf8c |
.PD 1
|
|
Packit Service |
c5cf8c |
.PD 0
|
|
Packit Service |
c5cf8c |
.TP
|
|
Packit Service |
c5cf8c |
.B array_of_types
|
|
Packit Service |
c5cf8c |
- type of elements in each block (array
|
|
Packit Service |
c5cf8c |
of handles to datatype objects)
|
|
Packit Service |
c5cf8c |
.PD 1
|
|
Packit Service |
c5cf8c |
|
|
Packit Service |
c5cf8c |
.SH OUTPUT PARAMETERS
|
|
Packit Service |
c5cf8c |
.PD 0
|
|
Packit Service |
c5cf8c |
.TP
|
|
Packit Service |
c5cf8c |
.B newtype
|
|
Packit Service |
c5cf8c |
- new datatype (handle)
|
|
Packit Service |
c5cf8c |
.PD 1
|
|
Packit Service |
c5cf8c |
|
|
Packit Service |
c5cf8c |
.SH DEPRECATED FUNCTION
|
|
Packit Service |
c5cf8c |
The MPI-2 standard deprecated a number of routines because MPI-2 provides
|
|
Packit Service |
c5cf8c |
better versions. This routine is one of those that was deprecated. The
|
|
Packit Service |
c5cf8c |
routine may continue to be used, but new code should use the replacement
|
|
Packit Service |
c5cf8c |
routine.
|
|
Packit Service |
c5cf8c |
The replacement for this routine is
|
|
Packit Service |
c5cf8c |
.I MPI_Type_create_struct
|
|
Packit Service |
c5cf8c |
|
|
Packit Service |
c5cf8c |
|
|
Packit Service |
c5cf8c |
.SH NOTES
|
|
Packit Service |
c5cf8c |
If an upperbound is set explicitly by using the MPI datatype
|
|
Packit Service |
c5cf8c |
.I MPI_UB
|
|
Packit Service |
c5cf8c |
, the
|
|
Packit Service |
c5cf8c |
corresponding index must be positive.
|
|
Packit Service |
c5cf8c |
|
|
Packit Service |
c5cf8c |
The MPI standard originally made vague statements about padding and alignment;
|
|
Packit Service |
c5cf8c |
this was intended to allow the simple definition of structures that could
|
|
Packit Service |
c5cf8c |
be sent with a count greater than one. For example,
|
|
Packit Service |
c5cf8c |
.nf
|
|
Packit Service |
c5cf8c |
struct { int a; char b; } foo;
|
|
Packit Service |
c5cf8c |
.fi
|
|
Packit Service |
c5cf8c |
|
|
Packit Service |
c5cf8c |
may have
|
|
Packit Service |
c5cf8c |
.I sizeof(foo) > sizeof(int) + sizeof(char)
|
|
Packit Service |
c5cf8c |
; for example,
|
|
Packit Service |
c5cf8c |
.I sizeof(foo) == 2*sizeof(int)
|
|
Packit Service |
c5cf8c |
\&.
|
|
Packit Service |
c5cf8c |
The initial version of the MPI standard
|
|
Packit Service |
c5cf8c |
defined the extent of a datatype as including an
|
|
Packit Service |
c5cf8c |
.B epsilon
|
|
Packit Service |
c5cf8c |
that would have
|
|
Packit Service |
c5cf8c |
allowed an implementation to make the extent an MPI datatype
|
|
Packit Service |
c5cf8c |
for this structure equal to
|
|
Packit Service |
c5cf8c |
.I 2*sizeof(int)
|
|
Packit Service |
c5cf8c |
\&.
|
|
Packit Service |
c5cf8c |
|
|
Packit Service |
c5cf8c |
However, since different systems might define different paddings, there was
|
|
Packit Service |
c5cf8c |
much discussion by the MPI Forum about what was the correct value of
|
|
Packit Service |
c5cf8c |
epsilon, and one suggestion was to define epsilon as zero.
|
|
Packit Service |
c5cf8c |
This would have been the best thing to do in MPI 1.0, particularly since
|
|
Packit Service |
c5cf8c |
the
|
|
Packit Service |
c5cf8c |
.I MPI_UB
|
|
Packit Service |
c5cf8c |
type allows the user to easily set the end of the structure.
|
|
Packit Service |
c5cf8c |
Unfortunately, this change did not make it into the final document.
|
|
Packit Service |
c5cf8c |
Currently, this routine does not add any padding, since the amount of
|
|
Packit Service |
c5cf8c |
padding needed is determined by the compiler that the user is using to
|
|
Packit Service |
c5cf8c |
build their code, not the compiler used to construct the MPI library.
|
|
Packit Service |
c5cf8c |
A later version of MPICH may provide for some natural choices of padding
|
|
Packit Service |
c5cf8c |
(e.g., multiple of the size of the largest basic member), but users are
|
|
Packit Service |
c5cf8c |
advised to never depend on this, even with vendor MPI implementations.
|
|
Packit Service |
c5cf8c |
Instead, if you define a structure datatype and wish to send or receive
|
|
Packit Service |
c5cf8c |
multiple items, you should explicitly include an
|
|
Packit Service |
c5cf8c |
.I MPI_UB
|
|
Packit Service |
c5cf8c |
entry as the
|
|
Packit Service |
c5cf8c |
last member of the structure. For example, the following code can be used
|
|
Packit Service |
c5cf8c |
for the structure foo
|
|
Packit Service |
c5cf8c |
.nf
|
|
Packit Service |
c5cf8c |
blen[0] = 1; array_of_displacements[0] = 0; oldtypes[0] = MPI_INT;
|
|
Packit Service |
c5cf8c |
blen[1] = 1; array_of_displacements[1] = &foo.b - &foo; oldtypes[1] = MPI_CHAR;
|
|
Packit Service |
c5cf8c |
blen[2] = 1; array_of_displacements[2] = sizeof(foo); oldtypes[2] = MPI_UB;
|
|
Packit Service |
c5cf8c |
MPI_Type_struct(3, blen, array_of_displacements, oldtypes, &newtype);
|
|
Packit Service |
c5cf8c |
.fi
|
|
Packit Service |
c5cf8c |
|
|
Packit Service |
c5cf8c |
|
|
Packit Service |
c5cf8c |
.SH THREAD AND INTERRUPT SAFETY
|
|
Packit Service |
c5cf8c |
|
|
Packit Service |
c5cf8c |
This routine is thread-safe. This means that this routine may be
|
|
Packit Service |
c5cf8c |
safely used by multiple threads without the need for any user-provided
|
|
Packit Service |
c5cf8c |
thread locks. However, the routine is not interrupt safe. Typically,
|
|
Packit Service |
c5cf8c |
this is due to the use of memory allocation routines such as
|
|
Packit Service |
c5cf8c |
.I malloc
|
|
Packit Service |
c5cf8c |
or other non-MPICH runtime routines that are themselves not interrupt-safe.
|
|
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_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_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_INTERN
|
|
Packit Service |
c5cf8c |
- This error is returned when some part of the MPICH
|
|
Packit Service |
c5cf8c |
implementation is unable to acquire memory.
|
|
Packit Service |
c5cf8c |
.PD 1
|