mirror of
https://github.com/TREX-CoE/trexio.git
synced 2025-01-08 20:33:36 +01:00
Fix EOF detection for an arbitrary ranked dset
This commit is contained in:
parent
4904de5674
commit
722453688b
@ -544,11 +544,11 @@ trexio_hdf5_read_$group_dset$ (trexio_t* const file,
|
|||||||
trexio_exit_code rc_read;
|
trexio_exit_code rc_read;
|
||||||
|
|
||||||
// attempt to read indices
|
// attempt to read indices
|
||||||
rc_read = trexio_hdf5_open_read_dset_sparse(f->$group$_group, dset_index_name, offset_i, count_i, NULL, is_index, index_read);
|
rc_read = trexio_hdf5_open_read_dset_sparse(f->$group$_group, dset_index_name, $group_dset_rank$, offset_i, count_i, NULL, is_index, index_read);
|
||||||
if (rc_read != TREXIO_SUCCESS && rc_read != TREXIO_END) return rc_read;
|
if (rc_read != TREXIO_SUCCESS && rc_read != TREXIO_END) return rc_read;
|
||||||
// attempt to read values
|
// attempt to read values
|
||||||
// when EOF is encountered - the count_v[0] is modified and contains the number of elements being read
|
// when EOF is encountered - the count_v[0] is modified and contains the number of elements being read
|
||||||
rc_read = trexio_hdf5_open_read_dset_sparse(f->$group$_group, dset_value_name, offset_v, count_v, eof_read_size, is_value, value_read);
|
rc_read = trexio_hdf5_open_read_dset_sparse(f->$group$_group, dset_value_name, 1, offset_v, count_v, eof_read_size, is_value, value_read);
|
||||||
if (rc_read != TREXIO_SUCCESS && rc_read != TREXIO_END) return rc_read;
|
if (rc_read != TREXIO_SUCCESS && rc_read != TREXIO_END) return rc_read;
|
||||||
|
|
||||||
return rc_read;
|
return rc_read;
|
||||||
@ -1007,7 +1007,7 @@ trexio_exit_code trexio_hdf5_read_determinant_list(trexio_t* const file,
|
|||||||
|
|
||||||
/* Attempt to read determinants (if EOF -> eof_read_size is modified with the number of elements read and return code is TREXIO_END)
|
/* Attempt to read determinants (if EOF -> eof_read_size is modified with the number of elements read and return code is TREXIO_END)
|
||||||
0 argument below is requires to skip internal treatment specific to sparse indices (i.e. their de-compression).*/
|
0 argument below is requires to skip internal treatment specific to sparse indices (i.e. their de-compression).*/
|
||||||
return trexio_hdf5_open_read_dset_sparse(f->determinant_group, dset_det_name, offset, count, eof_read_size, 0, list);
|
return trexio_hdf5_open_read_dset_sparse(f->determinant_group, dset_det_name, (uint32_t) dims[1], offset, count, eof_read_size, 0, list);
|
||||||
}
|
}
|
||||||
#+end_src
|
#+end_src
|
||||||
|
|
||||||
@ -1037,15 +1037,15 @@ trexio_exit_code trexio_hdf5_write_determinant_list(trexio_t* const file,
|
|||||||
if ( H5LTfind_dataset(f->determinant_group, dset_det_name) != 1 ) {
|
if ( H5LTfind_dataset(f->determinant_group, dset_det_name) != 1 ) {
|
||||||
/* If the file does not exist -> create it and write */
|
/* If the file does not exist -> create it and write */
|
||||||
|
|
||||||
/* Create chunked dataset with index_dtype datatype and write indices into it */
|
/* Create chunked dataset with det_dtype datatype and write indices into it */
|
||||||
rc_write = trexio_hdf5_create_write_dset_sparse(f->determinant_group, dset_det_name, index_dtype, chunk_dims, list);
|
rc_write = trexio_hdf5_create_write_dset_sparse(f->determinant_group, dset_det_name, det_dtype, chunk_dims, list);
|
||||||
if (rc_write != TREXIO_SUCCESS) return rc_write;
|
if (rc_write != TREXIO_SUCCESS) return rc_write;
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
/* If the file exists -> open it and write */
|
/* If the file exists -> open it and write */
|
||||||
hsize_t offset_data[1] = {(hsize_t) offset_file * dims[1]};
|
hsize_t offset_data[1] = {(hsize_t) offset_file * dims[1]};
|
||||||
|
|
||||||
/* Create chunked dataset with index_dtype datatype and write indices into it */
|
/* Create chunked dataset with det_dtype datatype and write indices into it */
|
||||||
rc_write = trexio_hdf5_open_write_dset_sparse(f->determinant_group, dset_det_name, det_dtype, chunk_dims, offset_data, list);
|
rc_write = trexio_hdf5_open_write_dset_sparse(f->determinant_group, dset_det_name, det_dtype, chunk_dims, offset_data, list);
|
||||||
if (rc_write != TREXIO_SUCCESS) return rc_write;
|
if (rc_write != TREXIO_SUCCESS) return rc_write;
|
||||||
|
|
||||||
@ -1210,6 +1210,7 @@ trexio_hdf5_open_write_dset_sparse (const hid_t group_id,
|
|||||||
trexio_exit_code
|
trexio_exit_code
|
||||||
trexio_hdf5_open_read_dset_sparse (const hid_t group_id,
|
trexio_hdf5_open_read_dset_sparse (const hid_t group_id,
|
||||||
const char* dset_name,
|
const char* dset_name,
|
||||||
|
const uint32_t dset_rank,
|
||||||
const hsize_t* offset_file,
|
const hsize_t* offset_file,
|
||||||
hsize_t* const size_read,
|
hsize_t* const size_read,
|
||||||
int64_t* const eof_read_size,
|
int64_t* const eof_read_size,
|
||||||
@ -1248,9 +1249,9 @@ trexio_hdf5_open_read_dset_sparse (const hid_t group_id,
|
|||||||
if (max_offset > ddims[0]) {
|
if (max_offset > ddims[0]) {
|
||||||
is_EOF = 1;
|
is_EOF = 1;
|
||||||
// lower the value of count to reduce the number of elements which will be read
|
// lower the value of count to reduce the number of elements which will be read
|
||||||
size_read[0] -= max_offset - ddims[0];
|
size_read[0] -= (max_offset - ddims[0]);
|
||||||
// modified the value of eof_read_size passed by address
|
// modified the value of eof_read_size passed by address
|
||||||
if (eof_read_size != NULL) *eof_read_size = size_read[0];
|
if (eof_read_size != NULL) *eof_read_size = size_read[0]/dset_rank;
|
||||||
}
|
}
|
||||||
|
|
||||||
// special case when reading int indices
|
// special case when reading int indices
|
||||||
@ -1335,7 +1336,7 @@ trexio_hdf5_open_read_dset_sparse (const hid_t group_id,
|
|||||||
#+begin_src c :tangle suffix_hdf5.h
|
#+begin_src c :tangle suffix_hdf5.h
|
||||||
trexio_exit_code trexio_hdf5_create_write_dset_sparse (const hid_t group_id, const char* dset_name, const hid_t dtype_id, const hsize_t* chunk_dims, const void* data_sparse);
|
trexio_exit_code trexio_hdf5_create_write_dset_sparse (const hid_t group_id, const char* dset_name, const hid_t dtype_id, const hsize_t* chunk_dims, const void* data_sparse);
|
||||||
trexio_exit_code trexio_hdf5_open_write_dset_sparse (const hid_t group_id, const char* dset_name, const hid_t dtype_id, const hsize_t* chunk_dims, const hsize_t* offset_file, const void* data_sparse);
|
trexio_exit_code trexio_hdf5_open_write_dset_sparse (const hid_t group_id, const char* dset_name, const hid_t dtype_id, const hsize_t* chunk_dims, const hsize_t* offset_file, const void* data_sparse);
|
||||||
trexio_exit_code trexio_hdf5_open_read_dset_sparse (const hid_t group_id, const char* dset_name, const hsize_t* offset_file, hsize_t* const size_read, int64_t* const eof_read_size, const int is_index, void* const data_sparse);
|
trexio_exit_code trexio_hdf5_open_read_dset_sparse (const hid_t group_id, const char* dset_name, const uint32_t dset_rank, const hsize_t* offset_file, hsize_t* const size_read, int64_t* const eof_read_size, const int is_index, void* const data_sparse);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
#+end_src
|
#+end_src
|
||||||
|
@ -154,7 +154,7 @@ static int test_read_determinant (const char* file_name, const back_end_t backen
|
|||||||
assert(rc == TREXIO_END);
|
assert(rc == TREXIO_END);
|
||||||
assert(chunk_read == eof_read_size_check);
|
assert(chunk_read == eof_read_size_check);
|
||||||
assert(det_list_read[6*size_r-1] == 0);
|
assert(det_list_read[6*size_r-1] == 0);
|
||||||
assert(det_list_read[6*offset_data_read] == 497);
|
assert(det_list_read[6*offset_data_read] == 6 * (int64_t) (offset_file_read-offset));
|
||||||
|
|
||||||
// check the value of determinant_num
|
// check the value of determinant_num
|
||||||
int32_t det_num = 0;
|
int32_t det_num = 0;
|
||||||
@ -195,7 +195,7 @@ int main(){
|
|||||||
test_write_determinant (TREXIO_FILE, TEST_BACKEND, SIZE);
|
test_write_determinant (TREXIO_FILE, TEST_BACKEND, SIZE);
|
||||||
test_read_determinant (TREXIO_FILE, TEST_BACKEND, SIZE);
|
test_read_determinant (TREXIO_FILE, TEST_BACKEND, SIZE);
|
||||||
|
|
||||||
// rc = system(RM_COMMAND);
|
rc = system(RM_COMMAND);
|
||||||
assert (rc == 0);
|
assert (rc == 0);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
Loading…
Reference in New Issue
Block a user