IODA
|
Implementation of the HDF5 backend. More...
Files | |
file | Handles.cpp |
HDF5 resource handles in C++. | |
file | Handles.h |
HDF5 resource handles in C++. | |
file | HH-attributes.h |
HDF5 engine implementation of Attribute. | |
file | HH-Filters.h |
HDF5 filters. | |
file | HH-groups.h |
HDF5 group interface. | |
file | HH-hasattributes.h |
HDF5 engine implementation of Has_Attributes. | |
file | HH-hasvariables.h |
HDF5 engine implementation of Has_Variables. | |
file | HH-types.h |
HDF5 engine implementation of ioda::detail::Type_Provider. | |
file | HH-util.h |
Utility functions for HDF5. | |
file | HH-variablecreation.h |
HDF5 engine variable creation parameters. | |
file | HH-variables.h |
HDF5 engine implementation of Variable. | |
file | HH-attributes.cpp |
HDF5 engine implementation of Attribute. | |
file | HH-Filters.cpp |
HDF5 filters. | |
file | HH-groups.cpp |
HDF5 engine implementation of Group. | |
file | HH-hasattributes.cpp |
HDF5 engine implementation of Has_Attributes. | |
file | HH-hasvariables.cpp |
HDF5 engine implementation of Has_Variables. | |
file | HH-types.cpp |
HDF5 engine implementation of Type. | |
file | HH-util.cpp |
HDF5 utility functions. | |
file | HH-variablecreation.cpp |
HDF5 engine Variable creation and property lists. | |
file | HH-variables.cpp |
HDF5 engine implementation of Variable. | |
Classes | |
class | ioda::detail::Engines::HH::Handles::HH_hid_t |
A class to wrap HDF5's hid_t resource handles. More... | |
struct | ioda::detail::Engines::HH::Handles::InvalidHDF5Handle |
Detect invalid HDF5 ids. More... | |
class | ioda::detail::Engines::HH::HH_Attribute |
This is the implementation of Attributes using HDF5. More... | |
struct | ioda::detail::Engines::HH::Filters |
Order-obeying filter insertions and replacements. More... | |
class | ioda::detail::Engines::HH::HH_Group |
This is the implementation of Groups using HDF5. Do not use outside of IODA. More... | |
class | ioda::detail::Engines::HH::HH_HasAttributes |
This is the implementation of Has_Attributes using HDF5. More... | |
class | ioda::detail::Engines::HH::DatasetParameterPack |
This encapsulates dataset creation parameters. More... | |
class | ioda::detail::Engines::HH::HH_Type_Provider |
This is the implementation of Type_Provider using HDF5. Do not use outside of IODA. More... | |
class | ioda::detail::Engines::HH::HH_Type |
This is the implementation of ioda::Type using HDF5. Do not use outside of IODA. More... | |
struct | ioda::detail::Engines::HH::ds_list_t |
Duplicate the HDF5 dataset list structure for REFERENCE_LISTs. More... | |
struct | ioda::detail::Engines::HH::Iterator_find_attr_data_t |
Data to pass to/from iterator classes. More... | |
struct | ioda::detail::Engines::HH::View_hvl_t< Inner > |
A "view" of hvl_t objects. Adds C++ conveniences to an otherwise troublesome class. More... | |
struct | ioda::detail::Engines::HH::Vlen_data |
Internal structure to encapsulate resources and prevent leaks. More... | |
class | ioda::detail::Engines::HH::VariableCreation |
This encapsulates dataset creation parameters. Used for generating HDF5 property lists for variable creation. More... | |
class | ioda::detail::Engines::HH::HH_Variable |
This is the implementation of Variables using HDF5. More... | |
Typedefs | |
typedef hobj_ref_t | ioda::detail::Engines::HH::ref_t |
Implementation of the HDF5 backend.
typedef hobj_ref_t ioda::detail::Engines::HH::ref_t |
|
strong |
Describes what a handle points to.
Enumerator | |
---|---|
ATTRIBUTE | |
DATASET | |
DATASPACE | |
DATATYPE | |
FILE | |
GROUP | |
LINK | |
PROPERTYLIST | |
REFERENCE | |
UNKNOWN |
|
inline |
|
delete |
|
delete |
|
inline |
|
inline |
HH_hid_t ioda::detail::Engines::HH::attr_reference_list_space | ( | hsize_t | numrefs | ) |
Definition at line 219 of file HH-util.cpp.
HH_hid_t ioda::detail::Engines::HH::attr_reference_list_type | ( | ) |
Definition at line 205 of file HH-util.cpp.
void ioda::detail::Engines::HH::attr_update_dimension_list | ( | HH_Variable * | var, |
const std::vector< std::vector< ref_t >> & | new_dim_list | ||
) |
Attribute DIMENSION_LIST update function.
This function exists to update DIMENSION_LISTs without updating the mirrored REFERENCE_LIST entry in the variable's scales. This is done for performance reasons, as attaching dimension scales for hundreds of variables sequentially is very slow.
NOTE: This code does not use the regular atts.open(...) call for performance reasons when we have to repeat this call for hundreds or thousands of variables. We instead do a creation-order-preferred search.
var | is the variable of interest. |
new_dim_list | is the mapping of dimensions that should be added to the variable. |
Definition at line 126 of file HH-util.cpp.
void ioda::detail::Engines::HH::attr_update_reference_list | ( | HH_Variable * | scale, |
const std::vector< ds_list_t > & | ref_var_axis | ||
) |
Attribute REFERENCE_LIST update function.
This function exists to update REFERENCE_LISTs without updating the mirrored DIMENSION_LIST entry. This is done for performance reasons, as attaching dimension scales for hundreds of variables sequentially is very slow.
NOTE: This code does not use the regular atts.open(...) call for performance reasons when we have to repeat this call for hundreds or thousands of variables. We instead do a creation-order-preferred search.
scale | is the scale of interest. |
ref_var_axis_list | is the mapping of variables-dimension numbers that should be added to the scale's REFERENCE_LIST attribute. |
Definition at line 230 of file HH-util.cpp.
bool ioda::detail::Engines::HH::CanUseSZIP | ( | HH_hid_t | dtype | ) |
Can SZIP encoding be used for a datatype?@detail This depends on the data type and the HDF5 build options. SZIP cannot be applied to compound, array, variable-length, enumerative or user-defined datatypes.
dtype | is the data type. |
Definition at line 48 of file HH-Filters.cpp.
|
inline |
|
inline |
H5_index_t ioda::detail::Engines::HH::getAttrCreationOrder | ( | hid_t | obj, |
H5O_type_t | objType | ||
) |
Determine attribute creation order for a dataset.
obj | is the dataset being queried |
objType | is the type of object (Dataset or Group). |
Check if the variable has attribute creation order stored and/or indexed. This is not the default, but it can speed up object list accesses considerably.
Definition at line 55 of file HH-util.cpp.
std::string ioda::detail::Engines::HH::getNameFromIdentifier | ( | hid_t | obj_id | ) |
Gets a variable / group / link name from an id. Useful for debugging.
obj_id | is the object. |
ioda::Exception | if obj_id is invalid. |
Definition at line 263 of file HH-util.cpp.
std::pair< bool, bool > ioda::detail::Engines::HH::isFilteravailable | ( | H5Z_filter_t | filt | ) |
Check that the given filter is available for encoding/decoding in the HDF5 pipeline.
filt | is the filter in question. Commonly H5Z_FILTER_SZIP. |
Definition at line 33 of file HH-Filters.cpp.
herr_t ioda::detail::Engines::HH::iterate_find_attr | ( | hid_t | loc_id, |
const char * | name, | ||
void * | op_data | ||
) |
Callback function for H5Aiterate / H5Aiterate2 / H5Aiterate1.
Definition at line 37 of file HH-util.cpp.
std::pair< bool, hsize_t > ioda::detail::Engines::HH::iterativeAttributeSearch | ( | hid_t | baseObject, |
const char * | attname, | ||
H5_index_t | iteration_type | ||
) |
Linear search to find an attribute.
baseObject | is the object that could contain the attribute. |
attname | is the name of the attribute. |
iteration_type | is the type of iteration for the search. See getAttrCreationOrder. |
Definition at line 82 of file HH-util.cpp.
HH_Attribute ioda::detail::Engines::HH::iterativeAttributeSearchAndOpen | ( | hid_t | baseObject, |
H5O_type_t | objType, | ||
const char * | attname | ||
) |
Linear search to find and open an attribute, if it exists.
baseObject | is the object that could contain the attribute. |
objType | is the type of object (Dataset or Group). |
attname | is the name of the attribute. |
This function is useful because it is faster than the regular attribute open by name routine, which does not take advantage of attribute creation order indexing. Performance is particularly good when there are few attributes attached to the base object.
Definition at line 100 of file HH-util.cpp.
|
inline |
|
inline |
|
inline |
|
inline |
std::unique_ptr<hvl_t[]> ioda::detail::Engines::HH::Vlen_data::buf |
hsize_t ioda::detail::Engines::HH::Iterator_find_attr_data_t::idx = 0 |
hvl_t& ioda::detail::Engines::HH::View_hvl_t< Inner >::obj |
std::string ioda::detail::Engines::HH::Iterator_find_attr_data_t::search_for |
bool ioda::detail::Engines::HH::Iterator_find_attr_data_t::success = false |