-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsigma_v_calculation_12C(p,g)_13N.f90
79 lines (47 loc) · 2.87 KB
/
sigma_v_calculation_12C(p,g)_13N.f90
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
program sigma_v_calculation
! This program calculates sigma_v depending on given sigma or s_factor
implicit none
! Type declarations
double precision :: E_G, A_1, A_0, A, sigma_v_int_constant, sigma_v_int, sigma_v, new_sigma_v
double precision, dimension(7):: E, sigma
double precision, dimension(60) :: T9
double precision :: PI
INTEGER :: Z_0,Z_1
integer :: i, j
! Executable statements
!Get variables for deuterium burning reaction d(p, g)3He
PI = DACOS(-1.D0)
Z_0 = 1 !deuterium atomic umber
Z_1 = 1 !proton atomic number
!S = (/ 0.18e-1, 0.31e-1, 0.33, 0.31, 0.70e-2, 0.67e-3, 0.85e-4 /)
E = (/ 326.8, 360.0, 424.6, 427.4, 521.5, 692.3, 979.4 /)
E = E*10**(-3.0)
A_1 = 1.007277 !atomic mass of proton
A_0 = 12.0107 ! atomic mass of deuterium
A = (A_0*A_1)/(A_0+A_1) !reduced atomic mass
E_G = (0.98948*Z_0*Z_1*SQRT(A))**2
sigma = (/ 2.5, 6.5, 1.24e2, 1.16e2, 5.0, 1.0, 0.27 /)
sigma = sigma*10**(-6.0)
! T9 = (/ 40.0, 20.0, 10.0, 5.0, 2.5, 1.25, 1.0, 0.8, 0.6, 0.4, 0.2, 0.1, 0.005, 0.0025 /)
T9 = (/0.001, 0.002, 0.003, 0.004, 0.005, 0.006, 0.007, 0.008, 0.009,0.010, 0.011, 0.012,0.013, 0.014, &
0.015, 0.016, 0.018, 0.020, 0.025, 0.030, 0.040, 0.050, 0.060, 0.070, 0.080, 0.090, 0.100, 0.110, 0.120, 0.130, &
0.140, 0.150, 0.160, 0.180, 0.200, 0.250, 0.300, 0.350, 0.400, 0.450, 0.500, 0.600, 0.700, 0.800, 0.900, 1.000, &
1.250, 1.500, 1.750, 2.000, 2.500, 3.000, 3.500, 4.000, 5.000, 6.000, 7.000, 8.000, 9.000, 10.00 /)
do i= 1, size(T9)
sigma_v_int_constant = 6.1968*(10**(-14.0))*(A**(-1.0/2))*(T9(i)**(-3.0/2))
sigma_v_int = 0
do j = 1, (size(sigma) - 1)
sigma_v_int = sigma_v_int + sigma(j)*E(j)*EXP(-11.605*E(j)/T9(i)) * (E(j+1) - E(j))
end do
sigma_v = sigma_v_int_constant*sigma_v_int
open(1, file = 'sigma_v_12C(p,g)13N.dat', status = 'unknown')
write(1,*) T9(i), sigma_v*(6.022*10**(23.0))
new_sigma_v = 2.04e+7*(T9(i))**(-(2.0/3.0))*EXP(-13.690/((T9(i))**(1.0/3.0))-(T9(i)/1.500)**2) &
*(1.+.030*((T9(i))**(1.0/3.0))+1.19*(T9(i))**(2.0/3.0)+.254*T9(i)+2.06*((T9(i))**(4.0/3.0)) &
+1.12*((T9(i))**(5.0/3.0))) &
+ 1.08e+5*((T9(i))**(-3.0/2.0))*EXP(-4.925/T9(i)) &
+ 2.15e+5*((T9(i))**(-3.0/2.0))*EXP(-18.179/T9(i))
open(2, file = 'new_sigma_v_12C(p,g)13N.dat', status = 'unknown')
write(2,*) T9(i), new_sigma_v
end do
end program sigma_v_calculation