1
0
mirror of https://github.com/TREX-CoE/trexio.git synced 2024-12-22 20:35:44 +01:00
trexio/tests/test_f.f90

217 lines
6.1 KiB
Fortran
Raw Normal View History

program test_trexio
2021-06-04 18:14:45 +02:00
use trexio
implicit none
call system('rm -rf test_write_f.dir')
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)
call system('rm -rf test_write_f.dir')
2021-06-04 18:14:45 +02:00
call system('rm -rf 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 -rf test_write_f.h5')
end program test_trexio
2021-06-04 18:14:45 +02:00
subroutine test_write(file_name, back_end)
! ============ Test write functionality =============== !
use trexio
use, intrinsic :: iso_c_binding
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
2021-03-24 16:06:04 +01:00
integer(8) :: trex_file
2021-03-24 17:22:58 +01:00
integer :: rc = 1
2021-06-07 11:01:37 +02:00
integer :: num
2021-03-23 16:34:13 +01:00
2021-06-10 01:49:43 +02:00
integer :: basis_nucleus_index(12)
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-06-04 15:36:56 +02:00
character(len=:), allocatable :: sym_str
character(len=:), allocatable :: label(:)
! parameters to be written
2021-03-23 18:12:53 +01:00
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-06-10 01:49:43 +02:00
basis_nucleus_index = (/ 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12 /)
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' ]
sym_str = 'B3U with some comments'
! ================= START OF TEST ===================== !
2021-03-23 18:12:53 +01:00
2021-06-04 18:14:45 +02:00
trex_file = trexio_open(file_name, 'w', back_end)
2021-03-30 11:56:04 +02:00
rc = trexio_has_nucleus_num(trex_file)
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)
call trexio_assert(rc, TREXIO_HAS_NOT, 'SUCCESS HAS NOT 2')
rc = trexio_write_nucleus_num(trex_file, num)
call trexio_assert(rc, TREXIO_SUCCESS, 'SUCCESS WRITE NUM')
2021-03-24 16:06:04 +01:00
rc = trexio_write_nucleus_charge(trex_file, charge)
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)
call trexio_assert(rc, TREXIO_SUCCESS, 'SUCCESS WRITE COORD')
2021-03-23 16:34:13 +01:00
rc = trexio_write_nucleus_label(trex_file, label, 5)
call trexio_assert(rc, TREXIO_SUCCESS, 'SUCCESS WRITE LABEL')
deallocate(label)
rc = trexio_write_nucleus_point_group(trex_file, sym_str, 32)
2021-06-04 15:36:56 +02:00
deallocate(sym_str)
call trexio_assert(rc, TREXIO_SUCCESS, 'SUCCESS WRITE POINT GROUP')
2021-06-04 15:36:56 +02:00
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-30 11:56:04 +02:00
rc = trexio_has_nucleus_num(trex_file)
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)
call trexio_assert(rc, TREXIO_SUCCESS, 'SUCCESS HAS 2')
2021-03-30 11:56:04 +02:00
rc = trexio_close(trex_file)
call trexio_assert(rc, TREXIO_SUCCESS, 'SUCCESS CLOSE')
! ================= END OF TEST ===================== !
end subroutine test_write
2021-06-04 18:14:45 +02:00
subroutine test_read(file_name, back_end)
! ============ Test read functionality =============== !
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
2021-03-24 16:06:04 +01:00
integer(8) :: trex_file
integer :: i, j, k, ind, offset, flag
2021-03-24 17:22:58 +01:00
integer :: rc = 1
integer :: num, num_read
2021-06-10 01:49:43 +02:00
integer :: basis_nucleus_index(12)
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)
character(len=4) :: tmp_str
character(len=4) :: label(12) ! also works with allocatable arrays
2021-06-04 15:36:56 +02:00
character(len=32) :: sym_str
character*(128) :: str
num = 12
! ================= START OF TEST ===================== !
2021-06-04 18:14:45 +02:00
trex_file = trexio_open(file_name, 'r', back_end)
2021-03-23 16:34:13 +01: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
print *, 'FAILURE NUM CHECK'
call exit(-1)
2021-06-04 18:14:45 +02:00
endif
2021-03-24 16:06:04 +01:00
rc = trexio_read_nucleus_charge(trex_file, charge)
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
print *, 'FAILURE CHARGE CHECK'
2021-06-04 18:14:45 +02:00
call exit(-1)
endif
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
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-06-07 11:17:02 +02:00
rc = trexio_read_nucleus_label(trex_file, label, 2)
call trexio_assert(rc, TREXIO_SUCCESS)
if (trim(label(2)) == 'Na') then
2021-06-07 11:01:37 +02:00
write(*,*) 'SUCCESS READ LABEL'
else
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
rc = trexio_read_nucleus_point_group(trex_file, sym_str, 10)
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
print *, 'FAILURE POINT GROUP CHECK'
2021-06-07 11:01:37 +02:00
call exit(-1)
endif
rc = trexio_close(trex_file)
call trexio_assert(rc, TREXIO_SUCCESS)
! ================= END OF TEST ===================== !
end subroutine test_read
2021-03-23 18:12:53 +01:00