1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47
|
PROGRAM test_atomiclevelwidth
USE, INTRINSIC :: ISO_C_BINDING
USE, INTRINSIC :: ISO_FORTRAN_ENV
USE :: xraylib
USE :: libtest
IMPLICIT NONE
TYPE(xrl_error), POINTER :: error => NULL()
REAL (C_DOUBLE) :: width
width = AtomicLevelWidth(26, K_SHELL, error)
CALL assert(ABS(width - 1.19E-3_C_DOUBLE) < 1E-6_C_DOUBLE)
CALL assert(.NOT. ASSOCIATED(error))
width = AtomicLevelWidth(92, N7_SHELL, error)
CALL assert(ABS(width - 0.31E-3_C_DOUBLE) < 1E-8_C_DOUBLE);
CALL assert(.NOT. ASSOCIATED(error))
width = AtomicLevelWidth(185, K_SHELL, error)
CALL assert(width == 0.0_C_DOUBLE)
CALL assert(ASSOCIATED(error))
CALL assert(error%code == XRL_ERROR_INVALID_ARGUMENT)
WRITE (output_unit, '(A,A)') 'Error message: ', TRIM(error%message)
DEALLOCATE(error)
width = AtomicLevelWidth(26, -5, error)
CALL assert(width == 0.0)
CALL assert(ASSOCIATED(error))
CALL assert(error%code == XRL_ERROR_INVALID_ARGUMENT)
WRITE (output_unit, '(A,A)') 'Error message: ', TRIM(error%message)
DEALLOCATE(error)
width = AtomicLevelWidth(26, N3_SHELL, error)
CALL assert(width == 0.0)
CALL assert(ASSOCIATED(error))
CALL assert(error%code == XRL_ERROR_INVALID_ARGUMENT)
WRITE (output_unit, '(A,A)') 'Error message: ', TRIM(error%message)
DEALLOCATE(error)
width = AtomicLevelWidth(26, K_SHELL)
CALL assert(ABS(width - 1.19E-3_C_DOUBLE) < 1E-6_C_DOUBLE)
width = AtomicLevelWidth(-1, K_SHELL)
CALL assert(width == 0.0_C_DOUBLE)
ENDPROGRAM test_atomiclevelwidth
|