-
-
Notifications
You must be signed in to change notification settings - Fork 15
/
H5ObjectEx_D_ReadWrite.java
128 lines (113 loc) · 3.71 KB
/
H5ObjectEx_D_ReadWrite.java
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
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
/************************************************************
This example shows how to read and write data to a
dataset. The program first writes integers to a dataset
with dataspace dimensions of DIM_XxDIM_Y, then closes the
file. Next, it reopens the file, reads back the data, and
outputs it to the screen.
************************************************************/
package datasets;
import hdf.object.Dataset;
import hdf.object.Datatype;
import hdf.object.FileFormat;
import hdf.object.h5.H5Datatype;
import hdf.object.h5.H5File;
public class H5ObjectEx_D_ReadWrite {
private static String FILENAME = "H5ObjectEx_D_ReadWrite.h5";
private static String DATASETNAME = "DS1";
private static final int DIM_X = 4;
private static final int DIM_Y = 7;
private static final int DATATYPE_SIZE = 4;
private static void WriteDataset()
{
H5File file = null;
Dataset dset = null;
long[] dims = {DIM_X, DIM_Y};
int[][] dset_data = new int[DIM_X][DIM_Y];
H5Datatype typeInt = null;
// Initialize data.
for (int indx = 0; indx < DIM_X; indx++)
for (int jndx = 0; jndx < DIM_Y; jndx++)
dset_data[indx][jndx] = indx * jndx - jndx;
// Create a new file using default properties.
try {
file = new H5File(FILENAME, FileFormat.CREATE);
file.open();
}
catch (Exception e) {
e.printStackTrace();
}
// Create the datatype.
try {
typeInt =
new H5Datatype(Datatype.CLASS_INTEGER, DATATYPE_SIZE, Datatype.ORDER_LE, Datatype.NATIVE);
}
catch (Exception e) {
e.printStackTrace();
}
// Create the dataset. We will use all default properties for this example.
// And write the data to the dataset.
try {
dset = file.createScalarDS("/" + DATASETNAME, null, typeInt, dims, null, null, 0, dset_data);
}
catch (Exception e) {
e.printStackTrace();
}
// Close the file.
try {
file.close();
}
catch (Exception e) {
e.printStackTrace();
}
}
private static void ReadDataset()
{
H5File file = null;
Dataset dset = null;
int[] dset_data = new int[DIM_X * DIM_Y];
// Open file using the default properties.
try {
file = new H5File(FILENAME, FileFormat.READ);
file.open();
}
catch (Exception e) {
e.printStackTrace();
}
// Open dataset using the default properties.
try {
dset = (Dataset)file.get(DATASETNAME);
}
catch (Exception e) {
e.printStackTrace();
}
// Read the data using the default properties.
try {
dset.init();
dset_data = (int[])dset.getData();
}
catch (Exception e) {
e.printStackTrace();
}
// Output the data to the screen.
System.out.println(DATASETNAME + ":");
for (int indx = 0; indx < DIM_X; indx++) {
System.out.print(" [ ");
for (int jndx = 0; jndx < DIM_Y; jndx++)
System.out.print(dset_data[indx * DIM_Y + jndx] + " ");
System.out.println("]");
}
System.out.println();
// Close the file.
try {
file.close();
}
catch (Exception e) {
e.printStackTrace();
}
}
public static void main(String[] args)
{
H5ObjectEx_D_ReadWrite.WriteDataset();
H5ObjectEx_D_ReadWrite.ReadDataset();
}
}