diff options
author | Binh-Minh Ribler <bmribler@hdfgroup.org> | 2018-07-24 04:41:56 (GMT) |
---|---|---|
committer | Binh-Minh Ribler <bmribler@hdfgroup.org> | 2018-07-24 04:41:56 (GMT) |
commit | 98308480f6fbb97d9a273334db714c4c967fd6c9 (patch) | |
tree | c4c4ad86525962217a3cd25508b2c6f3c489b89f /c++/test/dsets.cpp | |
parent | 243a36911fb80931225e0044cc654ccbfec3ed10 (diff) | |
parent | 3c6a39858fef9e7207cd7c3e3057267ec380be0b (diff) | |
download | hdf5-98308480f6fbb97d9a273334db714c4c967fd6c9.zip hdf5-98308480f6fbb97d9a273334db714c4c967fd6c9.tar.gz hdf5-98308480f6fbb97d9a273334db714c4c967fd6c9.tar.bz2 |
Merge pull request #1146 in HDFFV/hdf5 from ~BMRIBLER/hdf5_bmr_cpp4:develop to develop
Code improvement
New class for dataset access property list
* commit '3c6a39858fef9e7207cd7c3e3057267ec380be0b':
Fixed typos
Entered entries for HDFFV-10150, HDFFV-10458, HDFFV-1047
Updated for C2Cppfunction_map.htm
Added class DSetAccPropList Description: - Added class DSetAccPropList for the dataset access property list. - Added wrapper for H5Dget_access_plist to class DataSet // Gets the access property list of this dataset. DSetAccPropList getAccessPlist() const;
Code improvement Description: Moved the new H5Object::getInfo member functions to H5Location and made them overloaded with the existing H5Location::getObjinfo. This way is cleaner than the previous approach. Platforms tested: Linux/64 (jelly) Linux/32 (jam) Darwin (osx1010test)
Diffstat (limited to 'c++/test/dsets.cpp')
-rw-r--r-- | c++/test/dsets.cpp | 127 |
1 files changed, 119 insertions, 8 deletions
diff --git a/c++/test/dsets.cpp b/c++/test/dsets.cpp index e86052b..14f1bd4 100644 --- a/c++/test/dsets.cpp +++ b/c++/test/dsets.cpp @@ -1116,12 +1116,11 @@ static herr_t test_types(H5File& file) /*------------------------------------------------------------------------- - * Function: test_getinfo + * Function: test_getObjinfo * - * Purpose Tests getInfo() + * Purpose Tests getObjinfo() * * Return Success: 0 - * * Failure: -1 * * July, 2018 @@ -1145,16 +1144,16 @@ static herr_t test_getinfo(H5File& file) // Get dataset header info H5O_info_t oinfo; HDmemset(&oinfo, 0, sizeof(oinfo)); - dataset.getInfo(oinfo, H5O_INFO_HDR); - verify_val(oinfo.hdr.nchunks, 1, "DataSet::getInfo", __LINE__, __FILE__); + dataset.getObjinfo(oinfo, H5O_INFO_HDR); + verify_val(oinfo.hdr.nchunks, 1, "DataSet::getObjinfo", __LINE__, __FILE__); dataset.close(); // Open the dataset we created above and then close it. This is one // way to open an existing dataset for accessing. dataset = file.openDataSet(DSET_DEFAULT_NAME); HDmemset(&oinfo, 0, sizeof(oinfo)); - dataset.getInfo(oinfo, H5O_INFO_ALL); - verify_val(oinfo.hdr.nchunks, 1, "DataSet::getInfo", __LINE__, __FILE__); + dataset.getObjinfo(oinfo, H5O_INFO_ALL); + verify_val(oinfo.hdr.nchunks, 1, "DataSet::getObjinfo", __LINE__, __FILE__); dataset.close(); PASSED(); @@ -1177,13 +1176,124 @@ static herr_t test_getinfo(H5File& file) /*------------------------------------------------------------------------- + * Function: test_chunk_cache + * + * Purpose Tests setting rdcc info on a DAPL, and interaction + * with the corresponding properties in the file structure. + * + * Return Success: 0 + * Failure: number of errors + * + * July 2018 + *------------------------------------------------------------------------- + */ +const int RANK1 = 1; +const H5std_string FILE_ACCPLIST("test_accplist.h5"); + +static herr_t test_chunk_cache(FileAccPropList fapl) +{ + SUBTEST("DSetAccPropList::set/getChunkCache"); + + try { + // Create a default dataset access and file access property lists + FileAccPropList fapl_def; + DSetAccPropList dapl; + + // Verify that chunk cache parameters are the same + int mdc_nelmts = 0; + size_t nslots_1 = 0, nslots_4 = 0, nbytes_1 = 0, nbytes_4 = 0; + double w0_1 = 0.0F, w0_4 = 0.0F; + fapl_def.getCache(mdc_nelmts, nslots_1, nbytes_1, w0_1); + dapl.getChunkCache(nslots_4, nbytes_4, w0_4); + verify_val(nslots_1, nslots_4, "DSetAccPropList::getChunkCache", __LINE__, __FILE__); + verify_val(nbytes_1, nbytes_4, "DSetAccPropList::getChunkCache", __LINE__, __FILE__); + verify_val(w0_1, w0_4, "DSetAccPropList::getChunkCache", __LINE__, __FILE__); + + // Set a link access property on dapl to verify property list inheritance + dapl.setNumLinks((size_t)134); + size_t nlinks = dapl.getNumLinks(); + verify_val(nlinks, (size_t)134, "DSetAccPropList::getNumLinks", __LINE__, __FILE__); + + // Make a copy of the external fapl + FileAccPropList fapl_local(fapl); + + // Set new rdcc settings on fapl local + size_t nslots_2 = nslots_1 * 2; + size_t nbytes_2 = nbytes_1 * 2; + double w0_2 = w0_1 / (double)2.0F; + fapl_local.getCache(mdc_nelmts, nslots_2, nbytes_2, w0_2); + + // Create a new file using default fcpl and the passed-in fapl + H5File file(FILE_ACCPLIST, H5F_ACC_TRUNC, FileCreatPropList::DEFAULT, fapl_local); + + // Create dataset creation property list + DSetCreatPropList dcpl; + + // Set chunk dimensions + hsize_t cdims[RANK1]; + cdims[0] = 10; + dcpl.setChunk(RANK1, cdims); + + // Create memory space + hsize_t mdims[RANK1]; + mdims[0] = 10; + DataSpace mspace(RANK1, mdims); + + // Create a dataset using that dataset creation properties + DataSet dataset(file.createDataSet(DSET_CHUNKED_NAME, PredType::NATIVE_INT, mspace, dcpl, dapl)); + + // Get the dataset access property list + DSetAccPropList dapl2 = dataset.getAccessPlist(); + + // Retrieve and verify the raw data chunk cache parameters + nslots_4 = nbytes_4 = 0; + w0_4 = 0.0F; + dapl2.getChunkCache(nslots_4, nbytes_4, w0_4); + verify_val(nslots_2, nslots_4, "DSetCreatPropList::getChunkCache", __LINE__, __FILE__); + verify_val(nbytes_2, nbytes_4, "DSetCreatPropList::getChunkCache", __LINE__, __FILE__); + verify_val(H5_DBL_ABS_EQUAL(w0_2, w0_4), 1, "DSetCreatPropList::getChunkCache", __LINE__, __FILE__); + + + // Set new values on original dapl + size_t nslots_3 = nslots_1 * 2; + size_t nbytes_3 = H5D_CHUNK_CACHE_NBYTES_DEFAULT; + double w0_3 = w0_2 / 2; + dapl.getChunkCache(nslots_3, nbytes_3, w0_3); + + // Close dataset + dataset.close(); + + // Reopen dataset + DataSet dataset2(file.openDataSet(DSET_CHUNKED_NAME, dapl)); + + // Get the dataset access property list + DSetAccPropList dapl3 = dataset2.getAccessPlist(); + + // Retrieve and verify the raw data chunk cache parameters + dapl3.getChunkCache(nslots_4, nbytes_4, w0_4); + verify_val(nslots_3, nslots_4, "DSetCreatPropList::getLayout", __LINE__, __FILE__); + verify_val(nbytes_3, nbytes_4, "DSetCreatPropList::getLayout", __LINE__, __FILE__); + verify_val(H5_DBL_ABS_EQUAL(w0_3, w0_4), 1, "DSetCreatPropList::getLayout", __LINE__, __FILE__); + + + PASSED(); + return 0; + } // end top try block + + catch (Exception& E) + { + return -1; + } +} // test_chunk_cache + + +/*------------------------------------------------------------------------- * Function: test_virtual * * Purpose Tests fixed, unlimited, and printf selections in the same * VDS * * Return Success: 0 - * * Failure: number of errors * * Programmer Binh-Minh Ribler @@ -1305,6 +1415,7 @@ void test_dset() nerrors += test_multiopen (file) < 0 ? 1:0; nerrors += test_types(file) < 0 ? 1:0; nerrors += test_virtual() < 0 ? 1:0; + nerrors += test_chunk_cache(fapl) < 0 ? 1:0; // Close group "emit diagnostics". grp.close(); |