HDF5 documents and links Introduction to HDF5 HDF5 User Guide |
And in this document, the
HDF5 Reference Manual H5 H5A H5D H5E H5F H5G H5I H5P H5R H5S H5T H5Z Tools Datatypes Collective Calls in Parallel |
(PDF of complete manual formatted as print volume) |
The C Interfaces:
H5Sclose
(hid_t space_id
)
H5Sclose
releases a dataspace.
Further access through the dataspace identifier is illegal.
Failure to release a dataspace with this call will
result in resource leaks.
hid_t space_id |
Identifier of dataspace to release. |
SUBROUTINE h5sclose_f(space_id, hdferr) IMPLICIT NONE INTEGER(HID_T), INTENT(IN) :: space_id ! Dataspace identifier INTEGER, INTENT(OUT) :: hdferr ! Error code ! 0 on success and -1 on failure END SUBROUTINE h5sclose_f
H5Scopy
(hid_t space_id
)
H5Scopy
creates a new dataspace which is an exact
copy of the dataspace identified by space_id
.
The dataspace identifier returned from this function should be
released with H5Sclose
or resource leaks will occur.
hid_t space_id |
Identifier of dataspace to copy. |
SUBROUTINE h5scopy_f(space_id, new_space_id, hdferr) IMPLICIT NONE INTEGER(HID_T), INTENT(IN) :: space_id ! Dataspace identifier INTEGER(HID_T), INTENT(OUT) :: new_space_id ! Identifier of dataspace copy INTEGER, INTENT(OUT) :: hdferr ! Error code ! 0 on success and -1 on failure END SUBROUTINE h5scopy_f
H5Screate
(H5S_class_t type
)
H5Screate
creates a new dataspace of a particular
type
.
The types currently supported are H5S_SCALAR
and
H5S_SIMPLE
;
others may be added later.
A scalar dataspace, H5S_SCALAR
,
has a single element, though that element may be of a complex
datatype, such as a compound or array datatype.
By convention, the rank of a scalar dataspace is always
0
(zero); think of it geometrically as a single,
dimensionless point, though that point can be complex.
A simple dataspace, H5S_SIMPLE
, consists of
a regular array of elements.
H5S_class_t type |
The type of dataspace to be created. |
SUBROUTINE h5screate_f(classtype, space_id, hdferr) IMPLICIT NONE INTEGER, INTENT(IN) :: classtype ! The type of the dataspace ! to be created. Possible values ! are: ! H5S_SCALAR_F ! H5S_SIMPLE_F INTEGER(HID_T), INTENT(OUT) :: space_id ! Dataspace identifier INTEGER, INTENT(OUT) :: hdferr ! Error code ! 0 on success and -1 on failure END SUBROUTINE h5screate_f
H5Screate_simple
(int rank
,
const hsize_t * dims
,
const hsize_t * maxdims
)
H5Screate_simple
creates a new simple dataspace
and opens it for access, returning a dataset identifier.
rank
is the number of dimensions used in the dataspace.
dims
is a one-dimensional array of size rank
specifying the size of each dimension of the dataset.
maxdims
is an array of the same size
specifying the upper limit on the size of each dimension.
maxdims
may be the null pointer, in which case the
upper limit is the same as dims
.
If an element of maxdims
is H5S_UNLIMITED
,
the maximum size of the corresponding dimension is unlimited.
Otherwise, no element of maxdims
should be
smaller than the corresponding element of dims
.
Note that any dataset with an unlimited dimension must also
be chunked; see
H5Pset_chunk
.
The dataspace identifier returned from this function must be
released with H5Sclose
or resource leaks will occur.
int rank |
Number of dimensions of dataspace. |
const hsize_t * dims |
An array of the size of each dimension. |
const hsize_t * maxdims |
An array of the maximum size of each dimension. |
H5Pset_chunk
SUBROUTINE h5screate_simple_f(rank, dims, space_id, hdferr, maxdims) IMPLICIT NONE INTEGER, INTENT(IN) :: rank ! Number of dataspace dimensions INTEGER(HSIZE_T), INTENT(IN) :: dims(*) ! Array with the dimension sizes INTEGER(HID_T), INTENT(OUT) :: space_id ! Dataspace identifier INTEGER, INTENT(OUT) :: hdferr ! Error code ! 0 on success and -1 on failure INTEGER(HSIZE_T), OPTIONAL, INTENT(IN) :: maxdims(*) ! Array with the maximum ! dimension sizes END SUBROUTINE h5screate_simple_f
H5Sextent_copy
(hid_t dest_space_id
,
hid_t source_space_id
)
H5Sextent_copy
copies the extent from
source_space_id
to dest_space_id
.
This action may change the type of the dataspace.
hid_t dest_space_id |
IN: The identifier for the dataspace to which the extent is copied. |
hid_t source_space_id |
IN: The identifier for the dataspace from which the extent is copied. |
SUBROUTINE h5sextent_copy_f(dest_space_id, source_space_id, hdferr) IMPLICIT NONE INTEGER(HID_T), INTENT(IN) :: dest_space_id ! Identifier of destination ! dataspace INTEGER(HID_T), INTENT(IN) :: source_space_id ! Identifier of source ! dataspace INTEGER, INTENT(OUT) :: hdferr ! Error code ! 0 on success and -1 on failure END SUBROUTINE h5sextent_copy_f
H5Sget_select_bounds
(hid_t space_id
,
hsize_t *start
,
hsize_t *end
)
H5Sget_select_bounds
retrieves the coordinates of
the bounding box containing the current selection and places
them into user-supplied buffers.
The start
and end
buffers must be large
enough to hold the dataspace rank number of coordinates.
The bounding box exactly contains the selection. I.e., if a 2-dimensional element selection is currently defined as containing the points (4,5), (6,8), and (10,7), then the bounding box will be (4, 5), (10, 8).
The bounding box calculation includes the current offset of the selection within the dataspace extent.
Calling this function on a none
selection will
return FAIL
.
hid_t space_id |
IN: Identifier of dataspace to query. |
hsize_t *start |
OUT: Starting coordinates of the bounding box. |
hsize_t *end |
OUT: Ending coordinates of the bounding box, i.e., the coordinates of the diagonally opposite corner. |
SUBROUTINE h5sget_select_bounds_f(space_id, start, end, hdferr) IMPLICIT NONE INTEGER(HID_T), INTENT(IN) :: space_id ! Dataspace identifier INTEGER(HSIZE_T), DIMENSION(*), INTENT(OUT) :: start ! Starting coordinates of the bounding box INTEGER(HSIZE_T), DIMENSION(*), INTENT(OUT) :: end ! Ending coordinates of the bounding box, ! i.e., the coordinates of the diagonally ! opposite corner INTEGER, INTENT(OUT) :: hdferr ! Error code END SUBROUTINE h5sget_select_bounds_f
Release | C |
1.6.0 |
The start and end
parameters have changed from type hsize_t *
to hssize_t *. |
H5Sget_select_elem_npoints
(hid_t space_id
)
H5Sget_select_elem_npoints
returns
the number of element points in the current dataspace selection.
hid_t space_id |
IN: Identifier of dataspace to query. |
SUBROUTINE h5sget_select_elem_npoints_f(space_id, num_points, hdferr) IMPLICIT NONE INTEGER(HID_T), INTENT(IN) :: space_id ! Dataspace identifier INTEGER, INTENT(OUT) :: num_points ! Number of points in ! the current elements selection INTEGER, INTENT(OUT) :: hdferr ! Error code END SUBROUTINE h5sget_select_elem_npoints_f
H5Sget_select_elem_pointlist
(hid_t space_id
,
hsize_t startpoint
,
hsize_t numpoints
,
hsize_t *buf
)
H5Sget_select_elem_pointlist
returns the list of
element points in the current dataspace selection. Starting with
the startpoint
-th point in the list of points,
numpoints
points are put into the user's buffer.
If the user's buffer fills up before numpoints
points are inserted, the buffer will contain only as many
points as fit.
The element point coordinates have the same dimensionality (rank)
as the dataspace they are located within. The list of element points
is formatted as follows:
<coordinate>, followed by
the next coordinate,
etc.
until all of the selected element points have been listed.
The points are returned in the order they will be iterated through when the selection is read/written from/to disk.
hid_t space_id |
IN: Dataspace identifier of selection to query. |
hsize_t startpoint |
IN: Element point to start with. |
hsize_t numpoints |
IN: Number of element points to get. |
hsize_t *buf |
OUT: List of element points selected. |
SUBROUTINE h5sget_select_elem_pointlist_f(space_id, startpoint, num_points, buf, hdferr) IMPLICIT NONE INTEGER(HID_T), INTENT(IN) :: space_id ! Dataspace identifier INTEGER(HSIZE_T), INTENT(IN) :: startpoint ! Element point to start with INTEGER, INTENT(OUT) :: num_points ! Number of points to get in ! the current element selection INTEGER(HSIZE_T), DIMENSION(*), INTENT(OUT) :: buf ! List of points selected INTEGER, INTENT(OUT) :: hdferr ! Error code END SUBROUTINE h5sget_select_elem_pointlist_f
H5Sget_select_hyper_blocklist
(hid_t space_id
,
hsize_t startblock
,
hsize_t numblocks
,
hsize_t *buf
)
H5Sget_select_hyper_blocklist
returns a list of
the hyperslab blocks currently selected. Starting with the
startblock
-th block in the list of blocks,
numblocks
blocks are put into the user's buffer.
If the user's buffer fills up before numblocks
blocks are inserted, the buffer will contain only as many
blocks as fit.
The block coordinates have the same dimensionality (rank)
as the dataspace they are located within. The list of blocks
is formatted as follows:
<"start" coordinate>, immediately followed by
<"opposite" corner coordinate>, followed by
the next "start" and "opposite" coordinates,
etc.
until all of the selected blocks have been listed.
No guarantee is implied as the order in which blocks are listed.
hid_t space_id |
IN: Dataspace identifier of selection to query. |
hsize_t startblock |
IN: Hyperslab block to start with. |
hsize_t numblocks |
IN: Number of hyperslab blocks to get. |
hsize_t *buf |
OUT: List of hyperslab blocks selected. |
SUBROUTINE h5sget_select_hyper_blocklist_f(space_id, startblock, num_blocks, buf, hdferr) IMPLICIT NONE INTEGER(HID_T), INTENT(IN) :: space_id ! Dataspace identifier INTEGER(HSIZE_T), INTENT(IN) :: startblock ! Hyperslab block to start with INTEGER, INTENT(OUT) :: num_blocks ! Number of hyperslab blocks to ! get in the current hyperslab ! selection INTEGER(HSIZE_T), DIMENSION(*), INTENT(OUT) :: buf ! List of hyperslab blocks selected INTEGER, INTENT(OUT) :: hdferr ! Error code END SUBROUTINE h5sget_select_hyper_blocklist_f
H5Sget_select_hyper_nblocks
(hid_t space_id
)
H5Sget_select_hyper_nblocks
returns the
number of hyperslab blocks in the current dataspace selection.
hid_t space_id |
IN: Identifier of dataspace to query. |
SUBROUTINE h5sget_select_hyper_nblocks_f(space_id, num_blocks, hdferr) IMPLICIT NONE INTEGER(HID_T), INTENT(IN) :: space_id ! Dataspace identifier INTEGER, INTENT(OUT) :: num_blocks ! Number of hyperslab blocks in ! the current hyperslab selection INTEGER, INTENT(OUT) :: hdferr ! Error code END SUBROUTINE h5sget_select_hyper_nblocks_f
H5Sget_select_npoints
(hid_t space_id
)
H5Sget_select_npoints
determines the number of elements
in the current selection of a dataspace.
hid_t space_id |
Dataspace identifier. |
SUBROUTINE h5sget_select_npoints_f(space_id, npoints, hdferr) IMPLICIT NONE INTEGER(HID_T), INTENT(IN) :: space_id ! Dataspace identifier INTEGER(HSSIZE_T), INTENT(OUT) :: npoints ! Number of elements in the ! selection INTEGER, INTENT(OUT) :: hdferr ! Error code ! 0 on success and -1 on failure END SUBROUTINE h5sget_select_npoints_f
H5Sget_select_type
(hid_t space_id
)
H5Sget_select_type
retrieves the
type of selection currently defined for the dataspace
space_id
.
hid_t space_id |
Dataspace identifier. |
H5S_sel_type
,
if successful.
Valid return values are as follows:
H5S_SEL_NONE
| No selection is defined. |
H5S_SEL_POINTS
| A sequence of points is selected. |
H5S_SEL_HYPERSLABS
| A hyperslab or compound hyperslab is selected. |
H5S_SEL_ALL
| The entire dataset is selected. |
SUBROUTINE h5sget_select_type_f(space_id, type, hdferr) IMPLICIT NONE INTEGER(HID_T), INTENT(IN) :: space_id ! Dataspace identifier INTEGER, INTENT(OUT) :: type ! Selection type ! Valid values are: ! H5S_SEL_ERROR_F ! H5S_SEL_NONE_F ! H5S_SEL_POINTS_F ! H5S_SEL_HYPERSLABS_F ! H5S_SEL_ALL_F INTEGER, INTENT(OUT) :: hdferr ! Error code END SUBROUTINE h5sget_select_type_f
Release | C |
1.6.0 | Function introduced in this release. |
H5Sget_simple_extent_dims
(hid_t space_id
,
hsize_t *dims
,
hsize_t *maxdims
)
H5Sget_simple_extent_dims
returns the size and maximum sizes
of each dimension of a dataspace through the dims
and maxdims
parameters.
Either or both of dims
and maxdims
may be NULL.
If a value in the returned array maxdims
is
H5S_UNLIMITED
(-1),
the maximum size of that dimension is unlimited.
hid_t space_id |
IN: Identifier of the dataspace object to query |
hsize_t *dims |
OUT: Pointer to array to store the size of each dimension. |
hsize_t *maxdims |
OUT: Pointer to array to store the maximum size of each dimension. |
SUBROUTINE h5sget_simple_extent_dims_f(space_id, dims, maxdims, hdferr) IMPLICIT NONE INTEGER(HID_T), INTENT(IN) :: space_id ! Dataspace identifier INTEGER(HSIZE_T), DIMENSION(*), INTENT(OUT) :: dims ! Array to store dimension sizes INTEGER(HSIZE_T), DIMENSION(*), INTENT(OUT) :: maxdims ! Array to store max dimension sizes INTEGER, INTENT(OUT) :: hdferr ! Error code ! Dataspace rank on success ! and -1 on failure END SUBROUTINE h5sget_simple_extent_dims_f
H5Sget_simple_extent_ndims
(hid_t space_id
)
H5Sget_simple_extent_ndims
determines the dimensionality (or rank)
of a dataspace.
hid_t space_id |
Identifier of the dataspace |
SUBROUTINE h5sget_simple_extent_ndims_f(space_id, rank, hdferr) IMPLICIT NONE INTEGER(HID_T), INTENT(IN) :: space_id ! Dataspace identifier INTEGER, INTENT(OUT) :: rank ! Number of dimensions INTEGER, INTENT(OUT) :: hdferr ! Error code ! 0 on success and -1 on failure END SUBROUTINE h5sget_simple_extent_ndims_f
H5Sget_simple_extent_npoints
(hid_t space_id
)
H5Sget_simple_extent_npoints
determines the number of elements
in a dataspace. For example, a simple 3-dimensional dataspace
with dimensions 2, 3, and 4 would have 24 elements.
hid_t space_id |
ID of the dataspace object to query |
SUBROUTINE h5sget_simple_extent_npoints_f(space_id, npoints, hdferr) IMPLICIT NONE INTEGER(HID_T), INTENT(IN) :: space_id ! Dataspace identifier INTEGER(HSIZE_T), INTENT(OUT) :: npoints ! Number of elements in dataspace INTEGER, INTENT(OUT) :: hdferr ! Error code ! 0 on success and -1 on failure END SUBROUTINE h5sget_simple_extent_npoints_f
H5Sget_simple_extent_type
(hid_t space_id
)
H5Sget_simple_extent_type
queries a dataspace to determine the
current class of a dataspace.
The function returns a class name, one of the following:
H5S_SCALAR
,
H5S_SIMPLE
, or
H5S_NONE
.
hid_t space_id |
Dataspace identifier. |
SUBROUTINE h5sget_simple_extent_type_f(space_id, classtype, hdferr) IMPLICIT NONE INTEGER(HID_T), INTENT(IN) :: space_id ! Dataspace identifier INTEGER, INTENT(OUT) :: classtype ! Class type ! Possible values are: ! H5S_NO_CLASS_F ! H5S_SCALAR_F ! H5S_SIMPLE_F INTEGER, INTENT(OUT) :: hdferr ! Error code ! 0 on success and -1 on failure END SUBROUTINE h5sget_simple_extent_type_f
H5Sis_simple
(hid_t space_id
)
H5Sis_simple
determines whether a dataspace is
a simple dataspace. [Currently, all dataspace objects are simple
dataspaces, complex dataspace support will be added in the future]
hid_t space_id |
Identifier of the dataspace to query |
TRUE
,
or 0
(zero), for FALSE
.
Otherwise returns a negative value.
SUBROUTINE h5sis_simple_f(space_id, flag, hdferr) IMPLICIT NONE INTEGER(HID_T), INTENT(IN) :: space_id ! Dataspace identifier LOGICAL, INTENT(OUT) :: flag ! Flag, indicates if dataspace ! is simple or not: ! TRUE or FALSE INTEGER, INTENT(OUT) :: hdferr ! Error code ! 0 on success and -1 on failure END SUBROUTINE h5sis_simple_f
H5Soffset_simple
(hid_t space_id
,
const hssize_t *offset
)
H5Soffset_simple
sets the offset of a
simple dataspace space_id
. The offset
array must be the same number of elements as the number of
dimensions for the dataspace. If the offset
array is set to NULL, the offset for the dataspace
is reset to 0.
This function allows the same shaped selection to be moved to different locations within a dataspace without requiring it to be redefined.
hid_t space_id |
IN: The identifier for the dataspace object to reset. |
const hssize_t *offset |
IN: The offset at which to position the selection. |
SUBROUTINE h5soffset_simple_f(space_id, offset, hdferr) IMPLICIT NONE INTEGER(HID_T), INTENT(IN) :: space_id ! Dataspace identifier INTEGER(HSSIZE_T), DIMENSION(*), INTENT(IN) :: offset ! The offset at which to position ! the selection INTEGER, INTENT(OUT) :: hdferr ! Error code ! 0 on success and -1 on failure END SUBROUTINE h5soffset_simple_f
H5Sselect_all
(
hid_t dspace_id
)
H5Sselect_all
selects the entire extent
of the dataspace dspace_id
.
More specifically, H5Sselect_all
sets the selection type
to H5S_SEL_ALL
, which specifies the
entire dataspace anywhere it is applied.
hid_t dspace_id |
IN: The identifier for the dataspace for which the selection is being made. |
H5Sget_select_type
SUBROUTINE h5sselect_all_f(dspace_id, hdferr) IMPLICIT NONE INTEGER(HID_T), INTENT(IN) :: dspace_id ! Dataspace identifier INTEGER, INTENT(OUT) :: hdferr ! Error code ! 0 on success and -1 on failure END SUBROUTINE h5sselect_all_f
H5Sselect_elements
(hid_t space_id
,
H5S_seloper_t op
,
size_t num_elements
,
const hsize_t *coord
)
H5Sselect_elements
selects array elements to be
included in the selection for the space_id
dataspace.
This is referred to as a point selection.
The number of elements selected is set in the
num_elements
parameter.
The coord
parameter is a pointer to a buffer
containing a serialized 2-dimensional array of size
num_elements
by the rank of the dataspace.
The array lists dataset elements in the point selection;
that is, it’s a list of of zero-based values specifying the
coordinates in the dataset of the selected elements.
The order of the element coordinates in the
coord
array specifies the order in which
the array elements are iterated through when I/O is performed.
Duplicate coordinate locations are not checked for.
See below for examples of the mapping between
the serialized contents of the buffer and
the point selection array that it represents.
The selection operator op
determines how the
new selection is to be combined with the previously existing
selection for the dataspace.
The following operators are supported:
H5S_SELECT_SET
| Replaces the existing selection with the parameters from this call. Overlapping blocks are not supported with this operator. Adds the new selection to the existing selection. |
H5S_SELECT_APPEND
| Adds the new selection following the last element of the existing selection. |
H5S_SELECT_PREPEND
| Adds the new selection preceding the first element of the existing selection. |
Mapping the serialized coord
buffer
to a 2-dimensional point selection array:
To illustrate the construction of the contents of the
coord
buffer, consider two simple examples:
a selection of 5 points in a 1-dimensional array and
a selection of 3 points in a 4-dimensional array.
In the 1D case, we will be selecting five points and a 1D dataspace has rank 1, so the selection will be described in a 5-by-1 array. To select the 1st, 14th, 17th, 23rd, 8th elements of the dataset, the selection array would be as follows (remembering that point coordinates are zero-based):
0 13 16 22 7This point selection array will be serialized in the
coord
buffer as:
0 13 16 22 7
In the 4D case, we will be selecting three points and a 4D dataspace has rank 4, so the selection will be described in a 3-by-4 array. To select the points (1,1,1,1), (14,6,12,18), and (8,22,30,22), the point selection array would be as follows:
0 0 0 0 13 5 11 17 7 21 29 21This point selection array will be serialized in the
coord
buffer as:
0 0 0 0 13 5 11 17 7 21 29 21
hid_t space_id |
Identifier of the dataspace. |
H5S_seloper_t op |
Operator specifying how the new selection is to be combined with the existing selection for the dataspace. |
size_t num_elements |
Number of elements to be selected. |
const hsize_t *coord |
A pointer to a buffer containing a serialized copy of a 2-dimensional array of zero-based values specifying the coordinates of the elements in the point selection. |
SUBROUTINE h5sselect_elements_f(space_id, operator, rank, num_elements, coord, hdferr) IMPLICIT NONE INTEGER(HID_T), INTENT(IN) :: space_id ! Dataspace identifier INTEGER, INTENT(IN) :: operator ! Flag, valid values are: ! H5S_SELECT_SET_F ! H5S_SELECT_APPEND_F ! H5S_SELECT_PREPEND_F INTEGER, INTENT(IN) :: rank ! Number of dataspace ! dimensions
INTEGER(SIZE_T), INTENT(IN) :: num_elements ! Number of elements to be ! selected INTEGER(HSIZE_T), DIMENSION(*,*), INTENT(IN) :: coord ! A 1-based array containing the ! coordinates of the selected ! elements ! NOTE: Reversed dimension declaration ! compared to the C specification ! of coord(num_elements, rank) INTEGER, INTENT(OUT) :: hdferr ! Error code ! 0 on success and -1 on failure END SUBROUTINE h5sselect_elements_f
Release | Change |
1.6.4 |
C coord parameter type changed to
const hsize_t.
Fortran coord parameter type changed to
INTEGER(HSIZE_T) . |
H5Sselect_hyperslab
(hid_t space_id
,
H5S_seloper_t op
,
const hsize_t *start
,
const hsize_t *stride
,
const hsize_t *count
,
const hsize_t *block
)
H5Sselect_hyperslab
selects a hyperslab region
to add to the current selected region for the dataspace
specified by space_id
.
The start
, stride
, count
,
and block
arrays must be the same size as the rank
of the dataspace. For example, if the dataspace is 4-dimensional,
each of these parameters must be a 1-dimensional array of size
4
.
The selection operator op
determines how the new
selection is to be combined with the already existing selection
for the dataspace.
The following operators are supported:
H5S_SELECT_SET
| Replaces the existing selection with the parameters from this call. Overlapping blocks are not supported with this operator. |
H5S_SELECT_OR
| Adds the new selection to the existing selection. (Binary OR) |
H5S_SELECT_AND
| Retains only the overlapping portions of the new selection and the existing selection. (Binary AND) |
H5S_SELECT_XOR
| Retains only the elements that are members of the new selection or the existing selection, excluding elements that are members of both selections. (Binary exclusive-OR, XOR) |
H5S_SELECT_NOTB
| Retains only elements of the existing selection that are not in the new selection. |
H5S_SELECT_NOTA
| Retains only elements of the new selection that are not in the existing selection. |
The start
array specifies the offset of the
starting element of the specified hyperslab.
The stride
array chooses array locations
from the dataspace with each value in the stride
array determining how many elements to move in each dimension.
Setting a value in the stride
array to 1
moves to
each element in that dimension of the dataspace; setting a value
of 2
in allocation in the stride
array
moves to every other element in that dimension of the dataspace.
In other words, the stride
determines the
number of elements to move from the start
location
in each dimension.
Stride values of 0
are not allowed.
If the stride
parameter is NULL
,
a contiguous hyperslab is selected (as if each value in the
stride
array were set to 1
).
The count
array determines how many blocks to
select from the dataspace, in each dimension.
The block
array determines
the size of the element block selected from the dataspace.
If the block
parameter is set to NULL
,
the block size defaults to a single element in each dimension
(as if each value in the block
array were set to
1
).
For example, consider a 2-dimensional dataspace with
hyperslab selection settings as follows:
the start
offset is specified as [1,1],
stride
is [4,4],
count
is [3,7], and
block
is [2,2].
In C, these settings will specify a hyperslab consisting of
21 2x2 blocks of array elements starting with location (1,1)
with the selected blocks at locations
(1,1), (5,1), (9,1), (1,5), (5,5), etc.;
in Fortran, they will specify a hyperslab consisting of
21 2x2 blocks of array elements starting with location (2,2)
with the selected blocks at locations
(2,2), (6,2), (10,2), (2,6), (6,6), etc.
Regions selected with this function call default to C order iteration when I/O is performed.
hid_t space_id |
IN: Identifier of dataspace selection to modify |
H5S_seloper_t op |
IN: Operation to perform on current selection. |
const hsize_t *start |
IN: Offset of start of hyperslab |
const hsize_t *count |
IN: Number of blocks included in hyperslab. |
const hsize_t *stride |
IN: Hyperslab stride. |
const hsize_t *block |
IN: Size of block in hyperslab. |
SUBROUTINE h5sselect_hyperslab_f(space_id, operator, start, count, hdferr, stride, block) IMPLICIT NONE INTEGER(HID_T), INTENT(IN) :: space_id ! Dataspace identifier INTEGER, INTENT(IN) :: op ! Flag, valid values are: ! H5S_SELECT_SET_F ! H5S_SELECT_OR_F INTEGER(HSIZE_T), DIMENSION(*), INTENT(IN) :: start ! Starting coordinates of hyperslab INTEGER(HSIZE_T), DIMENSION(*), INTENT(IN) :: count ! Number of blocks to select ! from dataspace INTEGER, INTENT(OUT) :: hdferr ! Error code ! 0 on success and -1 on failure INTEGER(HSIZE_T), DIMENSION(*), OPTIONAL, INTENT(IN) :: stride ! Array of how many elements to ! move in each direction INTEGER(HSIZE_T), DIMENSION(*), OPTIONAL, INTENT(IN) :: block ! Size of the element block END SUBROUTINE h5sselect_hyperslab_f
Release | C | Fortran90 | |
1.6.4 |
start[] parameter type changed to
const hsize_t. |
start parameter type changed to
INTEGER(HSIZE_T) . |
H5Sselect_none
(hid_t space_id
)
H5Sselect_none
resets the selection region
for the dataspace space_id
to include no elements.
hid_t space_id |
IN: The identifier for the dataspace in which the selection is being reset. |
SUBROUTINE h5sselect_none_f(space_id, hdferr) IMPLICIT NONE INTEGER(HID_T), INTENT(IN) :: space_id ! Dataspace identifier INTEGER, INTENT(OUT) :: hdferr ! Error code ! 0 on success and -1 on failure END SUBROUTINE h5sselect_none_f
H5Sselect_valid
(hid_t space_id
)
H5Sselect_valid
verifies that the selection
for the dataspace space_id
is within the extent
of the dataspace if the current offset for the dataspace is used.
hid_t space_id |
The identifier for the dataspace being queried. |
TRUE
,
if the selection is contained within the extent
or 0
(zero), for FALSE
, if it is not.
Returns a negative value on error conditions
such as the selection or extent not being defined.
SUBROUTINE h5sselect_valid_f(space_id, flag, hdferr) IMPLICIT NONE INTEGER(HID_T), INTENT(IN) :: space_id ! Dataspace identifier LOGICAL, INTENT(OUT) :: flag ! TRUE if the selection is ! contained within the extent, ! FALSE otherwise. INTEGER, INTENT(OUT) :: hdferr ! Error code ! 0 on success and -1 on failure END SUBROUTINE h5sselect_valid_f
H5Sset_extent_none
(hid_t space_id
)
H5Sset_extent_none
removes the extent from
a dataspace and sets the type to H5S_NO_CLASS.
hid_t space_id |
The identifier for the dataspace from which the extent is to be removed. |
SUBROUTINE h5sset_extent_none_f(space_id, hdferr) IMPLICIT NONE INTEGER(HID_T), INTENT(IN) :: space_id ! Dataspace identifier INTEGER, INTENT(OUT) :: hdferr ! Error code ! 0 on success and -1 on failure END SUBROUTINE h5sset_extent_none_f
H5Sset_extent_simple
(hid_t space_id
,
int rank
,
const hsize_t *current_size
,
const hsize_t *maximum_size
)
H5Sset_extent_simple
sets or resets the size of
an existing dataspace.
rank
is the dimensionality, or number of
dimensions, of the dataspace.
current_size
is an array of size rank
which contains the new size of each dimension in the dataspace.
maximum_size
is an array of size rank
which contains the maximum size of each dimension in the
dataspace.
Any previous extent is removed from the dataspace, the dataspace
type is set to H5S_SIMPLE
, and the extent is set as
specified.
hid_t space_id |
Dataspace identifier. |
int rank |
Rank, or dimensionality, of the dataspace. |
const hsize_t *current_size |
Array containing current size of dataspace. |
const hsize_t *maximum_size |
Array containing maximum size of dataspace. |
SUBROUTINE h5sset_extent_simple_f(space_id, rank, current_size, maximum_size, hdferr) IMPLICIT NONE INTEGER(HID_T), INTENT(IN) :: space_id ! Dataspace identifier INTEGER, INTENT(IN) :: rank ! Dataspace rank INTEGER(HSIZE_T), DIMENSION(rank), INTENT(IN) :: current_size ! Array with the new sizes ! of dimensions INTEGER(HSIZE_T), DIMENSION(rank), INTENT(IN) :: ! Array with the new maximum ! sizes of dimensions INTEGER, INTENT(OUT) :: hdferr ! Error code ! 0 on success and -1 on failure END SUBROUTINE h5sset_extent_simple_f
HDF5 documents and links Introduction to HDF5 HDF5 User Guide |
And in this document, the
HDF5 Reference Manual H5 H5A H5D H5E H5F H5G H5I H5P H5R H5S H5T H5Z Tools Datatypes Collective Calls in Parallel |
(PDF of complete manual formatted as print volume) |