2004-02-10 23:42:55 +08:00
|
|
|
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
2007-02-07 22:56:24 +08:00
|
|
|
* Copyright by The HDF Group. *
|
2004-02-10 23:42:55 +08:00
|
|
|
* All rights reserved. *
|
|
|
|
* *
|
|
|
|
* This file is part of HDF5. The full HDF5 copyright notice, including *
|
|
|
|
* terms governing use, modification, and redistribution, is contained in *
|
2017-04-18 03:32:16 +08:00
|
|
|
* the COPYING file, which can be found at the root of the source code *
|
2021-02-17 22:52:36 +08:00
|
|
|
* distribution tree, or in https://www.hdfgroup.org/licenses. *
|
2017-04-18 03:32:16 +08:00
|
|
|
* If you do not have access to either file, you may request a copy from *
|
|
|
|
* help@hdfgroup.org. *
|
2004-02-10 23:42:55 +08:00
|
|
|
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
|
|
|
|
1998-02-09 02:38:20 +08:00
|
|
|
/*
|
|
|
|
* This example shows how to create a compound data type,
|
|
|
|
* write an array which has the compound data type to the file,
|
|
|
|
* and read back fields' subsets.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "hdf5.h"
|
|
|
|
|
2020-09-30 22:27:10 +08:00
|
|
|
#define H5FILE_NAME "SDScompound.h5"
|
|
|
|
#define DATASETNAME "ArrayOfStructures"
|
|
|
|
#define LENGTH 10
|
|
|
|
#define RANK 1
|
1998-02-09 02:38:20 +08:00
|
|
|
|
1998-09-01 03:21:23 +08:00
|
|
|
int
|
|
|
|
main(void)
|
1998-02-09 02:38:20 +08:00
|
|
|
{
|
|
|
|
|
1998-09-01 03:21:23 +08:00
|
|
|
/* First structure and dataset*/
|
|
|
|
typedef struct s1_t {
|
2020-09-30 22:27:10 +08:00
|
|
|
int a;
|
|
|
|
float b;
|
|
|
|
double c;
|
1998-09-01 03:21:23 +08:00
|
|
|
} s1_t;
|
2020-09-30 22:27:10 +08:00
|
|
|
s1_t s1[LENGTH];
|
|
|
|
hid_t s1_tid; /* File datatype identifier */
|
1998-09-01 03:21:23 +08:00
|
|
|
|
|
|
|
/* Second structure (subset of s1_t) and dataset*/
|
|
|
|
typedef struct s2_t {
|
2020-09-30 22:27:10 +08:00
|
|
|
double c;
|
|
|
|
int a;
|
1998-09-01 03:21:23 +08:00
|
|
|
} s2_t;
|
2020-09-30 22:27:10 +08:00
|
|
|
s2_t s2[LENGTH];
|
|
|
|
hid_t s2_tid; /* Memory datatype handle */
|
1998-09-01 03:21:23 +08:00
|
|
|
|
|
|
|
/* Third "structure" ( will be used to read float field of s1) */
|
2020-09-30 22:27:10 +08:00
|
|
|
hid_t s3_tid; /* Memory datatype handle */
|
|
|
|
float s3[LENGTH];
|
1998-09-01 03:21:23 +08:00
|
|
|
|
2020-09-30 22:27:10 +08:00
|
|
|
int i;
|
|
|
|
hid_t file, dataset, space; /* Handles */
|
|
|
|
herr_t status;
|
|
|
|
hsize_t dim[] = {LENGTH}; /* Dataspace dimensions */
|
1998-09-01 03:21:23 +08:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Initialize the data
|
|
|
|
*/
|
2020-09-30 22:27:10 +08:00
|
|
|
for (i = 0; i < LENGTH; i++) {
|
1998-02-09 02:38:20 +08:00
|
|
|
s1[i].a = i;
|
2020-09-30 22:27:10 +08:00
|
|
|
s1[i].b = i * i;
|
|
|
|
s1[i].c = 1. / (i + 1);
|
1998-09-01 03:21:23 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Create the data space.
|
|
|
|
*/
|
|
|
|
space = H5Screate_simple(RANK, dim, NULL);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Create the file.
|
|
|
|
*/
|
2001-06-06 02:00:37 +08:00
|
|
|
file = H5Fcreate(H5FILE_NAME, H5F_ACC_TRUNC, H5P_DEFAULT, H5P_DEFAULT);
|
1998-09-01 03:21:23 +08:00
|
|
|
|
|
|
|
/*
|
2005-08-14 04:53:35 +08:00
|
|
|
* Create the memory data type.
|
1998-09-01 03:21:23 +08:00
|
|
|
*/
|
2020-09-30 22:27:10 +08:00
|
|
|
s1_tid = H5Tcreate(H5T_COMPOUND, sizeof(s1_t));
|
1998-09-01 03:21:23 +08:00
|
|
|
H5Tinsert(s1_tid, "a_name", HOFFSET(s1_t, a), H5T_NATIVE_INT);
|
|
|
|
H5Tinsert(s1_tid, "c_name", HOFFSET(s1_t, c), H5T_NATIVE_DOUBLE);
|
|
|
|
H5Tinsert(s1_tid, "b_name", HOFFSET(s1_t, b), H5T_NATIVE_FLOAT);
|
|
|
|
|
2005-08-14 04:53:35 +08:00
|
|
|
/*
|
1998-09-01 03:21:23 +08:00
|
|
|
* Create the dataset.
|
|
|
|
*/
|
[svn-r14199] Description:
Add H5Dcreate to API versioned routines, replacing internal usage with
H5Dcreate2
Fix thread-safe error stack initialization for API versioned error
stack printing routines.
Tested on:
FreeBSD/32 6.2 (duty) in debug mode
FreeBSD/64 6.2 (liberty) w/C++ & FORTRAN, in debug mode
Linux/32 2.6 (kagiso) w/PGI compilers, w/C++ & FORTRAN, w/threadsafe,
in debug mode
Linux/64-amd64 2.6 (smirom) w/default API=1.6.x, w/C++ & FORTRAN,
in production mode
Linux/64-ia64 2.6 (cobalt) w/Intel compilers, w/C++ & FORTRAN,
in production mode
Solaris/32 2.10 (linew) w/deprecated symbols disabled, w/C++ & FORTRAN,
w/szip filter, in production mode
Mac OS X/32 10.4.10 (amazon) in debug mode
2007-10-12 00:24:11 +08:00
|
|
|
dataset = H5Dcreate2(file, DATASETNAME, s1_tid, space, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT);
|
1998-09-01 03:21:23 +08:00
|
|
|
|
|
|
|
/*
|
2005-08-14 04:53:35 +08:00
|
|
|
* Wtite data to the dataset;
|
1998-09-01 03:21:23 +08:00
|
|
|
*/
|
|
|
|
status = H5Dwrite(dataset, s1_tid, H5S_ALL, H5S_ALL, H5P_DEFAULT, s1);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Release resources
|
|
|
|
*/
|
|
|
|
H5Tclose(s1_tid);
|
|
|
|
H5Sclose(space);
|
|
|
|
H5Dclose(dataset);
|
|
|
|
H5Fclose(file);
|
2005-08-14 04:53:35 +08:00
|
|
|
|
1998-09-01 03:21:23 +08:00
|
|
|
/*
|
|
|
|
* Open the file and the dataset.
|
|
|
|
*/
|
2001-06-06 02:00:37 +08:00
|
|
|
file = H5Fopen(H5FILE_NAME, H5F_ACC_RDONLY, H5P_DEFAULT);
|
2005-08-14 04:53:35 +08:00
|
|
|
|
[svn-r14193] Description:
Make H5Dopen versioned and change all internal usage to use H5Dopen2
Add simple regression test for H5Dopen1
Tested on:
FreeBSD/32 6.2 (duty) in debug mode
FreeBSD/64 6.2 (liberty) w/C++ & FORTRAN, in debug mode
Linux/32 2.6 (kagiso) w/PGI compilers, w/C++ & FORTRAN, w/threadsafe,
in debug mode
Linux/64-amd64 2.6 (smirom) w/default API=1.6.x, w/C++ & FORTRAN,
in production mode
Linux/64-ia64 2.6 (cobalt) w/Intel compilers, w/C++ & FORTRAN,
in production mode
Solaris/32 2.10 (linew) w/deprecated symbols disabled, w/C++ & FORTRAN,
w/szip filter, in production mode
Mac OS X/32 10.4.10 (amazon) in debug mode
2007-10-09 03:59:36 +08:00
|
|
|
dataset = H5Dopen2(file, DATASETNAME, H5P_DEFAULT);
|
1998-09-01 03:21:23 +08:00
|
|
|
|
2005-08-14 04:53:35 +08:00
|
|
|
/*
|
1998-09-01 03:21:23 +08:00
|
|
|
* Create a data type for s2
|
|
|
|
*/
|
|
|
|
s2_tid = H5Tcreate(H5T_COMPOUND, sizeof(s2_t));
|
|
|
|
|
|
|
|
H5Tinsert(s2_tid, "c_name", HOFFSET(s2_t, c), H5T_NATIVE_DOUBLE);
|
|
|
|
H5Tinsert(s2_tid, "a_name", HOFFSET(s2_t, a), H5T_NATIVE_INT);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Read two fields c and a from s1 dataset. Fields in the file
|
|
|
|
* are found by their names "c_name" and "a_name".
|
|
|
|
*/
|
|
|
|
status = H5Dread(dataset, s2_tid, H5S_ALL, H5S_ALL, H5P_DEFAULT, s2);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Display the fields
|
|
|
|
*/
|
|
|
|
printf("\n");
|
|
|
|
printf("Field c : \n");
|
2020-09-30 22:27:10 +08:00
|
|
|
for (i = 0; i < LENGTH; i++)
|
|
|
|
printf("%.4f ", s2[i].c);
|
1998-09-01 03:21:23 +08:00
|
|
|
printf("\n");
|
|
|
|
|
|
|
|
printf("\n");
|
|
|
|
printf("Field a : \n");
|
2020-09-30 22:27:10 +08:00
|
|
|
for (i = 0; i < LENGTH; i++)
|
|
|
|
printf("%d ", s2[i].a);
|
1998-09-01 03:21:23 +08:00
|
|
|
printf("\n");
|
|
|
|
|
2005-08-14 04:53:35 +08:00
|
|
|
/*
|
1998-09-01 03:21:23 +08:00
|
|
|
* Create a data type for s3.
|
|
|
|
*/
|
|
|
|
s3_tid = H5Tcreate(H5T_COMPOUND, sizeof(float));
|
|
|
|
|
|
|
|
status = H5Tinsert(s3_tid, "b_name", 0, H5T_NATIVE_FLOAT);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Read field b from s1 dataset. Field in the file is found by its name.
|
|
|
|
*/
|
|
|
|
status = H5Dread(dataset, s3_tid, H5S_ALL, H5S_ALL, H5P_DEFAULT, s3);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Display the field
|
|
|
|
*/
|
|
|
|
printf("\n");
|
|
|
|
printf("Field b : \n");
|
2020-09-30 22:27:10 +08:00
|
|
|
for (i = 0; i < LENGTH; i++)
|
|
|
|
printf("%.4f ", s3[i]);
|
1998-09-01 03:21:23 +08:00
|
|
|
printf("\n");
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Release resources
|
|
|
|
*/
|
|
|
|
H5Tclose(s2_tid);
|
|
|
|
H5Tclose(s3_tid);
|
|
|
|
H5Dclose(dataset);
|
|
|
|
H5Fclose(file);
|
|
|
|
|
|
|
|
return 0;
|
1998-02-09 02:38:20 +08:00
|
|
|
}
|