1999-06-26 02:11:09 +08:00
|
|
|
/*
|
1999-07-07 04:43:00 +08:00
|
|
|
* This program illustrates how references to objects can be used.
|
|
|
|
* Program creates a dataset and a group in a file. It also creates
|
|
|
|
* second dataset, and references to the first dataset and the group
|
|
|
|
* are stored in it.
|
1999-06-26 02:11:09 +08:00
|
|
|
* Program reopens the file and reads dataset with the references.
|
1999-07-07 04:43:00 +08:00
|
|
|
* References are used to open the objects. Information about the
|
|
|
|
* objects is displayed.
|
|
|
|
*/
|
1999-06-26 02:11:09 +08:00
|
|
|
|
1999-07-02 03:16:36 +08:00
|
|
|
#include <stdlib.h>
|
2001-04-04 02:33:07 +08:00
|
|
|
|
|
|
|
#include "hdf5.h"
|
1999-06-26 02:11:09 +08:00
|
|
|
|
2001-06-06 02:00:37 +08:00
|
|
|
#define H5FILE_NAME "refere.h5"
|
1999-06-26 02:11:09 +08:00
|
|
|
|
|
|
|
int
|
|
|
|
main(void) {
|
1999-07-07 04:43:00 +08:00
|
|
|
hid_t fid; /* File, group, datasets, datatypes */
|
|
|
|
hid_t gid_a; /* and dataspaces identifiers */
|
|
|
|
hid_t did_b, sid_b, tid_b;
|
1999-06-26 02:11:09 +08:00
|
|
|
hid_t did_r, tid_r, sid_r;
|
|
|
|
herr_t status;
|
|
|
|
|
|
|
|
hobj_ref_t *wbuf; /* buffer to write to disk */
|
|
|
|
hobj_ref_t *rbuf; /* buffer to read from disk */
|
|
|
|
|
|
|
|
|
|
|
|
hsize_t dim_r[1];
|
|
|
|
hsize_t dim_b[2];
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Create a file using default properties.
|
|
|
|
*/
|
2001-06-06 02:00:37 +08:00
|
|
|
fid = H5Fcreate(H5FILE_NAME, H5F_ACC_TRUNC, H5P_DEFAULT, H5P_DEFAULT);
|
1999-06-26 02:11:09 +08:00
|
|
|
|
|
|
|
/*
|
1999-07-07 04:43:00 +08:00
|
|
|
* Create group "A" in the file.
|
1999-06-26 02:11:09 +08:00
|
|
|
*/
|
2001-06-19 04:22:10 +08:00
|
|
|
gid_a = H5Gcreate(fid, "A", 0);
|
1999-06-26 02:11:09 +08:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Create dataset "B" in the file.
|
|
|
|
*/
|
|
|
|
dim_b[0] = 2;
|
|
|
|
dim_b[1] = 6;
|
|
|
|
sid_b = H5Screate_simple(2, dim_b, NULL);
|
|
|
|
did_b = H5Dcreate(fid, "B", H5T_NATIVE_FLOAT, sid_b, H5P_DEFAULT);
|
|
|
|
|
|
|
|
/*
|
1999-07-07 04:43:00 +08:00
|
|
|
* Create dataset "R" to store references to the objects "A" and "B".
|
1999-06-26 02:11:09 +08:00
|
|
|
*/
|
|
|
|
dim_r[0] = 2;
|
|
|
|
sid_r = H5Screate_simple(1, dim_r, NULL);
|
|
|
|
tid_r = H5Tcopy(H5T_STD_REF_OBJ);
|
|
|
|
did_r = H5Dcreate(fid, "R", tid_r, sid_r, H5P_DEFAULT );
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Allocate write and read buffers.
|
|
|
|
*/
|
1999-07-07 04:43:00 +08:00
|
|
|
wbuf = (hobj_ref_t *)malloc(sizeof(hobj_ref_t)*2);
|
|
|
|
rbuf = (hobj_ref_t *)malloc(sizeof(hobj_ref_t)*2);
|
1999-06-26 02:11:09 +08:00
|
|
|
|
|
|
|
/*
|
1999-07-07 04:43:00 +08:00
|
|
|
* Create references to the group "A" and dataset "B"
|
1999-06-26 02:11:09 +08:00
|
|
|
* and store them in the wbuf.
|
|
|
|
*/
|
|
|
|
H5Rcreate(&wbuf[0], fid, "A", H5R_OBJECT, -1);
|
|
|
|
H5Rcreate(&wbuf[1], fid, "B", H5R_OBJECT, -1);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Write dataset R using default transfer properties.
|
|
|
|
*/
|
|
|
|
status = H5Dwrite(did_r, H5T_STD_REF_OBJ, H5S_ALL, H5S_ALL,
|
|
|
|
H5P_DEFAULT, wbuf);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Close all objects.
|
|
|
|
*/
|
1999-07-07 04:43:00 +08:00
|
|
|
H5Gclose(gid_a);
|
1999-06-26 02:11:09 +08:00
|
|
|
|
|
|
|
H5Sclose(sid_b);
|
|
|
|
H5Dclose(did_b);
|
|
|
|
|
|
|
|
H5Tclose(tid_r);
|
|
|
|
H5Sclose(sid_r);
|
|
|
|
H5Dclose(did_r);
|
|
|
|
|
|
|
|
H5Fclose(fid);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Reopen the file.
|
|
|
|
*/
|
2001-06-06 02:00:37 +08:00
|
|
|
fid = H5Fopen(H5FILE_NAME, H5F_ACC_RDWR, H5P_DEFAULT);
|
1999-06-26 02:11:09 +08:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Open and read dataset "R".
|
|
|
|
*/
|
1999-07-07 04:43:00 +08:00
|
|
|
did_r = H5Dopen(fid, "R");
|
1999-06-26 02:11:09 +08:00
|
|
|
status = H5Dread(did_r, H5T_STD_REF_OBJ, H5S_ALL, H5S_ALL,
|
|
|
|
H5P_DEFAULT, rbuf);
|
|
|
|
|
|
|
|
/*
|
1999-07-07 04:43:00 +08:00
|
|
|
* Find the type of referenced objects.
|
1999-06-26 02:11:09 +08:00
|
|
|
*/
|
2001-12-21 04:51:30 +08:00
|
|
|
status = H5Rget_obj_type(did_r, H5R_OBJECT, &rbuf[0]);
|
1999-07-07 04:43:00 +08:00
|
|
|
if ( status == H5G_GROUP )
|
|
|
|
printf("First dereferenced object is a group. \n");
|
1999-06-26 02:11:09 +08:00
|
|
|
|
2001-12-21 04:51:30 +08:00
|
|
|
status = H5Rget_obj_type(did_r, H5R_OBJECT, &rbuf[1]);
|
1999-07-07 04:43:00 +08:00
|
|
|
if ( status == H5G_DATASET )
|
|
|
|
printf("Second dereferenced object is a dataset. \n");
|
1999-06-26 02:11:09 +08:00
|
|
|
/*
|
|
|
|
* Get datatype of the dataset "B"
|
|
|
|
*/
|
|
|
|
did_b = H5Rdereference(did_r, H5R_OBJECT, &rbuf[1]);
|
|
|
|
tid_b = H5Dget_type(did_b);
|
|
|
|
if(H5Tequal(tid_b, H5T_NATIVE_FLOAT))
|
1999-07-07 04:43:00 +08:00
|
|
|
printf("Datatype of the dataset is H5T_NATIVE_FLOAT.\n");
|
1999-06-26 02:11:09 +08:00
|
|
|
printf("\n");
|
|
|
|
|
|
|
|
/*
|
1999-07-07 04:43:00 +08:00
|
|
|
* Close all objects and free memory buffers.
|
1999-06-26 02:11:09 +08:00
|
|
|
*/
|
1999-07-07 04:43:00 +08:00
|
|
|
H5Dclose(did_r);
|
1999-06-26 02:11:09 +08:00
|
|
|
H5Dclose(did_b);
|
|
|
|
H5Tclose(tid_b);
|
|
|
|
H5Fclose(fid);
|
1999-07-07 04:43:00 +08:00
|
|
|
free(rbuf);
|
|
|
|
free(wbuf);
|
1999-06-26 02:11:09 +08:00
|
|
|
return 0;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|