#include "trexio.h" #include #include #include #include #define SIZE 100 #define N_CHUNKS 5 #define STATE_TEST 2 static int test_write_determinant (const char* file_name, const back_end_t backend, const int64_t offset, const int mo_num) { /* Try to write an array of sparse data into the TREXIO file */ trexio_t* file = NULL; trexio_exit_code rc; /*================= START OF TEST ==================*/ // open file in 'write' mode file = trexio_open(file_name, 'w', backend, &rc); assert (file != NULL); assert (rc == TREXIO_SUCCESS); // parameters to be written int64_t* det_list; double* det_coef; // write mo_num which will be used to determine the optimal size of int indices if (trexio_has_mo_num(file) == TREXIO_HAS_NOT) { rc = trexio_write_mo_num(file, mo_num); assert(rc == TREXIO_SUCCESS); } // write number of up and down electrons for checking consistency of determinants if (trexio_has_electron_up_num(file) == TREXIO_HAS_NOT) { rc = trexio_write_electron_up_num(file, 4); assert(rc == TREXIO_SUCCESS); } if (trexio_has_electron_dn_num(file) == TREXIO_HAS_NOT) { rc = trexio_write_electron_dn_num(file, 3); assert(rc == TREXIO_SUCCESS); } // get the number of int64 bit fields per determinant int int_num; rc = trexio_get_int64_num(file, &int_num); assert(rc == TREXIO_SUCCESS); assert(int_num == (mo_num-1)/64 + 1); // allocate memory and fill with values to be written det_list = (int64_t*) calloc(2 * int_num * SIZE, sizeof(int64_t)); det_coef = (double*) calloc(SIZE, sizeof(double)); int64_t size_list = TREXIO_NORB_PER_INT * int_num; const int32_t orb_list_up[4] = {0,1,2,3}; const int32_t orb_list_dn[3] = {0,1,2}; for(int i=0; i size_max) offset_file_read = 97L; offset_data_read = 1; int64_t eof_read_size_check = SIZE - offset_file_read; // if offset_file_read=97 => only 3 integrals will be read out of total of 100 if (offset != 0L) offset_file_read += offset; chunk_read = read_size_check; // read one chunk that will reach EOF and return TREXIO_END code rc = trexio_read_determinant_list(file, offset_file_read, &chunk_read, &det_list_read[2*int_num*offset_data_read]); /* printf("%s\n", trexio_string_of_error(rc)); for (int i=0; i