mirror of
https://github.com/HDFGroup/hdf5.git
synced 2025-02-17 16:10:24 +08:00
while he is visiting LLNL. I changed the default creation template offset and length to 4. Will fix the problem later. Changes since 19980205 ---------------------- ./src/H5H.c ./src/H5Hprivate.h ./src/H5O.c ./src/H5Ocont.c ./src/H5Odtype.c ./src/H5Oefl.c ./src/H5Olayout.c ./src/H5Oname.c ./src/H5Onull.c ./src/H5Oprivate.h ./src/H5Odspace.c ./src/H5Ostab.c ./src/debug.c ./html/H5.format.html Added an extra 4-byte field after the heap magic number for alignment on the DEC alpha. Changed object header message alignment to 8-bytes. ./src/H5F.c ./src/H5Farray.c ./src/H5Ffamily.c ./src/H5Fistore.c ./src/H5Flow.c ./src/H5Fprivate.h ./src/H5Fsec2.c ./src/H5Fstdio.c ./src/H5Gnode.c ./src/H5O.c ./src/H5Odtype.c ./src/H5P.c ./src/H5Pprivate.h ./src/H5T.c ./src/H5Tconv.c ./src/H5Tpkg.h ./src/H5Tpublic.h ./src/H5V.c ./src/H5detect.c ./test/cmpd_dset.c ./test/dsets.c ./test/dtypes.c ./test/extend.c ./test/hyperslab.c ./test/istore.c ./test/th5p.c ./test/theap.c Fixed a few irix64 warnings regarding size_t vs. int, variables set but not used, printf formats ./config/irix64 Added `-woff 1196' to get rid of errors about __vfork() being implicitly defined in a system header file. ./src/H5B.c Fixed a stack alignment problem.
132 lines
3.2 KiB
C
132 lines
3.2 KiB
C
/*
|
||
* Copyright (C) 1998 Spizella Software
|
||
* All rights reserved.
|
||
*
|
||
* Programmer: Robb Matzke <matzke@llnl.gov>
|
||
* Friday, January 30, 1998
|
||
*
|
||
* Purpose: Tests extendable datasets.
|
||
*/
|
||
#include <assert.h>
|
||
#include <hdf5.h>
|
||
|
||
#define NX 100 /* USE AN EVEN NUMBER!*/
|
||
#define NY 100 /* USE AN EVEN NUMBER!*/
|
||
|
||
|
||
/*-------------------------------------------------------------------------
|
||
* Function: main
|
||
*
|
||
* Purpose: Tests extendable datasets
|
||
*
|
||
* Return: Success: exit(0)
|
||
*
|
||
* Failure: exit(non-zero)
|
||
*
|
||
* Programmer: Robb Matzke
|
||
* Friday, January 30, 1998
|
||
*
|
||
* Modifications:
|
||
*
|
||
*-------------------------------------------------------------------------
|
||
*/
|
||
int
|
||
main (void)
|
||
{
|
||
hid_t file, dataset, mem_space, file_space, cparms;
|
||
herr_t status;
|
||
int i, j, k, m;
|
||
static int buf1[NY][NX], buf2[NX/2][NY/2];
|
||
static const size_t dims[2] = {NX, NY};
|
||
static const size_t half_dims[2] = {NX/2, NY/2};
|
||
static const size_t chunk_dims[2] = {NX/2, NY/2};
|
||
static size_t maxdims[2] = {H5P_UNLIMITED, H5P_UNLIMITED};
|
||
static size_t size[2];
|
||
int offset[2];
|
||
|
||
/* Initialize buffer and space */
|
||
for (i=0; i<NX; i++) {
|
||
for (j=0; j<NY; j++) {
|
||
buf1[i][j] = i*NY+j;
|
||
}
|
||
}
|
||
mem_space = H5Pcreate_simple (2, dims, maxdims);
|
||
assert (mem_space>=0);
|
||
|
||
/* Create the file */
|
||
file = H5Fcreate ("extend.h5", H5ACC_OVERWRITE, H5C_DEFAULT, H5C_DEFAULT);
|
||
assert (file>=0);
|
||
|
||
/* Create the dataset which is originally NX by NY */
|
||
cparms = H5Ccreate (H5C_DATASET_CREATE);
|
||
assert (cparms>=0);
|
||
status = H5Cset_chunk (cparms, 2, chunk_dims);
|
||
assert (status>=0);
|
||
dataset = H5Dcreate (file, "dataset", H5T_NATIVE_INT, mem_space, cparms);
|
||
assert (dataset>=0);
|
||
|
||
/* Write the data */
|
||
for (i=0; i<5; i++) {
|
||
for (j=0; j<5; j++) {
|
||
|
||
/* Extend the dataset */
|
||
offset[0] = i * NX;
|
||
offset[1] = j * NY;
|
||
size[0] = offset[0] + NX;
|
||
size[1] = offset[1] + NY;
|
||
status = H5Dextend (dataset, size);
|
||
assert (status>=0);
|
||
|
||
/* Select a hyperslab */
|
||
file_space = H5Dget_space (dataset);
|
||
assert (file_space>=0);
|
||
status = H5Pset_hyperslab (file_space, offset, dims, NULL);
|
||
assert (status>=0);
|
||
|
||
/* Write to the hyperslab */
|
||
status = H5Dwrite (dataset, H5T_NATIVE_INT, mem_space, file_space,
|
||
H5C_DEFAULT, buf1);
|
||
assert (status>=0);
|
||
H5Pclose (file_space);
|
||
}
|
||
}
|
||
H5Pclose (mem_space);
|
||
|
||
|
||
/* Read the data */
|
||
mem_space = H5Pcreate_simple (2, half_dims, NULL);
|
||
file_space = H5Dget_space (dataset);
|
||
for (i=0; i<10; i++) {
|
||
for (j=0; j<10; j++) {
|
||
|
||
/* Select a hyperslab */
|
||
offset[0] = i * NX/2;
|
||
offset[1] = j * NY/2;
|
||
assert (file_space>=0);
|
||
status = H5Pset_hyperslab (file_space, offset, half_dims, NULL);
|
||
assert (status>=0);
|
||
|
||
/* Read */
|
||
status = H5Dread (dataset, H5T_NATIVE_INT, mem_space, file_space,
|
||
H5C_DEFAULT, buf2);
|
||
assert (status>=0);
|
||
|
||
/* Compare */
|
||
for (k=0; k<NX/2; k++) {
|
||
for (m=0; m<NY/2; m++) {
|
||
assert (buf2[k][m]==buf1[(i%2)*NX/2+k][(j%2)*NY/2+m]);
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
|
||
H5Dclose (dataset);
|
||
H5Fclose (file);
|
||
|
||
return 0;
|
||
}
|
||
|
||
|
||
|