mirror of
https://github.com/TREX-CoE/trexio.git
synced 2025-01-05 19:08:59 +01:00
134 lines
4.0 KiB
Fortran
134 lines
4.0 KiB
Fortran
program test_trexio
|
|
|
|
call test_write()
|
|
call test_read()
|
|
|
|
end program test_trexio
|
|
|
|
subroutine test_write()
|
|
|
|
! ============ Test write functionality =============== !
|
|
|
|
use trexio
|
|
implicit none
|
|
|
|
integer(8) :: trex_file
|
|
|
|
integer :: rc = 1
|
|
integer :: num
|
|
|
|
double precision :: charge(12)
|
|
double precision :: coord(3,12)
|
|
|
|
! parameters to be written
|
|
num = 12
|
|
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 ===================== !
|
|
|
|
trex_file = trexio_open('trexio_test_fort', 'w', TREXIO_TEXT)
|
|
! trex_file = trexio_open('test_hdf5_fort.h5', 'w', TREXIO_HDF5)
|
|
|
|
rc = trexio_has_nucleus_num(trex_file)
|
|
if (rc == TREXIO_HAS_NOT) write(*,*) 'SUCCESS HAS NOT 1'
|
|
rc = trexio_has_nucleus_charge(trex_file)
|
|
if (rc == TREXIO_HAS_NOT) write(*,*) 'SUCCESS HAS NOT 2'
|
|
|
|
rc = trexio_write_nucleus_num(trex_file, num)
|
|
if (rc == TREXIO_SUCCESS) write(*,*) 'SUCCESS WRITE NUM'
|
|
|
|
rc = trexio_write_nucleus_charge(trex_file, charge)
|
|
if (rc == TREXIO_SUCCESS) write(*,*) 'SUCCESS WRITE CHARGE'
|
|
|
|
rc = trexio_write_nucleus_coord(trex_file, coord)
|
|
if (rc == TREXIO_SUCCESS) write(*,*) 'SUCCESS WRITE COORD'
|
|
|
|
rc = trexio_has_nucleus_num(trex_file)
|
|
if (rc == TREXIO_SUCCESS) write(*,*) 'SUCCESS HAS 1'
|
|
rc = trexio_has_nucleus_coord(trex_file)
|
|
if (rc == TREXIO_SUCCESS) write(*,*) 'SUCCESS HAS 2'
|
|
|
|
rc = trexio_close(trex_file)
|
|
if (rc == TREXIO_SUCCESS) write(*,*) 'SUCCESS CLOSE'
|
|
|
|
! ---------------------------------- !
|
|
! to modify fiels of existing file:
|
|
! text backend -> open with 'w'
|
|
! hdf5 backend -> open with 'a'
|
|
! ---------------------------------- !
|
|
|
|
!! trex_file = trexio_open('trexio_test_fort', 'w', TREXIO_TEXT);
|
|
!! trex_file = trexio_open('test_hdf5_fort.h5', 'a', TREXIO_HDF5)
|
|
|
|
! coord(1) = 666.666
|
|
|
|
! rc = trexio_write_nucleus_coord(trex_file,coord)
|
|
! if (rc == TREXIO_SUCCESS) write(*,*) 'SUCCESS MODIFY COORD'
|
|
|
|
! rc = trexio_close(trex_file)
|
|
! if (rc == TREXIO_SUCCESS) write(*,*) 'SUCCESS CLOSE'
|
|
|
|
! ================= END OF TEST ===================== !
|
|
|
|
end subroutine test_write
|
|
|
|
subroutine test_read()
|
|
|
|
! ============ Test read functionality =============== !
|
|
|
|
use trexio
|
|
implicit none
|
|
|
|
integer(8) :: trex_file
|
|
|
|
integer :: rc = 1
|
|
integer :: num, num_read
|
|
|
|
double precision :: charge(12)
|
|
double precision :: coord(3,12)
|
|
|
|
character*(128) :: str
|
|
|
|
num = 12
|
|
|
|
! ================= START OF TEST ===================== !
|
|
|
|
trex_file = trexio_open('trexio_test_fort', 'r', TREXIO_TEXT)
|
|
! trex_file = trexio_open('test_hdf5_fort.h5', 'r', TREXIO_HDF5)
|
|
|
|
rc = trexio_read_nucleus_num(trex_file, num_read)
|
|
|
|
if (rc == TREXIO_SUCCESS .and. num_read == num) write(*,*) 'SUCCESS READ NUM'
|
|
|
|
rc = trexio_read_nucleus_charge(trex_file, charge)
|
|
|
|
if (rc == TREXIO_SUCCESS .and. (abs(charge(11) - 1.0) < 1.0D-8) ) write(*,*) 'SUCCESS READ CHARGE'
|
|
|
|
rc = trexio_read_nucleus_coord(trex_file, coord)
|
|
|
|
if (rc == TREXIO_SUCCESS .and. (abs(coord(2,1) - 1.39250319d0) < 1.0D-8) ) write(*,*) 'SUCCESS READ COORD'
|
|
|
|
rc = trexio_close(trex_file)
|
|
if (rc == TREXIO_SUCCESS) write(*,*) 'SUCCESS CLOSE'
|
|
|
|
call trexio_string_of_error(TREXIO_READONLY,str)
|
|
write(*,*) str
|
|
|
|
! ================= END OF TEST ===================== !
|
|
|
|
end subroutine test_read
|
|
|