The HDF5 specification defines the standard objects and storage for the
standard HDF5 objects. (For information about the HDF5 library, model and
specification, see the HDF documentation.) This document is an additional
specification do define a standard profile for how to store tables in HDF5.
Table data in HDF5 is stored as HDF5 datasets with standard attributes to define
the properties of the tables.
1. Overview
A generic table is a sequence of records, each record has a name and a type.
Table data is stored as an HDF5 one dimensional compound dataset. A table
is defined as a collection of records whose values are stored in fixed-length
fields. All records have the same structure and all values in each field have
the same data type.
The dataset for a table is distinguished from other datasets by giving
it an attribute "CLASS=TABLE".
Optional attributes allow the storage of a title for the Table and for
each column, and a fill value for each column.
2. Table Attributes
The attributes for the Table are strings. They are written with the H5LTset_attribute_string
Lite API function. "Required" attributes must always be used. "Optional" attributes
must be used when required.
Attributes
-
Attribute name="CLASS" (Required)
-
This attribute is type H5T_C_S1, with size 5.
-
For all Tables, the value of this attribute is "TABLE".
-
This attribute identifies this data set as intended to be interpreted as Table that conforms to the specifications on this page.
Attribute name="VERSION" (Required)
-
This attribute is of type H5T_C_S1, with size corresponding to the length
of the version string. This attribute identifies the version number
of this specification to which it conforms. The current version number
is "0.2".
-
Attribute name="TITLE" (Optional)
-
The TITLE is an optional String that is to be used as the
informative title of the whole table.
The TITLE is set with the parameter
table_title
of the function
H5TBmake_table
.
-
Attribute name="FIELD_(n)_NAME" (Required)
-
The FIELD_(n)_NAME is an optional String that is to be used as the
informative title of column n of the table.
For each of the fields the word FIELD_ is concatenated with
the zero based field (n) index together with the name of the field.
-
Attribute name="FIELD_(n)_FILL" (Optional)
-
The FIELD_(n)_FILL is an optional String that is the fill value for
column n of the table.
For each of the fields the word FIELD_ is concatenated with
the zero based field (n) index together with the fill value, if present.
This value is written only when a fill value is defined for the table.
Table 1. Attributes of an Image Dataset
Attribute Name |
(R = Required
O= Optional) |
Type |
String Size |
Value |
CLASS |
R |
String |
5 |
"TABLE" |
VERSION |
R |
String |
3 |
"0.2" |
TITLE |
O |
String |
|
|
FIELD_(n)_NAME |
R |
String |
|
|
FIELD_(n)_FILL |
O* |
String |
|
|
* The attribute FIELD_(n)_FILL is written to the table if a fill value is
specified on the creation of the Table. Otherwise, it is not.The following
section of code shows the calls necessary to the creation of a table.
/* Create a new HDF5 file using default properties. */
file_id = H5Fcreate( "my_table.h5", H5F_ACC_TRUNC, H5P_DEFAULT, H5P_DEFAULT );
/* Call the make table function */
H5TBmake_table( "Table Title", file_id, "Table1", NFIELDS, NRECORDS, dst_size,
field_names, dst_offset, field_type,
chunk_size, fill_data, compress, p_data )
/* Close the file. */
status = H5Fclose( file_id );