summaryrefslogtreecommitdiffstats
path: root/examples/h5_write.c
blob: 2c52fa7c5eb2206de21335ab01f23aa5606407e0 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98

/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
 * Copyright by the Board of Trustees of the University of Illinois.         *
 * All rights reserved.                                                      *
 *                                                                           *
 * This file is part of HDF5.  The full HDF5 copyright notice, including     *
 * terms governing use, modification, and redistribution, is contained in    *
 * the files COPYING and Copyright.html.  COPYING can be found at the root   *
 * of the source code distribution tree; Copyright.html can be found at the  *
 * root level of an installed copy of the electronic HDF5 document set and   *
 * is linked from the top-level documents page.  It can also be found at     *
 * http://hdf.ncsa.uiuc.edu/HDF5/doc/Copyright.html.  If you do not have     *
 * access to either file, you may request a copy from hdfhelp@ncsa.uiuc.edu. *
 * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */

/*  
 *  This example writes data to the HDF5 file.
 *  Data conversion is performed during write operation.  
 */
 
#include "hdf5.h"

#define H5FILE_NAME        "SDS.h5"
#define DATASETNAME "IntArray" 
#define NX     5                      /* dataset dimensions */
#define NY     6
#define RANK   2

int
main (void)
{
    hid_t       file, dataset;         /* file and dataset handles */
    hid_t       datatype, dataspace;   /* handles */
    hsize_t     dimsf[2];              /* dataset dimensions */
    herr_t      status;                             
    int         data[NX][NY];          /* data to write */
    int         i, j;

    /* 
     * Data  and output buffer initialization. 
     */
    for (j = 0; j < NX; j++) {
	for (i = 0; i < NY; i++)
	    data[j][i] = i + j;
    }     
    /*
     * 0 1 2 3 4 5 
     * 1 2 3 4 5 6
     * 2 3 4 5 6 7
     * 3 4 5 6 7 8
     * 4 5 6 7 8 9
     */

    /*
     * Create a new file using H5F_ACC_TRUNC access,
     * default file creation properties, and default file
     * access properties.
     */
    file = H5Fcreate(H5FILE_NAME, H5F_ACC_TRUNC, H5P_DEFAULT, H5P_DEFAULT);

    /*
     * Describe the size of the array and create the data space for fixed
     * size dataset. 
     */
    dimsf[0] = NX;
    dimsf[1] = NY;
    dataspace = H5Screate_simple(RANK, dimsf, NULL); 

    /* 
     * Define datatype for the data in the file.
     * We will store little endian INT numbers.
     */
    datatype = H5Tcopy(H5T_NATIVE_INT);
    status = H5Tset_order(datatype, H5T_ORDER_LE);

    /*
     * Create a new dataset within the file using defined dataspace and
     * datatype and default dataset creation properties.
     */
    dataset = H5Dcreate(file, DATASETNAME, datatype, dataspace,
			H5P_DEFAULT);

    /*
     * Write the data to the dataset using default transfer properties.
     */
    status = H5Dwrite(dataset, H5T_NATIVE_INT, H5S_ALL, H5S_ALL,
		      H5P_DEFAULT, data);

    /*
     * Close/release resources.
     */
    H5Sclose(dataspace);
    H5Tclose(datatype);
    H5Dclose(dataset);
    H5Fclose(file);
 
    return 0;
}     
S" #define HDF4_IMAGE_CLASS "HDF4_IMAGE_CLASS" #define HDF4_IMAGE_SUBCLASS "HDF4_IMAGE_SUBCLASS" #define HDF4_PALETTE_CLASS "HDF4_PALETTE_CLASS" #define HDF4_PALETTE_TYPE "PAL_TYPE" #define PAL_TYPE "STANDARD8" /* 3. reserved name for HDF5 object name when meeting with name clashing. */ #define HDF4_VGROUP "HDF4_VGROUP" #define HDF4_PALETTE "HDF4_PALETTE" #define HDF4_SDS "HDF4_SDS" #define HDF4_VDATA "HDF4_VDATA" #define HDF4_IMAGE "HDF4_IMAGE" #define HDF4_DIMSCALE "HDF4_DIMSCALE" /* 4. global palette and dimension_list name. */ #define HDF4_IMAGE_PALETTE "HDF4_IMAGE_PALETTE" #define HDF4_DIMENSION_LIST "HDF4_DIMENSION_LIST" #define PALETTE "PALETTE" #define DIMSCALE "DIMSCALE" /* 5. define affix GLO for sds and image file attributes. these file attributes will be put under root group. */ #define GLOSDS "GLOSDS" #define GLOIMAGE "GLOIMAGE" /* 6. define HDF object label.*/ #define SDSLABEL "SDS" #define VDATALABEL "Vdata" #define VGROUPLABEL "Vgroup" #define GRLABEL "GR" #define RAST8LABEL "raster8" #define RAST24LABEL "raster24" #define PALABEL "palette" /* 7. define "IMAGE" CLASS required by image spec. */ #define IM_CLASS "IMAGE" /* 8. reserved group name for HDF4 dimensional scale and palette. */ #define HDF4_DIMG "/HDF4_DIMGROUP" #define HDF4_PALG "/HDF4_PALGROUP" /* 9. reserved name for hdf4 file label,file description, object label, object description. */ #define HDF4_FILE_LABEL "HDF4_FILE_LABEL" #define HDF4_FILE_DESC "HDF4_FILE_DESCRIPTION" #define HDF4_OBJECT_LABEL "HDF4_OBJECT_LABEL" #define HDF4_OBJECT_DESC "HDF4_OBJECT_DESCRIPTION" #define HDF4_SDS_LABEL "HDF4_SDS_LABEL" #define HDF4_SDS_DESC "HDF4_SDS_DESC" #define HDF4_IMAGE_LABEL "HDF4_IMAGE_LABEL" #define HDF4_IMAGE_DESC "HDF4_IMAGE_DESC" #define HDF4_VDATA_LABEL "HDF4_VDATA_LABEL" #define HDF4_VDATA_DESC "HDF4_VDATA_DESC" #define HDF4_VGROUP_LABEL "HDF4_VGROUP_LABEL" #define HDF4_VGROUP_DESC "HDF4_VGROUP_DESC" #define HDF4_PAL_LABEL "HDF4_PAL_LABEL" #define HDF4_PAL_DESC "HDF4_PAL_DESC" #define HDF4_IMAGE_INDEXED "HDF4_IMAGE_INDEXED" /*10. palette and dimensional scale hash size and the maximum length of object reference number in string format. global variables of vgroup, vdata, sds, image and total number of the object, number of global sds attributes and GR attributes.*/ #define PAL_HASHSIZE 64 #define DIM_HASHSIZE 64 #define VG_DEFHASHSIZE 64 #define VD_DEFHASHSIZE 64 #define MAXREF_LENGTH 5 /*considering the string size of HDF4_DIMGROUP. we add this into 276.*/ #define MAX_DIM_NAME 276 extern int32 estnum_vg; extern int32 estnum_vd; extern int32 num_sds; extern int32 num_images; extern int num_objects; extern int32 num_glsdsattrs; extern int32 num_glgrattrs; /**********************************************/ /*************** section II *******************/ /*This section describes hash tables and their functions used in h4-h5 converter.*/ /*********************************************/ /*define two kinds of hashtables. 1. struct table uses object reference as the key to handle whether this object is visited or not. 2. struct name_table uses object name as the key to handle name clashings and dimensional scale dataset. */ struct table { int ref; struct table *next; char *name; }; struct name_table { char *name; struct name_table *next; }; extern struct table* sds_hashtab; extern struct table* gr_hashtab; extern struct table* vg_hashtab; extern struct table* vd_hashtab; extern struct table* pal_hashtab; extern struct name_table* name_hashtab; extern struct name_table* dim_hashtab; /* routine for zeroing out the memory. */ void h4toh5_ZeroMemory(void*s,size_t n); /* look-up table, object reference is the key.*/ int lookup(int,int,struct table*); /*look-up table, key is name. */ int hash_fun(char*name,int size); int lookup_name(char*, int,struct name_table*); /* routines that initialize the tables and name tables.*/ int init_tab(int,struct table*); int init_nametab(int,struct name_table*); /* get name and set name for table. */ char* get_name(int,int,struct table *,int*); int set_name(int,int,struct table *,char*); /* free table routines. */ int freetable(int,struct table *); int freenametable(int, struct name_table*); void freehashmemory(void); /**********************************************/ /*************** section III *******************/ /*This section describes other common routines and their functions used in h4-h5 converter.*/ /*********************************************/ /* this routine defines the conversion of data type from h4 to h5. */ herr_t h4type_to_h5type(const int32 h4type, hid_t* h5memtype, size_t* h4memsize, size_t* h4size, hid_t *h5type); /* routines for translating predefined hdf4 attributes into hdf5 attributes*/ int h4_transpredattrs(hid_t ,const char *,char*data); int h4_transnumattr(hid_t h5g,const char *,uint16 group_ref); int vg_transattrs(int32,hid_t); /*string and int conversion routines.*/ hid_t mkstr(int size, H5T_str_t pad); herr_t h5string_to_int(const int32, hid_t*,const size_t,hid_t* ); int conv_int_str(uint16, char*); /* these routines were utility functions for other routines at h4toh5util.c */ char* trans_obj_name(int32,int32); char* get_obj_aboname(char*,char*,char*,const char*); char* make_objname_no(char*,char*,const char*); char* make_objname_yes(char*,char*); char* correct_name(char*); #endif