mirror of
https://github.com/TREX-CoE/trexio.git
synced 2024-12-23 12:56:53 +01:00
new read/write for numerical attributes
This commit is contained in:
parent
e88a228bb5
commit
3110a35562
@ -345,15 +345,17 @@ trexio_exit_code trexio_hdf5_read_nucleus_num(const trexio_t* file, uint64_t* nu
|
|||||||
assert (file != NULL);
|
assert (file != NULL);
|
||||||
assert (num != NULL);
|
assert (num != NULL);
|
||||||
|
|
||||||
h5nucleus_t* nucleus = trexio_hdf5_read_nucleus((trexio_hdf5_t*) file);
|
trexio_hdf5_t* f = (trexio_hdf5_t*) file;
|
||||||
|
/* Quit if the dimensioning attribute is missing in the file */
|
||||||
|
if (H5Aexists(f->nucleus_group, NUCLEUS_NUM_NAME) == 0) return TREXIO_FAILURE;
|
||||||
|
|
||||||
if (nucleus == NULL) {
|
/* Read the nucleus_num attribute of nucleus group */
|
||||||
return TREXIO_FAILURE;
|
hid_t num_id = H5Aopen(f->nucleus_group, NUCLEUS_NUM_NAME, H5P_DEFAULT);
|
||||||
}
|
if (num_id <= 0) return TREXIO_INVALID_ID;
|
||||||
|
|
||||||
/**/ *num = nucleus->num;
|
herr_t status = H5Aread(num_id, H5T_NATIVE_ULLONG, num);
|
||||||
|
if (status < 0) return TREXIO_FAILURE;
|
||||||
|
|
||||||
trexio_hdf5_free_nucleus(nucleus);
|
|
||||||
return TREXIO_SUCCESS;
|
return TREXIO_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -363,43 +365,55 @@ trexio_exit_code trexio_hdf5_write_nucleus_num(const trexio_t* file, const uint6
|
|||||||
assert (file != NULL);
|
assert (file != NULL);
|
||||||
assert (num > 0L);
|
assert (num > 0L);
|
||||||
|
|
||||||
h5nucleus_t* nucleus = trexio_hdf5_read_nucleus((trexio_hdf5_t*) file);
|
trexio_hdf5_t* f = (trexio_hdf5_t*) file;
|
||||||
|
hid_t num_id;
|
||||||
|
herr_t status;
|
||||||
|
/* Write the dimensioning variables */
|
||||||
|
hid_t dtype = H5Tcopy(H5T_NATIVE_ULLONG);
|
||||||
|
|
||||||
assert (nucleus != NULL);
|
if (H5Aexists(f->nucleus_group, NUCLEUS_NUM_NAME) == 0) {
|
||||||
|
|
||||||
if (nucleus->num != num) {
|
hid_t dspace = H5Screate(H5S_SCALAR);
|
||||||
|
|
||||||
if (nucleus->num != 0) {
|
num_id = H5Acreate(f->nucleus_group, NUCLEUS_NUM_NAME, dtype, dspace,
|
||||||
printf("%ld -> %ld %s \n", num, nucleus->num,
|
H5P_DEFAULT, H5P_DEFAULT);
|
||||||
"This variable already exists. Overwriting it is not supported");
|
assert (num_id > 0);
|
||||||
trexio_hdf5_free_nucleus(nucleus);
|
|
||||||
return TREXIO_FAILURE;
|
|
||||||
}
|
|
||||||
|
|
||||||
nucleus->num = num;
|
status = H5Awrite(num_id, dtype, &(num));
|
||||||
|
assert (status >= 0);
|
||||||
|
|
||||||
if (nucleus->charge != NULL) free(nucleus->charge);
|
H5Sclose(dspace);
|
||||||
nucleus->charge = NULL;
|
|
||||||
|
|
||||||
nucleus->charge = (double*) calloc(num, sizeof(double));
|
|
||||||
assert (nucleus->charge != NULL);
|
|
||||||
|
|
||||||
if (nucleus->coord != NULL) free(nucleus->coord );
|
|
||||||
nucleus->coord = NULL;
|
|
||||||
|
|
||||||
nucleus->coord = (double*) calloc(3*num, sizeof(double));
|
|
||||||
assert (nucleus->coord != NULL);
|
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
nucleus->num = num;
|
|
||||||
|
uint64_t nucleus_num;
|
||||||
|
trexio_exit_code rc = trexio_hdf5_read_nucleus_num(file, &(nucleus_num));
|
||||||
|
if (rc != TREXIO_SUCCESS) return rc;
|
||||||
|
|
||||||
|
if (nucleus_num != num) {
|
||||||
|
|
||||||
|
if (nucleus_num != 0) {
|
||||||
|
printf("%ld -> %ld %s \n", num, nucleus_num,
|
||||||
|
"This variable already exists. Overwriting it is not supported");
|
||||||
|
H5Tclose(dtype);
|
||||||
|
return TREXIO_FAILURE;
|
||||||
|
|
||||||
|
} else {
|
||||||
|
|
||||||
|
num_id = H5Aopen(f->nucleus_group, NUCLEUS_NUM_NAME, H5P_DEFAULT);
|
||||||
|
assert (num_id > 0);
|
||||||
|
|
||||||
|
status = H5Awrite(num_id, dtype, &(num));
|
||||||
|
assert (status >= 0);
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
trexio_exit_code rc = trexio_hdf5_write_nucleus((trexio_hdf5_t*) file, nucleus);
|
H5Aclose(num_id);
|
||||||
assert (rc == TREXIO_SUCCESS);
|
H5Tclose(dtype);
|
||||||
|
|
||||||
trexio_hdf5_free_nucleus(nucleus);
|
|
||||||
|
|
||||||
return TREXIO_SUCCESS;
|
return TREXIO_SUCCESS;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
trexio_exit_code trexio_hdf5_read_nucleus_coord(const trexio_t* file, double* coord, const uint32_t rank, const uint64_t* dims) {
|
trexio_exit_code trexio_hdf5_read_nucleus_coord(const trexio_t* file, double* coord, const uint32_t rank, const uint64_t* dims) {
|
||||||
|
@ -496,15 +496,17 @@ trexio_exit_code trexio_hdf5_read_nucleus_num(const trexio_t* file, uint64_t* nu
|
|||||||
assert (file != NULL);
|
assert (file != NULL);
|
||||||
assert (num != NULL);
|
assert (num != NULL);
|
||||||
|
|
||||||
h5nucleus_t* nucleus = trexio_hdf5_read_nucleus((trexio_hdf5_t*) file);
|
trexio_hdf5_t* f = (trexio_hdf5_t*) file;
|
||||||
|
/* Quit if the dimensioning attribute is missing in the file */
|
||||||
|
if (H5Aexists(f->nucleus_group, NUCLEUS_NUM_NAME) == 0) return TREXIO_FAILURE;
|
||||||
|
|
||||||
if (nucleus == NULL) {
|
/* Read the nucleus_num attribute of nucleus group */
|
||||||
return TREXIO_FAILURE;
|
hid_t num_id = H5Aopen(f->nucleus_group, NUCLEUS_NUM_NAME, H5P_DEFAULT);
|
||||||
}
|
if (num_id <= 0) return TREXIO_INVALID_ID;
|
||||||
|
|
||||||
/**/ *num = nucleus->num;
|
herr_t status = H5Aread(num_id, H5T_NATIVE_ULLONG, num);
|
||||||
|
if (status < 0) return TREXIO_FAILURE;
|
||||||
|
|
||||||
trexio_hdf5_free_nucleus(nucleus);
|
|
||||||
return TREXIO_SUCCESS;
|
return TREXIO_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -514,47 +516,57 @@ trexio_exit_code trexio_hdf5_write_nucleus_num(const trexio_t* file, const uint6
|
|||||||
assert (file != NULL);
|
assert (file != NULL);
|
||||||
assert (num > 0L);
|
assert (num > 0L);
|
||||||
|
|
||||||
h5nucleus_t* nucleus = trexio_hdf5_read_nucleus((trexio_hdf5_t*) file);
|
trexio_hdf5_t* f = (trexio_hdf5_t*) file;
|
||||||
|
hid_t num_id;
|
||||||
|
herr_t status;
|
||||||
|
/* Write the dimensioning variables */
|
||||||
|
hid_t dtype = H5Tcopy(H5T_NATIVE_ULLONG);
|
||||||
|
|
||||||
assert (nucleus != NULL);
|
if (H5Aexists(f->nucleus_group, NUCLEUS_NUM_NAME) == 0) {
|
||||||
|
|
||||||
if (nucleus->num != num) {
|
hid_t dspace = H5Screate(H5S_SCALAR);
|
||||||
|
|
||||||
if (nucleus->num != 0) {
|
num_id = H5Acreate(f->nucleus_group, NUCLEUS_NUM_NAME, dtype, dspace,
|
||||||
printf("%ld -> %ld %s \n", num, nucleus->num,
|
H5P_DEFAULT, H5P_DEFAULT);
|
||||||
"This variable already exists. Overwriting it is not supported");
|
assert (num_id > 0);
|
||||||
trexio_hdf5_free_nucleus(nucleus);
|
|
||||||
return TREXIO_FAILURE;
|
|
||||||
}
|
|
||||||
|
|
||||||
nucleus->num = num;
|
status = H5Awrite(num_id, dtype, &(num));
|
||||||
|
assert (status >= 0);
|
||||||
|
|
||||||
if (nucleus->charge != NULL) free(nucleus->charge);
|
H5Sclose(dspace);
|
||||||
nucleus->charge = NULL;
|
|
||||||
|
|
||||||
nucleus->charge = (double*) calloc(num, sizeof(double));
|
|
||||||
assert (nucleus->charge != NULL);
|
|
||||||
|
|
||||||
if (nucleus->coord != NULL) free(nucleus->coord );
|
|
||||||
nucleus->coord = NULL;
|
|
||||||
|
|
||||||
nucleus->coord = (double*) calloc(3*num, sizeof(double));
|
|
||||||
assert (nucleus->coord != NULL);
|
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
nucleus->num = num;
|
|
||||||
|
uint64_t nucleus_num;
|
||||||
|
trexio_exit_code rc = trexio_hdf5_read_nucleus_num(file, &(nucleus_num));
|
||||||
|
if (rc != TREXIO_SUCCESS) return rc;
|
||||||
|
|
||||||
|
if (nucleus_num != num) {
|
||||||
|
|
||||||
|
if (nucleus_num != 0) {
|
||||||
|
printf("%ld -> %ld %s \n", num, nucleus_num,
|
||||||
|
"This variable already exists. Overwriting it is not supported");
|
||||||
|
H5Tclose(dtype);
|
||||||
|
return TREXIO_FAILURE;
|
||||||
|
|
||||||
|
} else {
|
||||||
|
|
||||||
|
num_id = H5Aopen(f->nucleus_group, NUCLEUS_NUM_NAME, H5P_DEFAULT);
|
||||||
|
assert (num_id > 0);
|
||||||
|
|
||||||
|
status = H5Awrite(num_id, dtype, &(num));
|
||||||
|
assert (status >= 0);
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
trexio_exit_code rc = trexio_hdf5_write_nucleus((trexio_hdf5_t*) file, nucleus);
|
H5Aclose(num_id);
|
||||||
assert (rc == TREXIO_SUCCESS);
|
H5Tclose(dtype);
|
||||||
|
|
||||||
trexio_hdf5_free_nucleus(nucleus);
|
|
||||||
|
|
||||||
return TREXIO_SUCCESS;
|
return TREXIO_SUCCESS;
|
||||||
|
|
||||||
}
|
}
|
||||||
#+end_src
|
#+end_src
|
||||||
|
|
||||||
|
|
||||||
** Read/Write the coord attribute
|
** Read/Write the coord attribute
|
||||||
|
|
||||||
The ~coord~ array is assumed allocated with the appropriate size.
|
The ~coord~ array is assumed allocated with the appropriate size.
|
||||||
|
Loading…
Reference in New Issue
Block a user