diff options
Diffstat (limited to 'testpar')
-rw-r--r-- | testpar/t_mdset.c | 147 | ||||
-rw-r--r-- | testpar/testphdf5.c | 22 | ||||
-rw-r--r-- | testpar/testphdf5.h | 2 |
3 files changed, 169 insertions, 2 deletions
diff --git a/testpar/t_mdset.c b/testpar/t_mdset.c index dae0e0f..e3ef984 100644 --- a/testpar/t_mdset.c +++ b/testpar/t_mdset.c @@ -12,6 +12,7 @@ void write_dataset(hid_t, hid_t, hid_t); int read_dataset(hid_t, hid_t, hid_t); void create_group_recursive(hid_t, hid_t, hid_t, int); void recursive_read_group(hid_t, hid_t, hid_t, int); +void group_dataset_read(hid_t fid, int mpi_rank, int mpi_size, int m); void write_attribute(hid_t, int, int); int read_attribute(hid_t, int, int); int check_value(DATATYPE *, DATATYPE *); @@ -201,6 +202,152 @@ void compact_dataset(char *filename) H5Fclose(iof); } +/* Write multiple groups with a chunked dataset in each group collectively. + * These groups and datasets are for testing independent read later. + */ +void collective_group_write(char *filename, int ngroups) +{ + int mpi_rank, mpi_size; + int i, j, m; + char gname[64], dname[32]; + hid_t fid, gid, did, plist, dcpl, memspace, filespace; + DATATYPE outme[SIZE][SIZE]; + hssize_t chunk_origin[DIM]; + hsize_t chunk_dims[DIM], file_dims[DIM], count[DIM]; + const hsize_t chunk_size[2] = {SIZE/2, SIZE/2}; /* Chunk dimensions */ + herr_t ret1, ret2; + + MPI_Comm_rank(MPI_COMM_WORLD, &mpi_rank); + MPI_Comm_size(MPI_COMM_WORLD, &mpi_size); + + plist = create_faccess_plist(MPI_COMM_WORLD, MPI_INFO_NULL, facc_type); + fid = H5Fcreate(filename, H5F_ACC_TRUNC, H5P_DEFAULT, plist); + H5Pclose(plist); + + /* decide the hyperslab according to process number. */ + get_slab(chunk_origin, chunk_dims, count, file_dims); + + /* select hyperslab in memory and file spaces. These two operations are + * identical since the datasets are the same. */ + memspace = H5Screate_simple(DIM, file_dims, NULL); + ret1 = H5Sselect_hyperslab(memspace, H5S_SELECT_SET, chunk_origin, + chunk_dims, count, chunk_dims); + filespace = H5Screate_simple(DIM, file_dims, NULL); + ret2 = H5Sselect_hyperslab(filespace, H5S_SELECT_SET, chunk_origin, + chunk_dims, count, chunk_dims); + VRFY((memspace>=0), "memspace"); + VRFY((filespace>=0), "filespace"); + VRFY((ret1>=0), "mgroup memspace selection"); + VRFY((ret2>=0), "mgroup filespace selection"); + + dcpl = H5Pcreate(H5P_DATASET_CREATE); + ret1 = H5Pset_chunk (dcpl, 2, chunk_size); + VRFY((dcpl>=0), "dataset creation property"); + VRFY((ret1>=0), "set chunk for dataset creation property"); + + /* creates ngroups groups under the root group, writes chunked + * datasets in parallel. */ + for(m = 0; m < ngroups; m++) { + sprintf(gname, "group%d", m); + gid = H5Gcreate(fid, gname, 0); + VRFY((gid > 0), gname); + + sprintf(dname, "dataset%d", m); + did = H5Dcreate(gid, dname, H5T_NATIVE_INT, filespace, dcpl); + VRFY((did > 0), dname); + + for(i=0; i < SIZE; i++) + for(j=0; j < SIZE; j++) + outme[i][j] = (i+j)*1000 + mpi_rank; + + H5Dwrite(did, H5T_NATIVE_INT, memspace, filespace, H5P_DEFAULT, + outme); + + H5Dclose(did); + H5Gclose(gid); + +#ifdef BARRIER_CHECKS + if(! ((m+1) % 10)) { + printf("created %d groups\n", m+1); + MPI_Barrier(MPI_COMM_WORLD); + } +#endif /* BARRIER_CHECKS */ + } + + H5Pclose(dcpl); + H5Sclose(filespace); + H5Sclose(memspace); + H5Fclose(fid); +} + +/* Let two sets of processes open and read different groups and chunked + * datasets independently. + */ +void independent_group_read(char *filename, int ngroups) +{ + int mpi_rank, mpi_size, m; + hid_t plist, fid; + + MPI_Comm_rank(MPI_COMM_WORLD, &mpi_rank); + MPI_Comm_size(MPI_COMM_WORLD, &mpi_size); + + plist = create_faccess_plist(MPI_COMM_WORLD, MPI_INFO_NULL, facc_type); + fid = H5Fopen(filename, H5F_ACC_RDONLY, plist); + H5Pclose(plist); + + /* open groups and read datasets. Odd number processes read even number + * groups from the end; even number processes read odd number groups + * from the beginning. */ + if(mpi_rank%2==0) { + for(m=ngroups-1; m==0; m-=2) + group_dataset_read(fid, mpi_rank, mpi_size, m); + } else { + for(m=0; m<ngroups; m+=2) + group_dataset_read(fid, mpi_rank, mpi_size, m); + } + + H5Fclose(fid); +} + +/* Open and read datasets and compare data */ +void group_dataset_read(hid_t fid, int mpi_rank, int mpi_size, int m) +{ + int ret, i, j; + char gname[64], dname[32]; + hid_t gid, did; + DATATYPE *outdata, *indata; + + indata = (DATATYPE*)malloc(SIZE*SIZE*sizeof(DATATYPE)); + outdata = (DATATYPE*)malloc(SIZE*SIZE*sizeof(DATATYPE)); + + /* open every group under root group. */ + sprintf(gname, "group%d", m); + gid = H5Gopen(fid, gname); + VRFY((gid > 0), gname); + + /* check the data. */ + sprintf(dname, "dataset%d", m); + did = H5Dopen(gid, dname); + VRFY((did>0), dname); + + H5Dread(did, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, indata); + + /* this is the original value */ + for(i=0; i<SIZE; i++) + for(j=0; j<SIZE; j++) { + *outdata = (i+j)*1000 + mpi_rank; + outdata++; + } + outdata -= SIZE*SIZE; + + /* compare the original value(outdata) to the value in file(indata).*/ + ret = check_value(indata, outdata); + VRFY((ret==0), "check the data"); + + H5Dclose(did); + H5Gclose(gid); +} + /* * Example of using PHDF5 to create multiple groups. Under the root group, * it creates ngroups groups. Under the first group just created, it creates diff --git a/testpar/testphdf5.c b/testpar/testphdf5.c index 95dbf03..ea41e93 100644 --- a/testpar/testphdf5.c +++ b/testpar/testphdf5.c @@ -29,16 +29,19 @@ void *old_client_data; /* previous error handler arg.*/ int doread=1; /* read test */ int dowrite=1; /* write test */ int docompact=1; /* compact dataset test */ +int doindependent=1; /* independent test */ + /* FILENAME and filenames must have the same number of names */ -const char *FILENAME[7]={ +const char *FILENAME[8]={ "ParaEg1", "ParaEg2", "ParaEg3", "ParaMdset", "ParaMgroup", "ParaCompact", + "ParaIndividual", NULL}; -char filenames[7][PATH_MAX]; +char filenames[8][PATH_MAX]; hid_t fapl; /* file access property list */ #ifdef USE_PAUSE @@ -107,6 +110,7 @@ usage(void) printf("\t-n<n_groups>" "\tset number of groups for the multiple group test\n"); printf("\t-o\t\tno compact dataset test\n"); + printf("\t-i\t\tno independent read test\n"); printf("\t-v\t\tverbose on\n"); printf("\t-f <prefix>\tfilename prefix\n"); printf("\t-s\t\tuse Split-file together with MPIO\n"); @@ -157,6 +161,8 @@ parse_options(int argc, char **argv) break; case 'o': docompact = 0; break; + case 'i': doindependent = 0; + break; case 'v': verbose = 1; break; case 'f': if (--argc < 1) { @@ -392,6 +398,18 @@ int main(int argc, char **argv) else { MPI_BANNER("compact dataset test skipped"); } + + if (doindependent){ + MPI_BANNER("collective group and dataset write ..."); + collective_group_write(filenames[6], ngroups); + if (doread) { + MPI_BANNER("indepenent group and dataset read ..."); + independent_group_read(filenames[6], ngroups); + } + } + else{ + MPI_BANNER("Independent test skipped"); + } if (!(dowrite || doread || ndatasets || ngroups || docompact)){ usage(); diff --git a/testpar/testphdf5.h b/testpar/testphdf5.h index 57d6112..53ea52e 100644 --- a/testpar/testphdf5.h +++ b/testpar/testphdf5.h @@ -104,6 +104,8 @@ hid_t create_faccess_plist(MPI_Comm comm, MPI_Info info, int l_facc_type ); void multiple_dset_write(char *filename, int ndatasets); void multiple_group_write(char *filename, int ngroups); void multiple_group_read(char *filename, int ngroups); +void collective_group_write(char *filename, int ngroups); +void independent_group_read(char *filename, int ngroups); void test_split_comm_access(char *filename); void dataset_writeInd(char *filename); void dataset_writeAll(char *filename); |