1
0
mirror of https://github.com/TREX-CoE/trexio.git synced 2025-01-10 04:58:31 +01:00
trexio/tests/test_f.f90

231 lines
6.1 KiB
Fortran
Raw Normal View History

program test_trexio
2021-06-04 18:14:45 +02:00
use trexio
implicit none
2021-06-04 18:14:45 +02:00
call system('rm -rf trexio_test_fort')
print *, 'call test_write(''trexio_test_fort'', TREXIO_TEXT)'
call test_write('trexio_test_fort', TREXIO_TEXT)
print *, 'call test_read(''trexio_test_fort'', TREXIO_TEXT)'
call test_read('trexio_test_fort', TREXIO_TEXT)
call system('rm -rf trexio_test_fort')
call system('rm -rf trexio_test_fort')
print *, 'call test_write(''trexio_test_fort.h5'', TREXIO_HDF5)'
call test_write('trexio_test_fort.h5', TREXIO_HDF5)
print *, 'call test_read(''trexio_test_fort.h5'', TREXIO_HDF5)'
call test_read('trexio_test_fort.h5', TREXIO_HDF5)
call system('rm -rf trexio_test_fort.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
implicit none
2021-06-04 18:14:45 +02:00
character*(*), intent(in) :: file_name
integer(trexio_backend), intent(in) :: back_end
2021-03-24 16:06:04 +01:00
integer(8) :: trex_file
2021-03-24 17:22:58 +01:00
integer :: rc = 1
integer :: num
2021-06-04 18:14:45 +02:00
character*(128) :: str
2021-03-23 16:34:13 +01:00
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)
! 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) )
! ================= 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)
2021-06-04 18:14:45 +02:00
if (rc == TREXIO_HAS_NOT) then
write(*,*) 'SUCCESS HAS NOT 1'
else
call trexio_string_of_error(TREXIO_READONLY,str)
print *, trim(str)
call exit(1)
endif
2021-03-30 11:56:04 +02:00
rc = trexio_has_nucleus_charge(trex_file)
2021-06-04 18:14:45 +02:00
if (rc == TREXIO_HAS_NOT) then
write(*,*) 'SUCCESS HAS NOT 2'
else
call trexio_string_of_error(TREXIO_READONLY,str)
print *, trim(str)
call exit(1)
endif
rc = trexio_write_nucleus_num(trex_file, num)
2021-06-04 18:14:45 +02:00
if (rc == TREXIO_SUCCESS) then
write(*,*) 'SUCCESS WRITE NUM'
else
call trexio_string_of_error(TREXIO_READONLY,str)
print *, trim(str)
call exit(1)
endif
2021-03-24 16:06:04 +01:00
rc = trexio_write_nucleus_charge(trex_file, charge)
2021-06-04 18:14:45 +02:00
if (rc == TREXIO_SUCCESS) then
write(*,*) 'SUCCESS WRITE CHARGE'
else
call trexio_string_of_error(TREXIO_READONLY,str)
print *, trim(str)
call exit(1)
endif
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-04 18:14:45 +02:00
if (rc == TREXIO_SUCCESS) then
write(*,*) 'SUCCESS WRITE COORD'
else
call trexio_string_of_error(TREXIO_READONLY,str)
print *, trim(str)
call exit(1)
endif
2021-03-23 16:34:13 +01:00
2021-03-30 11:56:04 +02:00
rc = trexio_has_nucleus_num(trex_file)
2021-06-04 18:14:45 +02:00
if (rc == TREXIO_SUCCESS) then
write(*,*) 'SUCCESS HAS 1'
else
call trexio_string_of_error(TREXIO_READONLY,str)
print *, trim(str)
call exit(1)
endif
2021-03-30 11:56:04 +02:00
rc = trexio_has_nucleus_coord(trex_file)
2021-06-04 18:14:45 +02:00
if (rc == TREXIO_SUCCESS) then
write(*,*) 'SUCCESS HAS 2'
else
call trexio_string_of_error(TREXIO_READONLY,str)
print *, trim(str)
call exit(1)
endif
2021-03-30 11:56:04 +02:00
rc = trexio_close(trex_file)
2021-06-04 18:14:45 +02:00
if (rc == TREXIO_SUCCESS) then
write(*,*) 'SUCCESS CLOSE'
else
call trexio_string_of_error(TREXIO_READONLY,str)
print *, trim(str)
call exit(1)
endif
! ---------------------------------- !
2021-06-04 18:14:45 +02:00
! to modify fields of existing file:
! text backend -> open with 'w'
! hdf5 backend -> open with 'a'
! ---------------------------------- !
2021-03-25 11:42:13 +01:00
!! trex_file = trexio_open('trexio_test_fort', 'w', TREXIO_TEXT);
2021-03-24 17:22:58 +01:00
!! trex_file = trexio_open('test_hdf5_fort.h5', 'a', TREXIO_HDF5)
2021-03-24 17:13:53 +01:00
! coord(1) = 666.666
2021-03-24 17:13:53 +01:00
! rc = trexio_write_nucleus_coord(trex_file,coord)
2021-03-29 14:34:41 +02:00
! if (rc == TREXIO_SUCCESS) write(*,*) 'SUCCESS MODIFY COORD'
2021-03-24 17:13:53 +01:00
! rc = trexio_close(trex_file)
! if (rc == TREXIO_SUCCESS) write(*,*) '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
integer(trexio_backend), intent(in) :: back_end
2021-03-24 16:06:04 +01:00
integer(8) :: trex_file
2021-03-24 17:22:58 +01:00
integer :: rc = 1
integer :: num, num_read
double precision :: charge(12)
double precision :: coord(3,12)
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-24 16:06:04 +01:00
rc = trexio_read_nucleus_num(trex_file, num_read)
2021-03-23 16:34:13 +01:00
2021-06-04 18:14:45 +02:00
if (rc == TREXIO_SUCCESS .and. num_read == num) then
write(*,*) 'SUCCESS READ NUM'
else
call trexio_string_of_error(TREXIO_READONLY,str)
print *, trim(str)
call exit(1)
endif
2021-03-24 16:06:04 +01:00
rc = trexio_read_nucleus_charge(trex_file, charge)
2021-06-04 18:14:45 +02:00
if (rc == TREXIO_SUCCESS .and. (dabs(charge(11) - 1.d0) < 1.0D-8) ) then
write(*,*) 'SUCCESS READ CHARGE'
else
call trexio_string_of_error(TREXIO_READONLY,str)
print *, trim(str)
call exit(-1)
endif
2021-03-24 17:22:58 +01:00
rc = trexio_read_nucleus_coord(trex_file, coord)
2021-06-04 18:14:45 +02:00
if (rc == TREXIO_SUCCESS .and. (dabs(coord(2,1) - 1.39250319d0) < 1.0D-8) ) then
write(*,*) 'SUCCESS READ COORD'
else
call trexio_string_of_error(TREXIO_READONLY,str)
print *, trim(str)
call exit(-1)
endif
2021-03-24 17:22:58 +01:00
rc = trexio_close(trex_file)
2021-06-04 18:14:45 +02:00
if (rc == TREXIO_SUCCESS) then
write(*,*) 'SUCCESS CLOSE'
else
call trexio_string_of_error(TREXIO_READONLY,str)
print *, trim(str)
call exit(1)
endif
! ================= END OF TEST ===================== !
end subroutine test_read
2021-03-23 18:12:53 +01:00