File: test-radionuclides.f90

package info (click to toggle)
xraylib 4.0.0%2Bdfsg1-3
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 46,936 kB
  • sloc: ansic: 16,103; f90: 8,746; java: 6,766; python: 1,497; cpp: 1,305; pascal: 1,139; makefile: 809; ruby: 622; php: 594; perl: 573; cs: 193; sh: 125
file content (97 lines) | stat: -rw-r--r-- 3,656 bytes parent folder | download | duplicates (2)
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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
PROGRAM test_radionuclides

USE, INTRINSIC :: ISO_C_BINDING
USE, INTRINSIC :: ISO_FORTRAN_ENV
USE :: xraylib
USE :: libtest
IMPLICIT NONE

TYPE(xrl_error), POINTER :: error => NULL()
INTEGER, PARAMETER :: RADIONUCLIDE_LIST_LEN = 10
CHARACTER(KIND=C_CHAR, LEN=RADIO_NUCLIDE_STRING_LENGTH), DIMENSION(:), POINTER :: radionuclide_list
INTEGER :: i
TYPE (radioNuclideData), POINTER :: c

radionuclide_list => GetRadioNuclideDataList(error)
CALL assert(.NOT. ASSOCIATED(error))
CALL assert(SIZE(radionuclide_list) == RADIONUCLIDE_LIST_LEN)

DO i=1,RADIONUCLIDE_LIST_LEN
        c => GetRadioNuclideDataByName(radionuclide_list(i))
        CALL assert(c%name == radionuclide_list(i))
        DEALLOCATE(c)
ENDDO

DO i=1,RADIONUCLIDE_LIST_LEN
        c => GetRadioNuclideDataByIndex(i-1)
        CALL assert(c%name == radionuclide_list(i))
        DEALLOCATE(c)
ENDDO

DEALLOCATE(radionuclide_list)

c => GetRadioNuclideDataByIndex(3)
CALL assert(c%A == 125)
CALL assert(ALL(ABS(c%GammaEnergies - [35.4919_C_DOUBLE]) < 1E-6_C_DOUBLE))
CALL assert(ALL(ABS(c%GammaIntensities - [0.0668_C_DOUBLE]) < 1E-6_C_DOUBLE))
CALL assert(c%N == 72)
CALL assert(ALL(ABS(c%XrayIntensities- [0.0023_C_DOUBLE, 0.00112_C_DOUBLE, &
   0.0063_C_DOUBLE, 0.056_C_DOUBLE, 0.035_C_DOUBLE, 0.0042_C_DOUBLE, &
   0.007_C_DOUBLE, 0.00043_C_DOUBLE, 0.0101_C_DOUBLE, 0.0045_C_DOUBLE, &
   0.00103_C_DOUBLE, 0.0016_C_DOUBLE, 3.24e-05_C_DOUBLE, 0.406_C_DOUBLE, &
   0.757_C_DOUBLE, 0.0683_C_DOUBLE, 0.132_C_DOUBLE, 0.00121_C_DOUBLE, &
   0.0381_C_DOUBLE, 0.0058_C_DOUBLE]) < 1E-6_C_DOUBLE))
CALL assert(ALL(c%XrayLines - [-86, -60, -89, -90, -63, -33, -34, -91, -95,&
   -68, -38, -39, -1, -2, -3, -5, -6, -8, -11, -13] == 0))
CALL assert(c%Z == 53)
CALL assert(c%Z_xray == 52)
CALL assert(c%nGammas == 1)
CALL assert(c%nXrays == 20)
CALL assert(c%name == '125I')
DEALLOCATE(c)

c => GetRadioNuclideDataByName('125I')
CALL assert(c%A == 125)
CALL assert(ALL(ABS(c%GammaEnergies - [35.4919_C_DOUBLE]) < 1E-6_C_DOUBLE))
CALL assert(ALL(ABS(c%GammaIntensities - [0.0668_C_DOUBLE]) < 1E-6_C_DOUBLE))
CALL assert(c%N == 72)
CALL assert(ALL(ABS(c%XrayIntensities- [0.0023_C_DOUBLE, 0.00112_C_DOUBLE, &
   0.0063_C_DOUBLE, 0.056_C_DOUBLE, 0.035_C_DOUBLE, 0.0042_C_DOUBLE, &
   0.007_C_DOUBLE, 0.00043_C_DOUBLE, 0.0101_C_DOUBLE, 0.0045_C_DOUBLE, &
   0.00103_C_DOUBLE, 0.0016_C_DOUBLE, 3.24e-05_C_DOUBLE, 0.406_C_DOUBLE, &
   0.757_C_DOUBLE, 0.0683_C_DOUBLE, 0.132_C_DOUBLE, 0.00121_C_DOUBLE, &
   0.0381_C_DOUBLE, 0.0058_C_DOUBLE]) < 1E-6_C_DOUBLE))
CALL assert(ALL(c%XrayLines - [-86, -60, -89, -90, -63, -33, -34, -91, -95,&
   -68, -38, -39, -1, -2, -3, -5, -6, -8, -11, -13] == 0))
CALL assert(c%Z == 53)
CALL assert(c%Z_xray == 52)
CALL assert(c%nGammas == 1)
CALL assert(c%nXrays == 20)
CALL assert(c%name == '125I')
DEALLOCATE(c)

c => GetRadioNuclideDataByIndex(-1)
CALL assert(.NOT. ASSOCIATED(c))
c => GetRadioNuclideDataByIndex(RADIONUCLIDE_LIST_LEN)
CALL assert(.NOT. ASSOCIATED(c))
c => GetRadioNuclideDataByName('non-existent-radionuclide')
CALL assert(.NOT. ASSOCIATED(c))

c => GetRadioNuclideDataByIndex(-1, error)
CALL assert(.NOT. ASSOCIATED(c))
CALL assert(ASSOCIATED(error))
CALL assert(error%code == XRL_ERROR_INVALID_ARGUMENT)
DEALLOCATE(error)
c => GetRadioNuclideDataByIndex(RADIONUCLIDE_LIST_LEN, error)
CALL assert(.NOT. ASSOCIATED(c))
CALL assert(ASSOCIATED(error))
CALL assert(error%code == XRL_ERROR_INVALID_ARGUMENT)
DEALLOCATE(error)
c => GetRadioNuclideDataByName('non-existent-radionuclide', error)
CALL assert(.NOT. ASSOCIATED(c))
CALL assert(ASSOCIATED(error))
CALL assert(error%code == XRL_ERROR_INVALID_ARGUMENT)
DEALLOCATE(error)

ENDPROGRAM test_radionuclides