2021-03-22 16:40:45 +01:00
|
|
|
program test_trexio
|
2021-06-04 18:14:45 +02:00
|
|
|
use trexio
|
2021-11-02 11:06:03 +01:00
|
|
|
use, intrinsic :: iso_c_binding
|
2021-06-04 18:14:45 +02:00
|
|
|
implicit none
|
2021-12-01 13:35:42 +01:00
|
|
|
|
2022-01-20 14:22:32 +01:00
|
|
|
integer :: rc
|
2021-11-02 11:06:03 +01:00
|
|
|
logical :: have_hdf5
|
2021-03-22 16:40:45 +01:00
|
|
|
|
2022-07-12 17:21:53 +02:00
|
|
|
print'(a)' , "============================================"
|
2021-12-01 13:35:42 +01:00
|
|
|
print'(a,a)' , " TREXIO VERSION STRING : ", TREXIO_PACKAGE_VERSION
|
2021-10-08 13:55:56 +02:00
|
|
|
print'(a,i3)', " TREXIO MAJOR VERSION : ", TREXIO_VERSION_MAJOR
|
|
|
|
print'(a,i3)', " TREXIO MINOR VERSION : ", TREXIO_VERSION_MINOR
|
2022-07-12 17:21:53 +02:00
|
|
|
print'(a)' , "============================================"
|
2021-10-08 13:55:56 +02:00
|
|
|
|
2022-01-20 14:22:32 +01:00
|
|
|
rc = trexio_info()
|
|
|
|
|
2022-09-30 12:22:24 +02:00
|
|
|
call system('rm -f -- test_write_f.dir/*.txt test_write_f.dir/*.txt.size test_write_f.dir/.lock && rm -fd -- test_write_f.dir')
|
2021-06-08 14:39:04 +02:00
|
|
|
print *, 'call test_write(''test_write_f.dir'', TREXIO_TEXT)'
|
|
|
|
call test_write('test_write_f.dir', TREXIO_TEXT)
|
|
|
|
print *, 'call test_read(''test_write_f.dir'', TREXIO_TEXT)'
|
|
|
|
call test_read('test_write_f.dir', TREXIO_TEXT)
|
2022-09-30 12:22:24 +02:00
|
|
|
call system('rm -f -- test_write_f.dir/*.txt test_write_f.dir/*.txt.size test_write_f.dir/.lock && rm -fd -- test_write_f.dir')
|
2021-06-04 18:14:45 +02:00
|
|
|
|
2021-09-22 14:50:22 +02:00
|
|
|
call test_read_void('test_write_f.dir', TREXIO_TEXT)
|
|
|
|
|
2021-12-01 13:35:42 +01:00
|
|
|
! No way to conditionally check whether compilation was done with HDF5
|
2021-11-01 11:57:03 +01:00
|
|
|
! So temporarily disable the test for HDF5 back end at the moment
|
2021-11-02 11:06:03 +01:00
|
|
|
have_hdf5 = trexio_has_backend(TREXIO_HDF5)
|
|
|
|
if (have_hdf5) then
|
|
|
|
call system('rm -f -- test_write_f.h5')
|
|
|
|
print *, 'call test_write(''test_write_f.h5'', TREXIO_HDF5)'
|
|
|
|
call test_write('test_write_f.h5', TREXIO_HDF5)
|
|
|
|
print *, 'call test_read(''test_write_f.h5'', TREXIO_HDF5)'
|
|
|
|
call test_read('test_write_f.h5', TREXIO_HDF5)
|
|
|
|
call system('rm -f -- test_write_f.h5')
|
2021-12-01 13:35:42 +01:00
|
|
|
|
2021-11-02 11:06:03 +01:00
|
|
|
call test_read_void('test_write_f.h5', TREXIO_HDF5)
|
|
|
|
endif
|
2021-03-24 11:14:47 +01:00
|
|
|
|
|
|
|
end program test_trexio
|
2021-03-22 16:40:45 +01:00
|
|
|
|
2021-06-04 18:14:45 +02:00
|
|
|
subroutine test_write(file_name, back_end)
|
2021-03-30 14:20:46 +02:00
|
|
|
|
|
|
|
! ============ Test write functionality =============== !
|
2021-04-01 22:48:04 +02:00
|
|
|
|
2021-03-24 11:14:47 +01:00
|
|
|
use trexio
|
2021-06-03 13:42:56 +02:00
|
|
|
use, intrinsic :: iso_c_binding
|
2021-06-01 14:59:08 +02:00
|
|
|
|
2021-03-22 16:40:45 +01:00
|
|
|
implicit none
|
|
|
|
|
2021-06-04 18:14:45 +02:00
|
|
|
character*(*), intent(in) :: file_name
|
2021-06-07 11:17:02 +02:00
|
|
|
integer, intent(in) :: back_end
|
2021-06-04 18:14:45 +02:00
|
|
|
|
2022-03-07 12:48:13 +01:00
|
|
|
integer(trexio_t) :: trex_file
|
2021-03-22 16:40:45 +01:00
|
|
|
|
2022-03-07 12:48:13 +01:00
|
|
|
integer(trexio_exit_code) :: rc = 1
|
2021-06-07 11:01:37 +02:00
|
|
|
|
2022-04-12 16:36:04 +02:00
|
|
|
integer :: nucleus_num, mo_num, ao_num, basis_shell_num
|
2021-03-23 16:34:13 +01:00
|
|
|
|
2021-10-19 10:22:08 +02:00
|
|
|
integer :: basis_nucleus_index(24)
|
2021-03-24 16:06:04 +01:00
|
|
|
double precision :: charge(12)
|
2021-04-20 01:34:11 +02:00
|
|
|
double precision :: coord(3,12)
|
2021-03-24 11:14:47 +01:00
|
|
|
|
2021-06-04 15:36:56 +02:00
|
|
|
character(len=:), allocatable :: sym_str
|
2021-06-15 10:20:01 +02:00
|
|
|
character(len=:), allocatable :: label(:)
|
2022-07-04 14:35:24 +02:00
|
|
|
double precision, allocatable :: energy(:)
|
|
|
|
integer , allocatable :: spin(:)
|
2021-06-01 14:59:08 +02:00
|
|
|
|
2021-12-01 13:35:42 +01:00
|
|
|
! sparse data
|
2022-04-12 16:36:04 +02:00
|
|
|
integer(4) :: index_sparse_ao_2e_int_eri(4,100)
|
|
|
|
double precision :: value_sparse_ao_2e_int_eri(100)
|
2021-12-01 13:35:42 +01:00
|
|
|
|
2022-04-12 16:36:04 +02:00
|
|
|
! determinants
|
|
|
|
integer*8 :: det_list(6, 50)
|
|
|
|
integer*8 :: det_num
|
2022-04-29 12:17:38 +02:00
|
|
|
integer :: int_num
|
2021-12-01 13:35:42 +01:00
|
|
|
|
2022-04-12 16:36:04 +02:00
|
|
|
integer :: i, j, n_buffers = 5
|
|
|
|
integer(8) :: buf_size_sparse, buf_size_det, offset
|
|
|
|
|
|
|
|
buf_size_sparse = 100/n_buffers
|
|
|
|
buf_size_det = 50/n_buffers
|
|
|
|
|
|
|
|
! fill sparse indices and values
|
2021-12-01 13:35:42 +01:00
|
|
|
do i = 1, 100
|
2022-04-12 16:36:04 +02:00
|
|
|
index_sparse_ao_2e_int_eri(1,i) = 4*i - 3
|
|
|
|
index_sparse_ao_2e_int_eri(2,i) = 4*i+1 - 3
|
|
|
|
index_sparse_ao_2e_int_eri(3,i) = 4*i+2 - 3
|
|
|
|
index_sparse_ao_2e_int_eri(4,i) = 4*i+3 - 3
|
|
|
|
value_sparse_ao_2e_int_eri(i) = 3.14 + float(i)
|
|
|
|
enddo
|
2022-04-22 13:18:29 +02:00
|
|
|
|
2022-04-12 16:36:04 +02:00
|
|
|
! fill determinant list
|
|
|
|
do i = 1, 50
|
|
|
|
do j = 1, 6
|
|
|
|
det_list(j,i) = 6*i+(j-1) - 5
|
|
|
|
enddo
|
2021-12-01 13:35:42 +01:00
|
|
|
enddo
|
|
|
|
|
2021-03-30 14:20:46 +02:00
|
|
|
! parameters to be written
|
2022-04-12 16:36:04 +02:00
|
|
|
nucleus_num = 12
|
2021-04-20 01:34:11 +02:00
|
|
|
charge = (/ 6., 6., 6., 6., 6., 6., 1., 1., 1., 1., 1., 1. /)
|
|
|
|
coord = reshape( (/ 0.00000000d0, 1.39250319d0 , 0.00000000d0 , &
|
|
|
|
-1.20594314d0, 0.69625160d0 , 0.00000000d0 , &
|
|
|
|
-1.20594314d0, -0.69625160d0 , 0.00000000d0 , &
|
|
|
|
0.00000000d0, -1.39250319d0 , 0.00000000d0 , &
|
|
|
|
1.20594314d0, -0.69625160d0 , 0.00000000d0 , &
|
|
|
|
1.20594314d0, 0.69625160d0 , 0.00000000d0 , &
|
|
|
|
-2.14171677d0, 1.23652075d0 , 0.00000000d0 , &
|
|
|
|
-2.14171677d0, -1.23652075d0 , 0.00000000d0 , &
|
|
|
|
0.00000000d0, -2.47304151d0 , 0.00000000d0 , &
|
|
|
|
2.14171677d0, -1.23652075d0 , 0.00000000d0 , &
|
|
|
|
2.14171677d0, 1.23652075d0 , 0.00000000d0 , &
|
|
|
|
0.00000000d0, 2.47304151d0 , 0.00000000d0 /), &
|
|
|
|
shape(coord) )
|
2021-03-30 14:20:46 +02:00
|
|
|
|
2022-04-12 16:36:04 +02:00
|
|
|
! the first dimension of det_list (6) corresponds to mo_num=150; adapt the former if the latter is changed
|
|
|
|
mo_num = 150
|
|
|
|
ao_num = 1000
|
|
|
|
|
2021-10-21 15:52:12 +02:00
|
|
|
basis_shell_num = 24
|
2021-10-19 10:22:08 +02:00
|
|
|
basis_nucleus_index = (/ 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24 /)
|
2021-06-10 01:49:43 +02:00
|
|
|
|
2021-06-08 16:13:11 +02:00
|
|
|
label = [character(len=8) :: 'C', 'Na','C', 'C 66', 'C','C', 'H 99', 'Ru', 'H', 'H', 'H', 'H' ]
|
2021-06-01 14:59:08 +02:00
|
|
|
|
2021-06-15 11:26:03 +02:00
|
|
|
sym_str = 'B3U with some comments'
|
2021-06-01 14:59:08 +02:00
|
|
|
|
2021-03-30 14:20:46 +02:00
|
|
|
! ================= START OF TEST ===================== !
|
2021-03-23 18:12:53 +01:00
|
|
|
|
2022-01-19 14:08:38 +01:00
|
|
|
rc = trexio_inquire(file_name)
|
|
|
|
call trexio_assert(rc, TREXIO_FAILURE)
|
|
|
|
|
2021-09-22 14:50:22 +02:00
|
|
|
trex_file = trexio_open(file_name, 'w', back_end, rc)
|
|
|
|
call trexio_assert(rc, TREXIO_SUCCESS)
|
2021-03-30 11:56:04 +02:00
|
|
|
|
|
|
|
rc = trexio_has_nucleus_num(trex_file)
|
2021-06-14 11:54:10 +02:00
|
|
|
call trexio_assert(rc, TREXIO_HAS_NOT, 'SUCCESS HAS NOT 1')
|
2021-06-04 18:14:45 +02:00
|
|
|
|
2021-03-30 11:56:04 +02:00
|
|
|
rc = trexio_has_nucleus_charge(trex_file)
|
2021-06-14 11:54:10 +02:00
|
|
|
call trexio_assert(rc, TREXIO_HAS_NOT, 'SUCCESS HAS NOT 2')
|
2021-03-22 16:40:45 +01:00
|
|
|
|
2022-04-12 16:36:04 +02:00
|
|
|
rc = trexio_has_ao_2e_int_eri(trex_file)
|
2021-12-01 13:35:42 +01:00
|
|
|
call trexio_assert(rc, TREXIO_HAS_NOT, 'SUCCESS HAS NOT 3')
|
|
|
|
|
2022-04-12 16:36:04 +02:00
|
|
|
rc = trexio_has_determinant_list(trex_file)
|
|
|
|
call trexio_assert(rc, TREXIO_HAS_NOT, 'SUCCESS HAS NOT 4')
|
|
|
|
|
2022-07-04 11:23:47 +02:00
|
|
|
rc = trexio_has_nucleus(trex_file)
|
|
|
|
call trexio_assert(rc, TREXIO_HAS_NOT, 'SUCCESS HAS NOT 5')
|
|
|
|
|
|
|
|
rc = trexio_has_ao_2e_int(trex_file)
|
|
|
|
call trexio_assert(rc, TREXIO_HAS_NOT, 'SUCCESS HAS NOT 6')
|
|
|
|
|
2022-04-12 16:36:04 +02:00
|
|
|
rc = trexio_write_nucleus_num(trex_file, nucleus_num)
|
2021-06-14 11:54:10 +02:00
|
|
|
call trexio_assert(rc, TREXIO_SUCCESS, 'SUCCESS WRITE NUM')
|
2021-04-01 22:48:04 +02:00
|
|
|
|
2021-03-24 16:06:04 +01:00
|
|
|
rc = trexio_write_nucleus_charge(trex_file, charge)
|
2021-06-14 11:54:10 +02:00
|
|
|
call trexio_assert(rc, TREXIO_SUCCESS, 'SUCCESS WRITE CHARGE')
|
2021-03-23 16:34:13 +01:00
|
|
|
|
2021-03-24 16:06:04 +01:00
|
|
|
rc = trexio_write_nucleus_coord(trex_file, coord)
|
2021-06-14 11:54:10 +02:00
|
|
|
call trexio_assert(rc, TREXIO_SUCCESS, 'SUCCESS WRITE COORD')
|
2021-03-23 16:34:13 +01:00
|
|
|
|
2021-06-15 10:20:01 +02:00
|
|
|
rc = trexio_write_nucleus_label(trex_file, label, 5)
|
2021-06-15 11:26:03 +02:00
|
|
|
deallocate(label)
|
2021-12-10 11:34:37 +01:00
|
|
|
call trexio_assert(rc, TREXIO_SUCCESS, 'SUCCESS WRITE LABEL')
|
2021-06-01 14:59:08 +02:00
|
|
|
|
2021-06-14 11:54:10 +02:00
|
|
|
rc = trexio_write_nucleus_point_group(trex_file, sym_str, 32)
|
2021-06-04 15:36:56 +02:00
|
|
|
deallocate(sym_str)
|
2021-06-14 11:54:10 +02:00
|
|
|
call trexio_assert(rc, TREXIO_SUCCESS, 'SUCCESS WRITE POINT GROUP')
|
2021-06-04 15:36:56 +02:00
|
|
|
|
2021-10-21 15:52:12 +02:00
|
|
|
rc = trexio_write_basis_shell_num(trex_file, basis_shell_num)
|
2021-10-19 10:22:08 +02:00
|
|
|
call trexio_assert(rc, TREXIO_SUCCESS, 'SUCCESS WRITE BASIS NUM')
|
2021-03-30 11:56:04 +02:00
|
|
|
|
2021-06-15 11:49:42 +02:00
|
|
|
rc = trexio_write_basis_nucleus_index(trex_file, basis_nucleus_index)
|
|
|
|
call trexio_assert(rc, TREXIO_SUCCESS, 'SUCCESS WRITE INDEX')
|
2021-03-24 11:14:47 +01:00
|
|
|
|
2022-04-12 16:36:04 +02:00
|
|
|
! write ao_num which will be used to determine the optimal size of int indices
|
|
|
|
if (trexio_has_ao_num(trex_file) == TREXIO_HAS_NOT) then
|
|
|
|
rc = trexio_write_ao_num(trex_file, ao_num)
|
|
|
|
call trexio_assert(rc, TREXIO_SUCCESS, 'SUCCESS WRITE AO NUM')
|
|
|
|
endif
|
2022-04-22 13:18:29 +02:00
|
|
|
! write mo_num which will be used to determine the optimal size of the determinants bit fields
|
2021-12-14 17:46:04 +01:00
|
|
|
if (trexio_has_mo_num(trex_file) == TREXIO_HAS_NOT) then
|
2022-04-12 16:36:04 +02:00
|
|
|
rc = trexio_write_mo_num(trex_file, mo_num)
|
2021-12-14 17:46:04 +01:00
|
|
|
call trexio_assert(rc, TREXIO_SUCCESS, 'SUCCESS WRITE MO NUM')
|
|
|
|
endif
|
|
|
|
|
2022-07-04 14:35:24 +02:00
|
|
|
allocate(energy(mo_num))
|
|
|
|
do i=1,mo_num
|
|
|
|
energy(i) = dble(i)-100.d0
|
|
|
|
enddo
|
|
|
|
rc = trexio_write_mo_energy(trex_file, energy)
|
|
|
|
call trexio_assert(rc, TREXIO_SUCCESS, 'SUCCESS WRITE ENERGY')
|
|
|
|
deallocate(energy)
|
|
|
|
|
|
|
|
allocate(spin(mo_num))
|
|
|
|
spin(:) = 0
|
|
|
|
do i=mo_num/2+1,mo_num
|
|
|
|
spin(i) = 1
|
|
|
|
enddo
|
|
|
|
rc = trexio_write_mo_spin(trex_file, spin)
|
|
|
|
call trexio_assert(rc, TREXIO_SUCCESS, 'SUCCESS WRITE SPIN')
|
|
|
|
deallocate(spin)
|
|
|
|
|
2022-04-12 16:36:04 +02:00
|
|
|
|
2021-12-09 16:13:28 +01:00
|
|
|
offset = 0
|
2021-12-10 11:34:37 +01:00
|
|
|
do i = 1,n_buffers
|
2022-04-12 16:36:04 +02:00
|
|
|
rc = trexio_write_ao_2e_int_eri(trex_file, offset, buf_size_sparse, &
|
2022-07-04 14:35:24 +02:00
|
|
|
index_sparse_ao_2e_int_eri(1,offset+1), &
|
|
|
|
value_sparse_ao_2e_int_eri(offset+1))
|
2021-12-01 13:35:42 +01:00
|
|
|
call trexio_assert(rc, TREXIO_SUCCESS, 'SUCCESS WRITE SPARSE')
|
2022-04-12 16:36:04 +02:00
|
|
|
offset = offset + buf_size_sparse
|
|
|
|
enddo
|
|
|
|
|
|
|
|
offset = 0
|
|
|
|
do i = 1,n_buffers
|
|
|
|
rc = trexio_write_determinant_list(trex_file, offset, buf_size_det, &
|
2022-07-04 14:35:24 +02:00
|
|
|
det_list(1,offset+1))
|
2022-04-12 16:36:04 +02:00
|
|
|
call trexio_assert(rc, TREXIO_SUCCESS, 'SUCCESS WRITE DET LIST')
|
|
|
|
offset = offset + buf_size_det
|
2021-12-01 13:35:42 +01:00
|
|
|
enddo
|
2021-04-01 22:48:04 +02:00
|
|
|
|
2021-03-30 11:56:04 +02:00
|
|
|
rc = trexio_has_nucleus_num(trex_file)
|
2021-06-14 11:54:10 +02:00
|
|
|
call trexio_assert(rc, TREXIO_SUCCESS, 'SUCCESS HAS 1')
|
2021-06-04 18:14:45 +02:00
|
|
|
|
2021-03-30 11:56:04 +02:00
|
|
|
rc = trexio_has_nucleus_coord(trex_file)
|
2021-06-14 11:54:10 +02:00
|
|
|
call trexio_assert(rc, TREXIO_SUCCESS, 'SUCCESS HAS 2')
|
2021-03-30 11:56:04 +02:00
|
|
|
|
2022-04-12 16:36:04 +02:00
|
|
|
rc = trexio_has_ao_2e_int_eri(trex_file)
|
2021-12-02 17:35:06 +01:00
|
|
|
call trexio_assert(rc, TREXIO_SUCCESS, 'SUCCESS HAS 3')
|
|
|
|
|
2022-04-12 16:36:04 +02:00
|
|
|
rc = trexio_has_determinant_list(trex_file)
|
|
|
|
call trexio_assert(rc, TREXIO_SUCCESS, 'SUCCESS HAS 4')
|
|
|
|
|
2022-07-04 11:23:47 +02:00
|
|
|
rc = trexio_has_nucleus(trex_file)
|
|
|
|
call trexio_assert(rc, TREXIO_SUCCESS, 'SUCCESS HAS 5')
|
|
|
|
|
|
|
|
rc = trexio_has_ao_2e_int(trex_file)
|
|
|
|
call trexio_assert(rc, TREXIO_SUCCESS, 'SUCCESS HAS 6')
|
|
|
|
|
2021-03-24 11:14:47 +01:00
|
|
|
rc = trexio_close(trex_file)
|
2021-06-14 11:54:10 +02:00
|
|
|
call trexio_assert(rc, TREXIO_SUCCESS, 'SUCCESS CLOSE')
|
2021-03-24 11:14:47 +01:00
|
|
|
|
2021-03-30 14:20:46 +02:00
|
|
|
! ================= END OF TEST ===================== !
|
|
|
|
|
2021-03-24 11:14:47 +01:00
|
|
|
end subroutine test_write
|
|
|
|
|
2021-06-04 18:14:45 +02:00
|
|
|
|
|
|
|
subroutine test_read(file_name, back_end)
|
2021-03-24 11:14:47 +01:00
|
|
|
|
2021-03-30 14:20:46 +02:00
|
|
|
! ============ Test read functionality =============== !
|
|
|
|
|
2021-03-24 11:14:47 +01:00
|
|
|
use trexio
|
|
|
|
implicit none
|
|
|
|
|
2021-06-04 18:14:45 +02:00
|
|
|
character*(*), intent(in) :: file_name
|
2021-06-07 11:17:02 +02:00
|
|
|
integer, intent(in) :: back_end
|
2021-06-04 18:14:45 +02:00
|
|
|
|
2022-03-07 12:48:13 +01:00
|
|
|
integer(trexio_t) :: trex_file
|
2021-03-24 11:14:47 +01:00
|
|
|
|
2021-06-01 14:59:08 +02:00
|
|
|
integer :: i, j, k, ind, offset, flag
|
2022-03-07 12:48:13 +01:00
|
|
|
integer(trexio_exit_code) :: rc = 1
|
2021-10-21 15:52:12 +02:00
|
|
|
integer :: num, num_read, basis_shell_num
|
2021-03-24 11:14:47 +01:00
|
|
|
|
2021-10-19 10:22:08 +02:00
|
|
|
integer :: basis_nucleus_index(24)
|
2021-04-01 22:48:04 +02:00
|
|
|
double precision :: charge(12)
|
|
|
|
double precision :: coord(3,12)
|
2021-06-04 15:36:56 +02:00
|
|
|
|
2021-06-08 16:13:11 +02:00
|
|
|
character :: label_str(128)
|
2021-06-01 14:59:08 +02:00
|
|
|
character(len=4) :: tmp_str
|
2021-06-15 10:20:01 +02:00
|
|
|
character(len=4) :: label(12) ! also works with allocatable arrays
|
2021-04-01 22:48:04 +02:00
|
|
|
|
2021-06-04 15:36:56 +02:00
|
|
|
character(len=32) :: sym_str
|
2022-07-04 14:35:24 +02:00
|
|
|
integer :: mo_num
|
|
|
|
double precision, allocatable :: energy(:)
|
|
|
|
integer , allocatable :: spin(:)
|
2021-06-04 15:36:56 +02:00
|
|
|
|
2021-12-01 13:35:42 +01:00
|
|
|
! sparse data
|
2022-04-12 16:36:04 +02:00
|
|
|
integer(4) :: index_sparse_ao_2e_int_eri(4,20)
|
|
|
|
double precision :: value_sparse_ao_2e_int_eri(20)
|
2021-12-01 13:35:42 +01:00
|
|
|
integer(8) :: read_buf_size = 10
|
2021-12-16 11:05:57 +01:00
|
|
|
integer(8) :: read_buf_size_save = 10
|
2021-12-01 13:35:42 +01:00
|
|
|
integer(8) :: offset_read = 40
|
2021-12-10 14:02:05 +01:00
|
|
|
integer(8) :: offset_data_read = 5
|
|
|
|
integer(8) :: offset_eof = 97
|
|
|
|
integer(8) :: offset_data_eof = 1
|
2021-12-02 17:35:06 +01:00
|
|
|
integer(8) :: size_toread = 0
|
2021-12-01 13:35:42 +01:00
|
|
|
|
2022-04-12 16:36:04 +02:00
|
|
|
! determinant data
|
|
|
|
integer*8 :: det_list(6,50)
|
2022-07-12 17:21:53 +02:00
|
|
|
integer*8 :: det_list_check(3)
|
2022-04-12 16:36:04 +02:00
|
|
|
integer*8 :: read_buf_det_size = 20
|
|
|
|
integer*8 :: offset_det_read = 10
|
|
|
|
integer*8 :: offset_det_data_read = 5
|
2022-04-22 13:18:29 +02:00
|
|
|
integer*8 :: determinant_num
|
2022-04-29 12:17:38 +02:00
|
|
|
integer :: int_num
|
2022-04-22 13:18:29 +02:00
|
|
|
|
|
|
|
! orbital lists
|
|
|
|
integer*4 :: orb_list_up(150)
|
|
|
|
integer*4 :: orb_list_dn(150)
|
|
|
|
integer*4 :: occ_num_up, occ_num_dn
|
2022-04-12 16:36:04 +02:00
|
|
|
|
2021-04-01 22:48:04 +02:00
|
|
|
character*(128) :: str
|
2021-03-24 11:14:47 +01:00
|
|
|
|
|
|
|
num = 12
|
2021-10-21 15:52:12 +02:00
|
|
|
basis_shell_num = 24
|
2021-03-24 11:14:47 +01:00
|
|
|
|
2022-04-12 16:36:04 +02:00
|
|
|
index_sparse_ao_2e_int_eri = 0
|
|
|
|
value_sparse_ao_2e_int_eri = 0.0d0
|
|
|
|
|
|
|
|
det_list = 0_8
|
2022-04-22 13:18:29 +02:00
|
|
|
orb_list_up = 0
|
|
|
|
orb_list_dn = 0
|
2021-12-01 13:35:42 +01:00
|
|
|
|
2021-03-30 14:20:46 +02:00
|
|
|
! ================= START OF TEST ===================== !
|
|
|
|
|
2022-01-19 14:08:38 +01:00
|
|
|
rc = trexio_inquire(file_name)
|
|
|
|
call trexio_assert(rc, TREXIO_SUCCESS)
|
|
|
|
|
2022-01-25 15:00:55 +01:00
|
|
|
trex_file = trexio_open(file_name, 'r', TREXIO_AUTO, rc)
|
2021-09-22 14:50:22 +02:00
|
|
|
call trexio_assert(rc, TREXIO_SUCCESS)
|
2021-03-23 16:34:13 +01:00
|
|
|
|
2021-06-14 11:54:10 +02:00
|
|
|
rc = trexio_read_nucleus_num(trex_file, num_read)
|
|
|
|
call trexio_assert(rc, TREXIO_SUCCESS)
|
|
|
|
if (num_read == num) then
|
2021-06-04 18:14:45 +02:00
|
|
|
write(*,*) 'SUCCESS READ NUM'
|
|
|
|
else
|
2021-06-14 11:54:10 +02:00
|
|
|
print *, 'FAILURE NUM CHECK'
|
|
|
|
call exit(-1)
|
2021-06-04 18:14:45 +02:00
|
|
|
endif
|
|
|
|
|
2021-03-24 11:14:47 +01:00
|
|
|
|
2021-03-24 16:06:04 +01:00
|
|
|
rc = trexio_read_nucleus_charge(trex_file, charge)
|
2021-06-14 11:54:10 +02:00
|
|
|
call trexio_assert(rc, TREXIO_SUCCESS)
|
|
|
|
if (dabs(charge(11) - 1.d0) < 1.0D-8) then
|
2021-06-04 18:14:45 +02:00
|
|
|
write(*,*) 'SUCCESS READ CHARGE'
|
|
|
|
else
|
2021-06-14 11:54:10 +02:00
|
|
|
print *, 'FAILURE CHARGE CHECK'
|
2021-06-04 18:14:45 +02:00
|
|
|
call exit(-1)
|
|
|
|
endif
|
2021-03-22 16:40:45 +01:00
|
|
|
|
2021-03-30 14:20:46 +02:00
|
|
|
|
2021-06-14 11:54:10 +02:00
|
|
|
rc = trexio_read_nucleus_coord(trex_file, coord)
|
|
|
|
call trexio_assert(rc, TREXIO_SUCCESS)
|
|
|
|
if (dabs(coord(2,1) - 1.39250319d0) < 1.0D-8) then
|
2021-06-04 18:14:45 +02:00
|
|
|
write(*,*) 'SUCCESS READ COORD'
|
|
|
|
else
|
2021-06-14 11:54:10 +02:00
|
|
|
print *, 'FAILURE COORD CHECK'
|
2021-06-04 18:14:45 +02:00
|
|
|
call exit(-1)
|
|
|
|
endif
|
2021-03-24 17:22:58 +01:00
|
|
|
|
2021-12-01 13:35:42 +01:00
|
|
|
|
2022-07-08 12:27:24 +02:00
|
|
|
rc = trexio_read_nucleus_label(trex_file, label, 4)
|
2021-06-14 11:54:10 +02:00
|
|
|
call trexio_assert(rc, TREXIO_SUCCESS)
|
2022-07-08 12:27:24 +02:00
|
|
|
if (trim(label(2)) == 'Na' .and. &
|
|
|
|
trim(label(4)) == 'C 66' .and. &
|
|
|
|
trim(label(5)) == 'C') then
|
2021-06-07 11:01:37 +02:00
|
|
|
write(*,*) 'SUCCESS READ LABEL'
|
|
|
|
else
|
2021-06-14 11:54:10 +02:00
|
|
|
print *, 'FAILURE LABEL CHECK'
|
2021-06-07 11:01:37 +02:00
|
|
|
call exit(-1)
|
|
|
|
endif
|
2021-06-04 15:36:56 +02:00
|
|
|
|
2021-06-08 16:13:11 +02:00
|
|
|
|
2021-06-10 01:49:43 +02:00
|
|
|
rc = trexio_read_basis_nucleus_index(trex_file, basis_nucleus_index)
|
2021-06-15 11:49:42 +02:00
|
|
|
call trexio_assert(rc, TREXIO_SUCCESS)
|
|
|
|
if (basis_nucleus_index(12) == 12) then
|
2021-06-10 01:49:43 +02:00
|
|
|
write(*,*) 'SUCCESS READ INDEX'
|
|
|
|
else
|
2021-06-15 11:49:42 +02:00
|
|
|
print *, 'FAILURE INDEX CHECK'
|
2021-06-10 01:49:43 +02:00
|
|
|
call exit(-1)
|
|
|
|
endif
|
|
|
|
|
|
|
|
|
2021-06-15 11:26:03 +02:00
|
|
|
rc = trexio_read_nucleus_point_group(trex_file, sym_str, 10)
|
2021-06-14 11:54:10 +02:00
|
|
|
call trexio_assert(rc, TREXIO_SUCCESS)
|
|
|
|
if (sym_str(1:3) == 'B3U') then
|
2021-06-07 11:01:37 +02:00
|
|
|
write(*,*) 'SUCCESS READ POINT GROUP'
|
|
|
|
else
|
2021-06-14 11:54:10 +02:00
|
|
|
print *, 'FAILURE POINT GROUP CHECK'
|
2021-06-07 11:01:37 +02:00
|
|
|
call exit(-1)
|
|
|
|
endif
|
2021-06-01 14:59:08 +02:00
|
|
|
|
2021-03-22 16:40:45 +01:00
|
|
|
|
2022-04-12 16:36:04 +02:00
|
|
|
rc = trexio_read_ao_2e_int_eri(trex_file, offset_read, read_buf_size, &
|
2022-07-04 14:35:24 +02:00
|
|
|
index_sparse_ao_2e_int_eri(1, offset_data_read + 1), &
|
|
|
|
value_sparse_ao_2e_int_eri(offset_data_read + 1))
|
2021-12-16 11:05:57 +01:00
|
|
|
!do i = 1,20
|
2022-04-12 16:36:04 +02:00
|
|
|
! write(*,*) index_sparse_ao_2e_int_eri(1,i)
|
2021-12-16 11:05:57 +01:00
|
|
|
!enddo
|
2021-12-01 13:35:42 +01:00
|
|
|
call trexio_assert(rc, TREXIO_SUCCESS)
|
2022-04-12 16:36:04 +02:00
|
|
|
if (index_sparse_ao_2e_int_eri(1, 1) == 0 .and. &
|
|
|
|
index_sparse_ao_2e_int_eri(1, offset_data_read + 1) == offset_read*4 + 1) then
|
2021-12-01 13:35:42 +01:00
|
|
|
write(*,*) 'SUCCESS READ SPARSE DATA'
|
|
|
|
else
|
|
|
|
print *, 'FAILURE SPARSE DATA CHECK'
|
|
|
|
call exit(-1)
|
|
|
|
endif
|
|
|
|
|
2021-12-02 17:35:06 +01:00
|
|
|
|
2021-12-10 14:02:05 +01:00
|
|
|
! attempt to read reaching EOF: should return TREXIO_END and
|
|
|
|
! NOT increment the existing values in the buffer (only upd with what has been read)
|
2022-04-12 16:36:04 +02:00
|
|
|
rc = trexio_read_ao_2e_int_eri(trex_file, offset_eof, read_buf_size, &
|
2022-07-04 14:35:24 +02:00
|
|
|
index_sparse_ao_2e_int_eri(1, offset_data_eof + 1), &
|
|
|
|
value_sparse_ao_2e_int_eri(offset_data_eof + 1))
|
2021-12-10 14:02:05 +01:00
|
|
|
!do i = 1,20
|
2022-04-12 16:36:04 +02:00
|
|
|
! write(*,*) index_sparse_ao_2e_int_eri(1,i)
|
2021-12-10 14:02:05 +01:00
|
|
|
!enddo
|
2021-12-16 11:05:57 +01:00
|
|
|
call trexio_assert(rc, TREXIO_END)
|
|
|
|
if (read_buf_size == 3 .and. &
|
2022-04-12 16:36:04 +02:00
|
|
|
index_sparse_ao_2e_int_eri(1, 1) == 0 .and. &
|
|
|
|
index_sparse_ao_2e_int_eri(1, offset_data_read + 1) == offset_read*4 + 1 .and. &
|
|
|
|
index_sparse_ao_2e_int_eri(1, offset_data_eof + 1) == offset_eof*4 + 1) then
|
2021-12-10 14:02:05 +01:00
|
|
|
write(*,*) 'SUCCESS READ SPARSE DATA EOF'
|
2021-12-16 11:05:57 +01:00
|
|
|
read_buf_size = read_buf_size_save
|
2021-12-10 14:02:05 +01:00
|
|
|
else
|
|
|
|
print *, 'FAILURE SPARSE DATA EOF CHECK'
|
|
|
|
call exit(-1)
|
|
|
|
endif
|
|
|
|
|
2022-04-12 16:36:04 +02:00
|
|
|
! read the size (number of integrals) of the sparse dataset
|
|
|
|
rc = trexio_read_ao_2e_int_eri_size(trex_file, size_toread)
|
2021-12-02 17:35:06 +01:00
|
|
|
call trexio_assert(rc, TREXIO_SUCCESS)
|
|
|
|
if (size_toread == 100) then
|
|
|
|
write(*,*) 'SUCCESS READ SPARSE SIZE'
|
|
|
|
else
|
2021-12-10 11:34:37 +01:00
|
|
|
print *, 'FAILURE SPARSE SIZE CHECK'
|
2021-12-02 17:35:06 +01:00
|
|
|
call exit(-1)
|
|
|
|
endif
|
|
|
|
|
2022-04-29 12:17:38 +02:00
|
|
|
! obtain a number of int64 bit fields per determinant
|
|
|
|
rc = trexio_get_int64_num(trex_file, int_num)
|
|
|
|
call trexio_assert(rc, TREXIO_SUCCESS)
|
|
|
|
if (int_num == 3) then
|
|
|
|
write(*,*) 'SUCCESS GET INT64_NUM'
|
|
|
|
else
|
|
|
|
print *, 'FAILURE DET INT64_NUM CHECK'
|
|
|
|
call exit(-1)
|
|
|
|
endif
|
|
|
|
|
2022-04-12 16:36:04 +02:00
|
|
|
! read a chunk of determinants
|
|
|
|
rc = trexio_read_determinant_list(trex_file, offset_det_read, read_buf_det_size, &
|
2022-07-04 14:35:24 +02:00
|
|
|
det_list(1, offset_det_data_read + 1))
|
2022-04-12 16:36:04 +02:00
|
|
|
!do i = 1,50
|
|
|
|
! write(*,*) det_list(1,i)
|
|
|
|
!enddo
|
|
|
|
call trexio_assert(rc, TREXIO_SUCCESS)
|
|
|
|
if (det_list(1, 1) == 0 .and. &
|
|
|
|
det_list(1, offset_det_data_read + 1) == offset_det_read*6 + 1) then
|
|
|
|
write(*,*) 'SUCCESS READ DET LIST'
|
|
|
|
else
|
|
|
|
print *, 'FAILURE DET LIST CHECK'
|
|
|
|
call exit(-1)
|
|
|
|
endif
|
|
|
|
|
|
|
|
! read the total number of stored determinants
|
|
|
|
rc = trexio_read_determinant_num_64(trex_file, determinant_num)
|
|
|
|
call trexio_assert(rc, TREXIO_SUCCESS)
|
|
|
|
if (determinant_num == 50_8) then
|
|
|
|
write(*,*) 'SUCCESS READ DET NUM'
|
|
|
|
else
|
|
|
|
print *, 'FAILURE DET NUM CHECK'
|
|
|
|
call exit(-1)
|
|
|
|
endif
|
2021-12-02 17:35:06 +01:00
|
|
|
|
2022-04-22 13:18:29 +02:00
|
|
|
! convert one given determinant into lists of orbitals
|
|
|
|
rc = trexio_to_orbital_list_up_dn(3, det_list(:, offset_det_data_read+1), orb_list_up, orb_list_dn, occ_num_up, occ_num_dn)
|
|
|
|
!write(*,*) occ_num_up, occ_num_dn
|
2022-05-23 16:02:45 +02:00
|
|
|
! Print occupied orbitals for an up-spin component of a given determinant
|
2022-04-22 13:18:29 +02:00
|
|
|
!write(*,*) orb_list_up(1:occ_num_up)
|
2022-05-23 16:02:45 +02:00
|
|
|
! Print integers representanting a given determinant fully (up- and down-spin components)
|
2022-04-22 13:18:29 +02:00
|
|
|
!write(*,*) det_list(:, offset_det_data_read+1)
|
2022-05-23 16:02:45 +02:00
|
|
|
! Print binary representation of the first integer bit field of a given determinant
|
|
|
|
!write(*,'(B64.64)') det_list(1, offset_det_data_read+1)
|
2022-04-22 13:18:29 +02:00
|
|
|
call trexio_assert(rc, TREXIO_SUCCESS)
|
|
|
|
if (occ_num_up == 16 .and. occ_num_dn == 5) then
|
|
|
|
write(*,*) 'SUCCESS CONVERT DET LIST'
|
|
|
|
else
|
|
|
|
print *, 'FAILURE DET CONVERT CHECK'
|
|
|
|
call exit(-1)
|
|
|
|
endif
|
|
|
|
|
2022-07-12 17:21:53 +02:00
|
|
|
! convert one orbital list into a bitfield determinant representation
|
|
|
|
rc = trexio_to_bitfield_list(orb_list_up, occ_num_up, det_list_check, 3)
|
|
|
|
!write(*,*) occ_num_up, occ_num_dn
|
|
|
|
! Print occupied orbitals for an up-spin component of a given determinant
|
|
|
|
!write(*,*) orb_list_up(1:occ_num_up)
|
|
|
|
! Print integers representanting a given determinant fully (up- and down-spin components)
|
|
|
|
!write(*,*) det_list(1:3, offset_det_data_read+1)
|
|
|
|
!write(*,*) det_list_check(1:3)
|
|
|
|
! Print binary representation of the first integer bit field of a given determinant
|
|
|
|
!write(*,'(B64.64)') det_list(1, offset_det_data_read+1)
|
|
|
|
call trexio_assert(rc, TREXIO_SUCCESS)
|
|
|
|
if (det_list_check(1) == det_list(1, offset_det_data_read+1) .and. &
|
|
|
|
det_list_check(2) == det_list(2, offset_det_data_read+1) .and. &
|
|
|
|
det_list_check(3) == det_list(3, offset_det_data_read+1)) then
|
|
|
|
write(*,*) 'SUCCESS CONVERT ORB LIST'
|
|
|
|
else
|
|
|
|
print *, 'FAILURE ORB CONVERT CHECK'
|
|
|
|
call exit(-1)
|
|
|
|
endif
|
|
|
|
|
2022-07-04 14:35:24 +02:00
|
|
|
rc = trexio_read_mo_num(trex_file, mo_num)
|
|
|
|
call trexio_assert(rc, TREXIO_SUCCESS)
|
|
|
|
|
|
|
|
allocate(spin(mo_num), energy(mo_num))
|
|
|
|
rc = trexio_read_mo_energy(trex_file, energy)
|
|
|
|
call trexio_assert(rc, TREXIO_SUCCESS)
|
|
|
|
|
|
|
|
if (energy(10) /= -90.d0) then
|
|
|
|
print *, 'Failure to read MO energy: ', energy(10)
|
|
|
|
call exit(-1)
|
|
|
|
end if
|
|
|
|
|
|
|
|
rc = trexio_read_mo_spin(trex_file, spin)
|
|
|
|
call trexio_assert(rc, TREXIO_SUCCESS)
|
|
|
|
|
|
|
|
if (sum(spin) /= mo_num/2) then
|
|
|
|
print *, 'Failure to read MO spin', mo_num, sum(spin)
|
|
|
|
call exit(-1)
|
|
|
|
end if
|
|
|
|
|
2022-04-12 16:36:04 +02:00
|
|
|
! close the file
|
2021-03-24 11:14:47 +01:00
|
|
|
rc = trexio_close(trex_file)
|
2021-06-14 11:54:10 +02:00
|
|
|
call trexio_assert(rc, TREXIO_SUCCESS)
|
2021-03-22 16:40:45 +01:00
|
|
|
|
2021-03-30 14:20:46 +02:00
|
|
|
! ================= END OF TEST ===================== !
|
|
|
|
|
2021-03-24 11:14:47 +01:00
|
|
|
end subroutine test_read
|
2021-03-23 18:12:53 +01:00
|
|
|
|
2021-09-22 14:50:22 +02:00
|
|
|
subroutine test_read_void(file_name, back_end)
|
|
|
|
|
|
|
|
! ============ Test read of non-existing file =============== !
|
|
|
|
|
|
|
|
use trexio
|
|
|
|
implicit none
|
|
|
|
|
|
|
|
character*(*), intent(in) :: file_name
|
|
|
|
integer, intent(in) :: back_end
|
|
|
|
|
2022-10-07 11:37:11 +02:00
|
|
|
integer(trexio_t) :: trex_file
|
2021-09-22 14:50:22 +02:00
|
|
|
integer :: rc = 1
|
|
|
|
character(128) :: str
|
|
|
|
|
|
|
|
! ================= START OF TEST ===================== !
|
|
|
|
|
|
|
|
trex_file = trexio_open(file_name, 'r', back_end, rc)
|
2021-12-13 09:59:27 +01:00
|
|
|
if (rc /= TREXIO_OPEN_ERROR) then
|
|
|
|
rc = trexio_close(trex_file)
|
|
|
|
endif
|
2021-09-22 14:50:22 +02:00
|
|
|
call trexio_assert(rc, TREXIO_OPEN_ERROR)
|
|
|
|
|
|
|
|
call trexio_string_of_error(rc, str)
|
2022-04-12 16:36:04 +02:00
|
|
|
print *, 'Test error message: ', trim(str)
|
2021-09-22 14:50:22 +02:00
|
|
|
|
|
|
|
! ================= END OF TEST ===================== !
|
|
|
|
|
|
|
|
end subroutine test_read_void
|