mirror of
https://github.com/TREX-CoE/trexio.git
synced 2025-01-03 01:56:13 +01:00
Build and test Python API without HDF5 back end
This commit is contained in:
parent
d1ada666c6
commit
326686e44c
25
Makefile.am
25
Makefile.am
@ -37,7 +37,7 @@ CLEANFILES = trexio.mod
|
|||||||
if HAVE_FORTRAN
|
if HAVE_FORTRAN
|
||||||
BUILT_SOURCES = trexio.mod
|
BUILT_SOURCES = trexio.mod
|
||||||
else
|
else
|
||||||
BUILT_SOURCES =
|
BUILT_SOURCES =
|
||||||
endif
|
endif
|
||||||
EXTRA_DIST = .git_hash
|
EXTRA_DIST = .git_hash
|
||||||
|
|
||||||
@ -261,10 +261,18 @@ pytrexio_i = $(srcdir)/src/pytrexio.i
|
|||||||
numpy_i = $(srcdir)/src/numpy.i
|
numpy_i = $(srcdir)/src/numpy.i
|
||||||
|
|
||||||
|
|
||||||
|
if HAVE_HDF5
|
||||||
|
python-test: $(TEST_PY)
|
||||||
|
python3 -m pytest -v --all $(TEST_PY)
|
||||||
|
$(RM) -r -- __pycache__
|
||||||
|
$(RM) -f -- test_file_py.h5 unsafe_test_file_py.h5
|
||||||
|
$(RM) -rf -- test_file_py.dir unsafe_test_file_py.dir
|
||||||
|
else
|
||||||
python-test: $(TEST_PY)
|
python-test: $(TEST_PY)
|
||||||
python3 -m pytest -v $(TEST_PY)
|
python3 -m pytest -v $(TEST_PY)
|
||||||
$(RM) -r -- __pycache__
|
$(RM) -r -- __pycache__
|
||||||
$(RM) -f -- test_file_py.h5 unsafe_test_file_py.h5
|
$(RM) -rf -- test_file_py.dir unsafe_test_file_py.dir
|
||||||
|
endif
|
||||||
|
|
||||||
python-install: $(pytrexio_py) $(setup_py) $(setup_cfg)
|
python-install: $(pytrexio_py) $(setup_py) $(setup_cfg)
|
||||||
cd python && \
|
cd python && \
|
||||||
@ -274,11 +282,15 @@ python-sdist: $(pytrexio_py) $(setup_py) $(setup_cfg)
|
|||||||
cd python && \
|
cd python && \
|
||||||
python3 -m build --sdist
|
python3 -m build --sdist
|
||||||
|
|
||||||
|
if HAVE_HDF5
|
||||||
$(pytrexio_py): $(pytrexio_c)
|
$(pytrexio_py): $(pytrexio_c)
|
||||||
cd tools && ./prepare_python.sh
|
cd tools && ./prepare_python.sh
|
||||||
|
else
|
||||||
|
$(pytrexio_py): $(pytrexio_c)
|
||||||
|
cd tools && ./prepare_python.sh --without-hdf5
|
||||||
|
endif
|
||||||
|
|
||||||
# Build Python module and C wrapper code for TREXIO using SWIG
|
# Build Python module and C wrapper code for TREXIO using SWIG
|
||||||
# [?] swig -python -threads pytrexio.i ----> Add thread support for all the interface
|
|
||||||
$(pytrexio_c): $(ORG_FILES) $(GENERATOR_FILES) $(trexio_h) $(pytrexio_i) $(numpy_i)
|
$(pytrexio_c): $(ORG_FILES) $(GENERATOR_FILES) $(trexio_h) $(pytrexio_i) $(numpy_i)
|
||||||
@if [[ $(SWIG).x != ".x" ]] ; then \
|
@if [[ $(SWIG).x != ".x" ]] ; then \
|
||||||
cp $(trexio_h) src/ ; \
|
cp $(trexio_h) src/ ; \
|
||||||
@ -307,7 +319,7 @@ DEB_FILES = \
|
|||||||
helpers-debian/libtrexio0.install \
|
helpers-debian/libtrexio0.install \
|
||||||
helpers-debian/libtrexio-dev.install \
|
helpers-debian/libtrexio-dev.install \
|
||||||
helpers-debian/source \
|
helpers-debian/source \
|
||||||
helpers-debian/README.source
|
helpers-debian/README.source
|
||||||
|
|
||||||
debian_from_dist: $(DEB_FILES) $(SOURCES) $(trexio_h)
|
debian_from_dist: $(DEB_FILES) $(SOURCES) $(trexio_h)
|
||||||
cp ../trexio-$(PACKAGE_VERSION).tar.gz ../libtrexio_$(PACKAGE_VERSION).orig.tar.gz
|
cp ../trexio-$(PACKAGE_VERSION).tar.gz ../libtrexio_$(PACKAGE_VERSION).orig.tar.gz
|
||||||
@ -317,6 +329,9 @@ debian_from_dist: $(DEB_FILES) $(SOURCES) $(trexio_h)
|
|||||||
CLEANFILES += $(pytrexio_c) \
|
CLEANFILES += $(pytrexio_c) \
|
||||||
$(pytrexio_py) \
|
$(pytrexio_py) \
|
||||||
$(trexio_py) \
|
$(trexio_py) \
|
||||||
|
$(srcdir)/src/trexio.py \
|
||||||
|
$(srcdir)/src/pytrexio.py \
|
||||||
|
$(srcdir)/src/trexio.h \
|
||||||
python/src/*.c \
|
python/src/*.c \
|
||||||
python/src/*.h
|
python/src/*.h
|
||||||
|
|
||||||
|
@ -40,7 +40,7 @@ if numpy_isUndefined and not do_sdist:
|
|||||||
|
|
||||||
rootpath = os.path.dirname(os.path.abspath(__file__))
|
rootpath = os.path.dirname(os.path.abspath(__file__))
|
||||||
srcpath = os.path.join(rootpath, 'src')
|
srcpath = os.path.join(rootpath, 'src')
|
||||||
c_files = ['trexio.c', 'trexio_hdf5.c', 'trexio_text.c', 'pytrexio_wrap.c']
|
c_files = ['trexio.c', 'trexio_text.c']
|
||||||
|
|
||||||
|
|
||||||
with open("README.md", "r") as fh:
|
with open("README.md", "r") as fh:
|
||||||
@ -61,12 +61,15 @@ if not version_r:
|
|||||||
# The block below is needed to derive additional flags related to the HDF5 library,
|
# The block below is needed to derive additional flags related to the HDF5 library,
|
||||||
# which is required to build pytrexio extension module during the setup.py execution
|
# which is required to build pytrexio extension module during the setup.py execution
|
||||||
|
|
||||||
|
h5_present = False
|
||||||
h5_ldflags_withl = os.environ.get("H5_LDFLAGS", None)
|
h5_ldflags_withl = os.environ.get("H5_LDFLAGS", None)
|
||||||
h5_cflags_withI = os.environ.get("H5_CFLAGS", None)
|
h5_cflags_withI = os.environ.get("H5_CFLAGS", None)
|
||||||
|
|
||||||
h5_ldflags_isUndefined = h5_ldflags_withl is None or h5_ldflags_withl==""
|
h5_ldflags_isUndefined = h5_ldflags_withl is None or h5_ldflags_withl==""
|
||||||
h5_cflags_isUndefined = h5_cflags_withI is None or h5_cflags_withI==""
|
h5_cflags_isUndefined = h5_cflags_withI is None or h5_cflags_withI==""
|
||||||
|
|
||||||
|
h5_present = (not h5_ldflags_isUndefined) & (not h5_cflags_isUndefined)
|
||||||
|
|
||||||
if (h5_ldflags_isUndefined or h5_cflags_isUndefined) and not do_sdist:
|
if (h5_ldflags_isUndefined or h5_cflags_isUndefined) and not do_sdist:
|
||||||
|
|
||||||
try:
|
try:
|
||||||
@ -76,20 +79,26 @@ if (h5_ldflags_isUndefined or h5_cflags_isUndefined) and not do_sdist:
|
|||||||
|
|
||||||
try:
|
try:
|
||||||
assert pk.exists('hdf5')
|
assert pk.exists('hdf5')
|
||||||
|
h5_present = True
|
||||||
except AssertionError:
|
except AssertionError:
|
||||||
raise Exception("pkg-config could not locate HDF5")
|
print("pkg-config could not locate HDF5; installing TREXIO with TEXT back-end only!")
|
||||||
|
|
||||||
h5_cflags_withI = pk.cflags('hdf5')
|
if h5_present:
|
||||||
h5_ldflags_withl = pk.libs('hdf5')
|
h5_cflags_withI = pk.cflags('hdf5')
|
||||||
|
h5_ldflags_withl = pk.libs('hdf5')
|
||||||
|
|
||||||
|
if h5_present:
|
||||||
h5_cflags = h5_cflags_withI.replace("-I","").split(" ")[0] if not do_sdist else ""
|
h5_cflags = h5_cflags_withI.replace("-I","").split(" ")[0] if not do_sdist else ""
|
||||||
h5_ldflags = h5_ldflags_withl.split(" ")[0] if not do_sdist else ""
|
h5_ldflags = h5_ldflags_withl.split(" ")[0] if not do_sdist else ""
|
||||||
|
c_files.append('trexio_hdf5.c')
|
||||||
|
|
||||||
# ============================ End of the HDF5 block ============================ #
|
# ============================ End of the HDF5 block ============================ #
|
||||||
|
|
||||||
# Define pytrexio extension module based on TREXIO source codes + SWIG-generated wrapper
|
# Define pytrexio extension module based on TREXIO source codes + SWIG-generated wrapper
|
||||||
pytrexio_module = Extension('pytrexio._pytrexio',
|
c_files.append('pytrexio_wrap.c')
|
||||||
|
|
||||||
|
if h5_present:
|
||||||
|
pytrexio_module = Extension('pytrexio._pytrexio',
|
||||||
sources = [os.path.join(srcpath, code) for code in c_files],
|
sources = [os.path.join(srcpath, code) for code in c_files],
|
||||||
include_dirs = [h5_cflags, srcpath, numpy_includedir],
|
include_dirs = [h5_cflags, srcpath, numpy_includedir],
|
||||||
libraries = ['hdf5' ],
|
libraries = ['hdf5' ],
|
||||||
@ -101,6 +110,17 @@ pytrexio_module = Extension('pytrexio._pytrexio',
|
|||||||
],
|
],
|
||||||
extra_link_args = [h5_ldflags]
|
extra_link_args = [h5_ldflags]
|
||||||
)
|
)
|
||||||
|
else:
|
||||||
|
pytrexio_module = Extension('pytrexio._pytrexio',
|
||||||
|
sources = [os.path.join(srcpath, code) for code in c_files],
|
||||||
|
include_dirs = [srcpath, numpy_includedir],
|
||||||
|
extra_compile_args = [
|
||||||
|
'-std=c99',
|
||||||
|
'-Wno-discarded-qualifiers',
|
||||||
|
'-Wno-unused-variable',
|
||||||
|
'-Wno-unused-but-set-variable'
|
||||||
|
]
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
setup(name = 'trexio',
|
setup(name = 'trexio',
|
||||||
|
@ -6,19 +6,22 @@ import trexio
|
|||||||
from benzene_data import *
|
from benzene_data import *
|
||||||
|
|
||||||
|
|
||||||
FILENAME = 'test_file_py.h5'
|
def clean(back_end, filename):
|
||||||
BACK_END = trexio.TREXIO_HDF5
|
|
||||||
|
|
||||||
|
|
||||||
def clean():
|
|
||||||
"""Remove test files."""
|
"""Remove test files."""
|
||||||
import os
|
if back_end == trexio.TREXIO_HDF5:
|
||||||
|
import os
|
||||||
try:
|
try:
|
||||||
os.remove(FILENAME)
|
os.remove(filename)
|
||||||
os.remove('unsafe_' + FILENAME)
|
os.remove('unsafe_' + filename)
|
||||||
except FileNotFoundError:
|
except FileNotFoundError:
|
||||||
pass
|
pass
|
||||||
|
else:
|
||||||
|
import shutil
|
||||||
|
try:
|
||||||
|
shutil.rmtree(filename)
|
||||||
|
shutil.rmtree('unsafe_' + filename)
|
||||||
|
except FileNotFoundError:
|
||||||
|
pass
|
||||||
|
|
||||||
|
|
||||||
def test_info():
|
def test_info():
|
||||||
@ -29,7 +32,7 @@ def test_info():
|
|||||||
def test_void():
|
def test_void():
|
||||||
"""Check raise of an error upon I/O on non-existing file."""
|
"""Check raise of an error upon I/O on non-existing file."""
|
||||||
with pytest.raises(trexio.Error):
|
with pytest.raises(trexio.Error):
|
||||||
_ = trexio.File('void.file', 'r', BACK_END)
|
_ = trexio.File('void.file', 'r', trexio.TREXIO_TEXT)
|
||||||
|
|
||||||
|
|
||||||
def test_orbital_list():
|
def test_orbital_list():
|
||||||
@ -53,20 +56,30 @@ def test_bitfield_list():
|
|||||||
class TestIO:
|
class TestIO:
|
||||||
"""Unit tests for writing/reading different blocks of the TREXIO file."""
|
"""Unit tests for writing/reading different blocks of the TREXIO file."""
|
||||||
|
|
||||||
filename = FILENAME
|
@pytest.fixture(autouse=True)
|
||||||
back_end = BACK_END
|
def setup(self, backend):
|
||||||
mode = 'w'
|
self.mode = 'w'
|
||||||
test_file = None
|
self.test_file = None
|
||||||
|
if backend == 'hdf5':
|
||||||
clean()
|
self.back_end = trexio.TREXIO_HDF5
|
||||||
|
self.filename = 'test_file_py.h5'
|
||||||
|
elif backend == 'text':
|
||||||
|
self.back_end = trexio.TREXIO_TEXT
|
||||||
|
self.filename = 'test_file_py.dir'
|
||||||
|
else:
|
||||||
|
raise ValueError("Wrong TREXIO back-end supplied to pytest.")
|
||||||
|
|
||||||
|
|
||||||
def __del__(self):
|
def test_clean(self):
|
||||||
if self.test_file:
|
"""Clean existing files."""
|
||||||
if self.test_file.isOpen:
|
clean(self.back_end, self.filename)
|
||||||
self.test_file.close()
|
|
||||||
|
|
||||||
|
|
||||||
|
#def __del__(self):
|
||||||
|
# """Class destructor."""
|
||||||
|
# if self.test_file:
|
||||||
|
# if self.test_file.isOpen:
|
||||||
|
# self.test_file.close()
|
||||||
def open(self, filename=None, mode=None, back_end=None):
|
def open(self, filename=None, mode=None, back_end=None):
|
||||||
"""Create a TREXIO file and open it for writing."""
|
"""Create a TREXIO file and open it for writing."""
|
||||||
if not filename:
|
if not filename:
|
||||||
@ -107,12 +120,17 @@ class TestIO:
|
|||||||
with pytest.raises(trexio.Error):
|
with pytest.raises(trexio.Error):
|
||||||
trexio.write_nucleus_num(self.test_file, nucleus_num * 2)
|
trexio.write_nucleus_num(self.test_file, nucleus_num * 2)
|
||||||
|
|
||||||
|
if self.test_file.isOpen:
|
||||||
|
self.test_file.close()
|
||||||
|
|
||||||
|
|
||||||
def test_num(self):
|
def test_num(self):
|
||||||
"""Write a number."""
|
"""Write a number."""
|
||||||
self.open()
|
self.open()
|
||||||
trexio.write_nucleus_num(self.test_file, nucleus_num)
|
trexio.write_nucleus_num(self.test_file, nucleus_num)
|
||||||
assert trexio.has_nucleus_num(self.test_file)
|
assert trexio.has_nucleus_num(self.test_file)
|
||||||
|
if self.test_file.isOpen:
|
||||||
|
self.test_file.close()
|
||||||
|
|
||||||
|
|
||||||
def test_str(self):
|
def test_str(self):
|
||||||
@ -120,6 +138,8 @@ class TestIO:
|
|||||||
self.open()
|
self.open()
|
||||||
trexio.write_nucleus_point_group(self.test_file, point_group)
|
trexio.write_nucleus_point_group(self.test_file, point_group)
|
||||||
assert trexio.has_nucleus_point_group(self.test_file)
|
assert trexio.has_nucleus_point_group(self.test_file)
|
||||||
|
if self.test_file.isOpen:
|
||||||
|
self.test_file.close()
|
||||||
|
|
||||||
|
|
||||||
def test_array_str(self):
|
def test_array_str(self):
|
||||||
@ -129,6 +149,8 @@ class TestIO:
|
|||||||
self.test_num()
|
self.test_num()
|
||||||
trexio.write_nucleus_label(self.test_file, nucleus_label)
|
trexio.write_nucleus_label(self.test_file, nucleus_label)
|
||||||
assert trexio.has_nucleus_label(self.test_file)
|
assert trexio.has_nucleus_label(self.test_file)
|
||||||
|
if self.test_file.isOpen:
|
||||||
|
self.test_file.close()
|
||||||
|
|
||||||
|
|
||||||
def test_array_1D(self):
|
def test_array_1D(self):
|
||||||
@ -138,6 +160,8 @@ class TestIO:
|
|||||||
self.test_num()
|
self.test_num()
|
||||||
trexio.write_nucleus_charge(self.test_file, nucleus_charge)
|
trexio.write_nucleus_charge(self.test_file, nucleus_charge)
|
||||||
assert trexio.has_nucleus_charge(self.test_file)
|
assert trexio.has_nucleus_charge(self.test_file)
|
||||||
|
if self.test_file.isOpen:
|
||||||
|
self.test_file.close()
|
||||||
|
|
||||||
|
|
||||||
def test_array_2D(self):
|
def test_array_2D(self):
|
||||||
@ -147,6 +171,8 @@ class TestIO:
|
|||||||
self.test_num()
|
self.test_num()
|
||||||
trexio.write_nucleus_coord(self.test_file, nucleus_coord)
|
trexio.write_nucleus_coord(self.test_file, nucleus_coord)
|
||||||
assert trexio.has_nucleus_coord(self.test_file)
|
assert trexio.has_nucleus_coord(self.test_file)
|
||||||
|
if self.test_file.isOpen:
|
||||||
|
self.test_file.close()
|
||||||
|
|
||||||
|
|
||||||
def test_indices(self):
|
def test_indices(self):
|
||||||
@ -159,6 +185,8 @@ class TestIO:
|
|||||||
# now write the indices
|
# now write the indices
|
||||||
trexio.write_basis_nucleus_index(self.test_file, indices_np)
|
trexio.write_basis_nucleus_index(self.test_file, indices_np)
|
||||||
assert trexio.has_basis_nucleus_index(self.test_file)
|
assert trexio.has_basis_nucleus_index(self.test_file)
|
||||||
|
if self.test_file.isOpen:
|
||||||
|
self.test_file.close()
|
||||||
|
|
||||||
|
|
||||||
def test_sparse(self):
|
def test_sparse(self):
|
||||||
@ -170,6 +198,8 @@ class TestIO:
|
|||||||
offset = 0
|
offset = 0
|
||||||
trexio.write_ao_2e_int_eri(self.test_file, offset, num_integrals, indices, values)
|
trexio.write_ao_2e_int_eri(self.test_file, offset, num_integrals, indices, values)
|
||||||
assert trexio.has_ao_2e_int_eri(self.test_file)
|
assert trexio.has_ao_2e_int_eri(self.test_file)
|
||||||
|
if self.test_file.isOpen:
|
||||||
|
self.test_file.close()
|
||||||
|
|
||||||
|
|
||||||
def test_determinant(self):
|
def test_determinant(self):
|
||||||
@ -189,31 +219,39 @@ class TestIO:
|
|||||||
assert trexio.has_determinant_coefficient(self.test_file)
|
assert trexio.has_determinant_coefficient(self.test_file)
|
||||||
# manually check the consistency between coefficient_size and number of determinants
|
# manually check the consistency between coefficient_size and number of determinants
|
||||||
assert trexio.read_determinant_coefficient_size(self.test_file) == trexio.read_determinant_num(self.test_file)
|
assert trexio.read_determinant_coefficient_size(self.test_file) == trexio.read_determinant_num(self.test_file)
|
||||||
|
if self.test_file.isOpen:
|
||||||
|
self.test_file.close()
|
||||||
|
|
||||||
|
|
||||||
def test_delete_group(self):
|
def test_delete_group(self):
|
||||||
"""Delete a group."""
|
"""Delete a group."""
|
||||||
self.open(filename='unsafe_' + self.filename, mode='u', back_end=self.back_end)
|
self.open(filename='unsafe_' + self.filename, mode='u', back_end=self.back_end)
|
||||||
|
|
||||||
self.test_num()
|
trexio.write_nucleus_num(self.test_file, nucleus_num)
|
||||||
self.test_array_1D()
|
trexio.write_nucleus_charge(self.test_file, nucleus_charge)
|
||||||
self.test_array_2D()
|
trexio.flush(self.test_file)
|
||||||
|
|
||||||
|
assert trexio.has_nucleus_num(self.test_file)
|
||||||
|
assert trexio.has_nucleus_charge(self.test_file)
|
||||||
assert trexio.has_nucleus(self.test_file)
|
assert trexio.has_nucleus(self.test_file)
|
||||||
|
|
||||||
trexio.delete_nucleus(self.test_file)
|
trexio.delete_nucleus(self.test_file)
|
||||||
|
|
||||||
assert not trexio.has_nucleus_num(self.test_file)
|
assert not trexio.has_nucleus_num(self.test_file)
|
||||||
assert not trexio.has_nucleus_charge(self.test_file)
|
assert not trexio.has_nucleus_charge(self.test_file)
|
||||||
assert not trexio.has_nucleus_coord(self.test_file)
|
|
||||||
assert not trexio.has_nucleus(self.test_file)
|
assert not trexio.has_nucleus(self.test_file)
|
||||||
|
|
||||||
|
if self.test_file.isOpen:
|
||||||
|
self.test_file.close()
|
||||||
|
|
||||||
|
|
||||||
def test_has_group(self):
|
def test_has_group(self):
|
||||||
"""Check existense of a group."""
|
"""Check existense of a group."""
|
||||||
self.open()
|
self.open()
|
||||||
assert trexio.has_nucleus(self.test_file)
|
assert trexio.has_nucleus(self.test_file)
|
||||||
assert not trexio.has_rdm(self.test_file)
|
assert not trexio.has_rdm(self.test_file)
|
||||||
|
if self.test_file.isOpen:
|
||||||
|
self.test_file.close()
|
||||||
|
|
||||||
|
|
||||||
def test_context_manager(self):
|
def test_context_manager(self):
|
||||||
@ -231,6 +269,8 @@ class TestIO:
|
|||||||
self.open(mode='r')
|
self.open(mode='r')
|
||||||
num_r = trexio.read_nucleus_num(self.test_file)
|
num_r = trexio.read_nucleus_num(self.test_file)
|
||||||
assert num_r == nucleus_num
|
assert num_r == nucleus_num
|
||||||
|
if self.test_file.isOpen:
|
||||||
|
self.test_file.close()
|
||||||
|
|
||||||
|
|
||||||
def test_read_array_1D(self):
|
def test_read_array_1D(self):
|
||||||
@ -240,6 +280,8 @@ class TestIO:
|
|||||||
assert charges_np_r.dtype is np.dtype(np.float64)
|
assert charges_np_r.dtype is np.dtype(np.float64)
|
||||||
assert charges_np_r.size == nucleus_num
|
assert charges_np_r.size == nucleus_num
|
||||||
np.testing.assert_array_almost_equal(charges_np_r, np.array(nucleus_charge), decimal=8)
|
np.testing.assert_array_almost_equal(charges_np_r, np.array(nucleus_charge), decimal=8)
|
||||||
|
if self.test_file.isOpen:
|
||||||
|
self.test_file.close()
|
||||||
|
|
||||||
|
|
||||||
def test_read_array_2D(self):
|
def test_read_array_2D(self):
|
||||||
@ -250,6 +292,8 @@ class TestIO:
|
|||||||
assert coords_np.dtype is np.dtype(np.float64)
|
assert coords_np.dtype is np.dtype(np.float64)
|
||||||
assert coords_np.size == nucleus_num * 3
|
assert coords_np.size == nucleus_num * 3
|
||||||
np.testing.assert_array_almost_equal(coords_np, np.array(nucleus_coord).reshape(nucleus_num,3), decimal=8)
|
np.testing.assert_array_almost_equal(coords_np, np.array(nucleus_coord).reshape(nucleus_num,3), decimal=8)
|
||||||
|
if self.test_file.isOpen:
|
||||||
|
self.test_file.close()
|
||||||
|
|
||||||
|
|
||||||
def test_read_errors(self):
|
def test_read_errors(self):
|
||||||
@ -258,6 +302,8 @@ class TestIO:
|
|||||||
# unsafe call to read_safe should fail with error message corresponding to TREXIO_UNSAFE_ARRAY_DIM
|
# unsafe call to read_safe should fail with error message corresponding to TREXIO_UNSAFE_ARRAY_DIM
|
||||||
with pytest.raises(trexio.Error):
|
with pytest.raises(trexio.Error):
|
||||||
_ = trexio.read_nucleus_charge(self.test_file, dim=nucleus_num/2)
|
_ = trexio.read_nucleus_charge(self.test_file, dim=nucleus_num/2)
|
||||||
|
if self.test_file.isOpen:
|
||||||
|
self.test_file.close()
|
||||||
|
|
||||||
|
|
||||||
def test_read_integers(self):
|
def test_read_integers(self):
|
||||||
@ -276,7 +322,8 @@ class TestIO:
|
|||||||
assert indices_np_64.dtype is np.dtype(np.int64)
|
assert indices_np_64.dtype is np.dtype(np.int64)
|
||||||
assert indices_np_64.size == basis_shell_num
|
assert indices_np_64.size == basis_shell_num
|
||||||
assert (indices_np_64 == np.array(nucleus_index)).all()
|
assert (indices_np_64 == np.array(nucleus_index)).all()
|
||||||
|
if self.test_file.isOpen:
|
||||||
|
self.test_file.close()
|
||||||
|
|
||||||
def test_sparse_read(self):
|
def test_sparse_read(self):
|
||||||
"""Read a sparse array."""
|
"""Read a sparse array."""
|
||||||
@ -300,7 +347,8 @@ class TestIO:
|
|||||||
assert read_buf_size == (num_integrals - buf_size)
|
assert read_buf_size == (num_integrals - buf_size)
|
||||||
assert indices_sparse_np[0][0] == offset_file * 4
|
assert indices_sparse_np[0][0] == offset_file * 4
|
||||||
assert indices_sparse_np[read_buf_size-1][3] == (offset_file + read_buf_size) * 4 - 1
|
assert indices_sparse_np[read_buf_size-1][3] == (offset_file + read_buf_size) * 4 - 1
|
||||||
|
if self.test_file.isOpen:
|
||||||
|
self.test_file.close()
|
||||||
|
|
||||||
def test_determinant_read(self):
|
def test_determinant_read(self):
|
||||||
"""Read the CI determinants."""
|
"""Read the CI determinants."""
|
||||||
@ -320,7 +368,8 @@ class TestIO:
|
|||||||
#print(f'First complete read of determinant coefficients: {read_buf_size}')
|
#print(f'First complete read of determinant coefficients: {read_buf_size}')
|
||||||
assert not eof
|
assert not eof
|
||||||
assert read_buf_size == buf_size
|
assert read_buf_size == buf_size
|
||||||
|
if self.test_file.isOpen:
|
||||||
|
self.test_file.close()
|
||||||
|
|
||||||
def test_array_str_read(self):
|
def test_array_str_read(self):
|
||||||
"""Read an array of strings."""
|
"""Read an array of strings."""
|
||||||
@ -328,6 +377,8 @@ class TestIO:
|
|||||||
labels_r = trexio.read_nucleus_label(self.test_file)
|
labels_r = trexio.read_nucleus_label(self.test_file)
|
||||||
assert len(labels_r) == nucleus_num
|
assert len(labels_r) == nucleus_num
|
||||||
assert labels_r == nucleus_label
|
assert labels_r == nucleus_label
|
||||||
|
if self.test_file.isOpen:
|
||||||
|
self.test_file.close()
|
||||||
|
|
||||||
|
|
||||||
def test_str_read(self):
|
def test_str_read(self):
|
||||||
@ -335,3 +386,5 @@ class TestIO:
|
|||||||
self.open(mode='r')
|
self.open(mode='r')
|
||||||
point_group_r = trexio.read_nucleus_point_group(self.test_file)
|
point_group_r = trexio.read_nucleus_point_group(self.test_file)
|
||||||
assert point_group_r == point_group
|
assert point_group_r == point_group
|
||||||
|
if self.test_file.isOpen:
|
||||||
|
self.test_file.close()
|
||||||
|
@ -1,11 +1,22 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
|
# We want the script to crash on the 1st error:
|
||||||
|
set -e
|
||||||
|
|
||||||
# Check that script is executed from tools directory
|
# Check that script is executed from tools directory
|
||||||
if [[ $(basename $PWD) != "tools" ]] ; then
|
if [[ $(basename $PWD) != "tools" ]] ; then
|
||||||
echo "This script should run in the tools directory"
|
echo "This script should run in the tools directory"
|
||||||
exit -1
|
exit -1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
DO_HDF5=0
|
||||||
|
if [[ -z ${1} ]] && [[ "${1}" == "--without-hdf5" ]] ; then
|
||||||
|
echo "Compiling Python API without the HDF5 back end."
|
||||||
|
DO_HDF5=1
|
||||||
|
else
|
||||||
|
echo "Compiling Python API with the HDF5 back end."
|
||||||
|
fi
|
||||||
|
|
||||||
TREXIO_ROOT=$(dirname "${PWD}../")
|
TREXIO_ROOT=$(dirname "${PWD}../")
|
||||||
|
|
||||||
# First define readonly global variables.
|
# First define readonly global variables.
|
||||||
@ -14,9 +25,7 @@ readonly INCLUDIR=${TREXIO_ROOT}/include
|
|||||||
readonly TOOLS=${TREXIO_ROOT}/tools
|
readonly TOOLS=${TREXIO_ROOT}/tools
|
||||||
readonly PYDIR=${TREXIO_ROOT}/python
|
readonly PYDIR=${TREXIO_ROOT}/python
|
||||||
readonly PYTREXIODIR=${PYDIR}/pytrexio
|
readonly PYTREXIODIR=${PYDIR}/pytrexio
|
||||||
|
readonly PYDIR_TREXIO_H=${PYDIR}/src/trexio.h
|
||||||
# We want the script to crash on the 1st error:
|
|
||||||
set -e
|
|
||||||
|
|
||||||
# Create src and trexio directories in the python folder if not yet done
|
# Create src and trexio directories in the python folder if not yet done
|
||||||
mkdir -p ${PYDIR}/src
|
mkdir -p ${PYDIR}/src
|
||||||
@ -25,22 +34,37 @@ mkdir -p ${PYTREXIODIR}
|
|||||||
# Copy all the source code and header files in the corresponding python directory
|
# Copy all the source code and header files in the corresponding python directory
|
||||||
cp ${SRC}/pytrexio.py ${PYTREXIODIR}/pytrexio.py
|
cp ${SRC}/pytrexio.py ${PYTREXIODIR}/pytrexio.py
|
||||||
cp ${SRC}/trexio.py ${PYDIR}/trexio.py
|
cp ${SRC}/trexio.py ${PYDIR}/trexio.py
|
||||||
cp ${SRC}/*.c ${PYDIR}/src
|
cp ${SRC}/trexio.c ${SRC}/trexio_s.h ${SRC}/trexio_private.h ${PYDIR}/src
|
||||||
cp ${SRC}/*.h ${PYDIR}/src
|
cp ${SRC}/trexio_text.{c,h} ${PYDIR}/src
|
||||||
cp ${INCLUDIR}/trexio.h ${PYDIR}/src
|
cp ${SRC}/pytrexio_wrap.c ${PYDIR}/src/pytrexio_wrap.c
|
||||||
|
cp ${INCLUDIR}/trexio.h ${PYDIR}/src
|
||||||
|
cp ${INCLUDIR}/config.h ${PYDIR}/src
|
||||||
|
|
||||||
# fix needed to define HAVE_HDF5 symbol so that Python extension is always compiled with HDF5 (without including config.h)
|
# fix needed for HAVE_HDF5 symbol so that Python extension can be compiled without config.h
|
||||||
# add "#define HAVE_HDF5 1" line after "#include stdint.h" using awk and sed
|
export LINE_NO=$(($(awk '/stdint.h/{print NR}' ${PYDIR_TREXIO_H}) + 1))
|
||||||
export LINE_NO=$(($(awk '/stdint.h/{print NR}' ${PYDIR}/src/trexio.h) + 1))
|
|
||||||
# sed on MacOS is different from GNU sed on Linux and requires special treatment
|
if [[ ${DO_HDF5} == 0 ]] ; then
|
||||||
if [[ "$OSTYPE" == "darwin"* ]]; then
|
cp ${SRC}/trexio_hdf5.{c,h} ${PYDIR}/src
|
||||||
sed -i '' -e "$LINE_NO"'i \
|
# add "#define HAVE_HDF5 1" line after "#include stdint.h" using awk and sed
|
||||||
#define HAVE_HDF5 1' "${PYDIR}/src/trexio.h"
|
# sed on MacOS is different from GNU sed on Linux and requires special treatment
|
||||||
else
|
# if [[ "$OSTYPE" == "darwin"* ]]; then
|
||||||
sed -i -e "$LINE_NO"'i \
|
# sed -i '' -e "$LINE_NO"'i \
|
||||||
#define HAVE_HDF5 1' "${PYDIR}/src/trexio.h"
|
# #define HAVE_HDF5 1' "${PYDIR_TREXIO_H}"
|
||||||
|
# else
|
||||||
|
# sed -i -e "$LINE_NO"'i \
|
||||||
|
# #define HAVE_HDF5 1' "${PYDIR_TREXIO_H}"
|
||||||
|
# fi
|
||||||
|
#else
|
||||||
|
# add "#undef HAVE_HDF5" line after "#include stdint.h" using awk and sed
|
||||||
|
# sed on MacOS is different from GNU sed on Linux and requires special treatment
|
||||||
|
# if [[ "$OSTYPE" == "darwin"* ]]; then
|
||||||
|
# sed -i '' -e "$LINE_NO"'i \
|
||||||
|
# #undef HAVE_HDF5' "${PYDIR_TREXIO_H}"
|
||||||
|
# else
|
||||||
|
# sed -i -e "$LINE_NO"'i \
|
||||||
|
# #undef HAVE_HDF5' "${PYDIR_TREXIO_H}"
|
||||||
|
# fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Copy additional info
|
# Copy additional info
|
||||||
cp ${TREXIO_ROOT}/AUTHORS ${TREXIO_ROOT}/LICENSE ${PYDIR}
|
cp ${TREXIO_ROOT}/AUTHORS ${TREXIO_ROOT}/LICENSE ${PYDIR}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user