From 64b3e25da59b61de15a61058a6758d4531b1ed49 Mon Sep 17 00:00:00 2001 From: q-posev Date: Tue, 19 Oct 2021 10:43:00 +0200 Subject: [PATCH] fix Python tests for basis_nucleus_index --- python/test/test_api.py | 18 +++++++++++------- python/test/test_pytrexio.py | 13 +++++++++++-- 2 files changed, 22 insertions(+), 9 deletions(-) diff --git a/python/test/test_api.py b/python/test/test_api.py index f6b151d..7dd9e0a 100644 --- a/python/test/test_api.py +++ b/python/test/test_api.py @@ -71,11 +71,15 @@ charges_np = np.array(charges, dtype=np.int32) # from the size of the list/array by SWIG using typemaps from numpy.i trexio.write_nucleus_charge(test_file, charges_np) +basis_num = 24 # initialize arrays of nuclear indices as a list and convert it to numpy array -indices = [i for i in range(nucleus_num)] +indices = [i for i in range(basis_num)] # type cast is important here because by default numpy transforms a list of integers into int64 array indices_np = np.array(indices, dtype=np.int64) +# first write basis_num because it is needed to check dimensions of basis_nucleus_index in TREXIO >= 2.0.0 +trexio.write_basis_num(test_file, basis_num) + # function call below works with both lists and numpy arrays, dimension needed for memory-safety is derived # from the size of the list/array by SWIG using typemacs from numpy.i trexio.write_basis_nucleus_index(test_file, indices_np) @@ -160,20 +164,20 @@ except trexio.Error: print("Unsafe call to safe API: checked") # safe call to read array of int values (nuclear indices) -rindices_np_16 = trexio.read_basis_nucleus_index(test_file2, dim=nucleus_num, dtype=np.int16) +rindices_np_16 = trexio.read_basis_nucleus_index(test_file2, dim=basis_num, dtype=np.int16) assert rindices_np_16.dtype is np.dtype(np.int16) -for i in range(nucleus_num): +for i in range(basis_num): assert rindices_np_16[i]==indices_np[i] -rindices_np_32 = trexio.read_basis_nucleus_index(test_file2, dim=nucleus_num, dtype=np.int32) +rindices_np_32 = trexio.read_basis_nucleus_index(test_file2, dim=basis_num, dtype=np.int32) assert rindices_np_32.dtype is np.dtype(np.int32) -for i in range(nucleus_num): +for i in range(basis_num): assert rindices_np_32[i]==indices_np[i] rindices_np_64 = trexio.read_basis_nucleus_index(test_file2) assert rindices_np_64.dtype is np.dtype(np.int64) -assert rindices_np_64.size==nucleus_num -for i in range(nucleus_num): +assert rindices_np_64.size==basis_num +for i in range(basis_num): assert rindices_np_64[i]==indices_np[i] # read nuclear coordinates without providing optional argument dim diff --git a/python/test/test_pytrexio.py b/python/test/test_pytrexio.py index 04b1266..04cdd55 100644 --- a/python/test/test_pytrexio.py +++ b/python/test/test_pytrexio.py @@ -59,11 +59,16 @@ assert rc==0 # charges[i] = 1. #rc = trexio_write_nucleus_charge(test_file, charges) +basis_num = 24 # initialize arrays of nuclear indices as a list and convert it to numpy array -indices = [i for i in range(nucleus_num)] +indices = [i for i in range(basis_num)] # type cast is important here because by default numpy transforms a list of integers into int64 array indices_np = np.array(indices, dtype=np.int32) +# first write basis_num because it is needed to check dimensions of basis_nucleus_index in TREXIO >= 2.0.0 +rc = trexio_write_basis_num(test_file, basis_num) +assert rc==0 + # function call below works with both lists and numpy arrays, dimension needed for memory-safety is derived # from the size of the list/array by SWIG using typemacs from numpy.i rc = trexio_write_safe_basis_nucleus_index(test_file, indices_np) @@ -124,8 +129,12 @@ assert rc==23 #for i in range(nucleus_num): # assert charges2[i]==charges[i] +result_basis = trexio_read_basis_num(test_file2) +assert result[0]==0 +assert result[1]==basis_num + # safe call to read_safe array of int values -rc, rindices_np = trexio_read_safe_basis_nucleus_index(test_file2, nucleus_num) +rc, rindices_np = trexio_read_safe_basis_nucleus_index(test_file2, basis_num) assert rc==0 assert rindices_np.dtype is np.dtype(np.int32) for i in range(nucleus_num):