-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathnewint.f
251 lines (210 loc) · 12.1 KB
/
newint.f
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
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
CCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCC
C Changes (to run inder unix f77):
C -------------------------------
C Programme renamed from nucint.for to newint.f
C COMMON /therm/ -> COMMON /thermcb/
C COMMON /bessel/ -> COMMON /besselcb/
C COMMON /check/ -> COMMON /checkcb/
C COMMON /time/ -> COMMON /ttime/
C
C Updated Correction to helium-4 abundance (using fitted rates and
C *smallest* step-size) - Sarkar, Rep. Prog Phys. 59, 1493 (1996):
C
C Y_p = Y_p - 0.0025 -> Y_p = Y_p - 0.0003
C
C
C output nucint.dat -> newint.dat
C
C========================IDENTIFICATION DIVISION================================
SUBROUTINE check
C----------REMARKS.
C This is an interface subroutine,
C a flexible module which allows user to manipulate physical quantities
C of interest at certain key points during the computer run.
C Included within this subroutine is a roster of all global variables
C and their respective COMMON areas.
C Current instructions accumulate abundances of deuterium, helium-3,
C helium-4, and lithium-7 for eventual plotting, taking into account
C the contribution of beryllium-7 to lithium-7 and tritium to helium-3.
C----------PARAMETERS.
PARAMETER (nrec=123) !Number of nuclear reactions. - Ninja
PARAMETER (nvar=29) !Number of variables to be evolved.
PARAMETER (nnuc=30) !Number of nuclides in calculation. Ninja
PARAMETER (itmax=200) !Maximum # of lines to be printed. Ninja
C----------COMMON AREAS.
COMMON /recpr0/ reacpr !Reaction parameter values.
COMMON /recpr/ iform,ii,jj,kk,ll,rev,q9 !Reaction parameter names.
COMMON /rates/ f,r !Reaction rates.
COMMON /evolp1/ t9,hv,phie,y !Evolution parameters.
COMMON /evolp2/ dt9,dhv,dphie,dydt !Evolution parameters.
COMMON /evolp3/ t90,hv0,phie0,y0 !Evolution parameters.
COMMON /compr0/ cy0,ct0,t9i0,t9f0,ytmin0,inc0 !Default comp parameters.
COMMON /compr/ cy,ct,t9i,t9f,ytmin,inc !Computation parameters.
COMMON /modpr0/ c0,cosmo0,xi0 !Default model parameters.
COMMON /modpr/ g,tau,xnu,c,cosmo,xi !Model parameters.
COMMON /varpr0/ dt0,eta0 !Default variationl params.
COMMON /varpr/ dt1,eta1 !Variational parameters.
COMMON /ttime/ t,dt,dlt9dt !Time variables.
COMMON /thermcb/ thm,hubcst !Dynamic variables.
COMMON /endens/ rhone0,rhob0,rhob,rnb !Energy densities.
COMMON /lncoef/ a,b,yx !Linear eqn coefficients.
COMMON /nucdat/ am,zm,dm !Nuclide data.
COMMON /besselcb/ bl1,bl2,bl3,bl4,bl5, !Eval function bl(z).
| bm1,bm2,bm3,bm4,bm5, !Eval function bm(z).
| bn1,bn2,bn3,bn4,bn5 !Eval function bn(z).
COMMON /kays/ bk0,bk1,bk2,bk3,bk4 !Coefficients K.
COMMON /flags/ ltime,is,ip,it,mbad !Flags,counters.
COMMON /checkcb/ itime !Computation location.
COMMON /outdat/ xout,thmout,t9out,tout,dtout, !Output data.
| etaout,hubout
COMMON /nupar/ t9mev,tnmev,tnu,cnorm,nu,rhonu !Neutrino parameters.
COMMON /runopt/ irun,isize,jsize !Run options.
COMMON /outopt/ nout,outfile !Output option.
C==========================DECLARATION DIVISION=================================
C----------REACTION PARAMETER VALUES.
REAL reacpr(nrec,8) !Reaction parameters.
C----------REACTION PARAMETER NAMES.
INTEGER iform(nrec) !Reaction type code (1-11).
INTEGER ii(nrec) !Incoming nuclide type (1-27).
INTEGER jj(nrec) !Incoming light nuclide type (1-6).
INTEGER kk(nrec) !Outgoing light nuclide type (1-6).
INTEGER ll(nrec) !Outgoing nuclide type (1-27).
REAL rev(nrec) !Reverse reaction coefficient.
REAL q9(nrec) !Energy released in reaction (in 10**9 K).
C----------REACTION RATES.
REAL f(nrec) !Forward reaction rate coefficients.
REAL r(nrec) !Reverse reaction rate coefficients.
C----------EVOLUTION PARAMETERS.
REAL t9 !Temperature of photons (units of 10**9 K).
REAL hv !Defined by hv = M(atomic)n(baryon)/t9**3.
REAL phie !Chemical potential of electron.
REAL y(nnuc) !Relative number abundances.
C----------EVOLUTION PARAMETERS (DERIVATIVES).
REAL dt9 !Change in temperature.
REAL dhv !Change in hv.
REAL dphie !Change in chemical potential.
REAL dydt(nnuc) !Change in relative number abundances.
C----------EVOLUTION PARAMETERS (ORIGINAL VALUES).
REAL y0(nnuc) !Rel # abundances at end of 1st R-K loop.
C----------DEFAULT COMPUTATION PARAMETERS.
REAL cy0 !Default cy.
REAL ct0 !Default ct.
REAL t9i0 !Default t9i.
REAL t9f0 !Default t9f.
REAL ytmin0 !Default ytmin.
INTEGER inc0 !Default accumulation increment.
C----------COMPUTATION PARAMETERS.
REAL cy !Time step limiting constant on abundances.
REAL ct !Time step limiting constant on temperature.
REAL t9i !Initial temperature (in 10**9 K).
REAL t9f !Final temperature (in 10**9 K).
REAL ytmin !Smallest abundances allowed.
INTEGER inc !Accumulation increment.
C----------DEFAULT MODEL PARAMETERS.
REAL c0(3) !Default c.
REAL cosmo0 !Default cosmological constant.
REAL xi0(3) !Default neutrino degeneracy parameters.
C----------EARLY UNIVERSE MODEL PARAMETERS.
REAL g !Gravitational constant.
REAL tau !Neutron lifetime (sec).
REAL xnu !Number of neutrino species.
REAL c(3) !c(1) is variation of gravitational constant.
| !c(2) is neutron half-life (min).
| !c(3) is number of neutrino species.
REAL cosmo !Cosmological constant.
REAL xi(3) !Neutrino degeneracy parameters.
| !xi(1) is e neutrino degeneracy parameter.
| !xi(2) is m neutrino degeneracy parameter.
| !xi(3) is t neutrino degeneracy parameter.
C----------DEFAULT VARIATIONAL PARAMETERS.
REAL dt0 !Default initial time step.
REAL eta0 !Default baryon-to-photon ratio.
C----------VARIATIONAL PARAMETERS.
REAL dt1 !Initial time step.
REAL eta1 !Baryon-to-photon ratio.
C----------TIME VARIABLES.
REAL t !Time.
REAL dt !Time step.
REAL dlt9dt !(1/t9)*d(t9)/d(t).
C----------DYNAMIC VARIABLES.
REAL thm(14) !Thermodynamic variables (energy densities).
REAL hubcst !Expansion rate of the universe.
C----------ENERGY DENSITIES.
REAL rhone0 !Initial electron neutrino energy density.
REAL rhob0 !Initial baryon energy density.
REAL rhob !Baryon energy density.
REAL rnb !Baryon energy density (ratio to init value).
C----------MATRIX COEFFICIENTS FOR LINEAR EQUATION.
DOUBLE PRECISION a(nnuc,nnuc)!Relates y(t+dt) to y(t).
REAL b(nnuc) !Contains y0 in inverse order.
REAL yx(nnuc) !yy in reverse order.
C----------NUCLIDE DATA.
REAL am(nnuc) !Atomic number of nuclide.
REAL zm(nnuc) !Charge of nuclide.
REAL dm(nnuc) !Mass excess of nuclide.
C----------EVALUATION OF FUNCTIONS bl,bm,bn.
REAL bl1,bl2,bl3,bl4,bl5 !Evaluation of function bl(z).
REAL bm1,bm2,bm3,bm4,bm5 !Evaluation of function bm(z).
REAL bn1,bn2,bn3,bn4,bn5 !Evaluation of function bn(z).
C----------EVALUATION OF MODIFIED BESSEL FUNCTIONS.
REAL bk0,bk1,bk2,bk3,bk4 !Values k0(r),k1(r),k2(r),k3(r),k4(r).
C----------FLAGS AND COUNTERS.
INTEGER ltime !Indicates if output buffer printed.
INTEGER is !# total iterations for particular model.
INTEGER ip !# iterations after outputing a line.
INTEGER it !# times accumulated in output buffer.
INTEGER mbad !Indicates if gaussian elimination failed.
C----------COMPUTATION LOCATION.
INTEGER itime !Time check.
C----------OUTPUT ARRAYS.
REAL xout(itmax,nnuc) !Nuclide mass fractions.
REAL thmout(itmax,6) !Thermodynamic variables.
REAL t9out(itmax) !Temperature (in units of 10**9 K).
REAL tout(itmax) !Time.
REAL dtout(itmax) !Time step.
REAL etaout(itmax) !Baryon to photon ratio.
REAL hubout(itmax) !Expansion rate.
C----------NEUTRINO PARAMETERS.
REAL t9mev !Temperature (in units of MeV).
REAL tnmev !Neutrino temperature (in units of MeV).
REAL tnu !Neutrino temperature.
REAL cnorm !Normalizing constant.
REAL rhonu !Neutrino energy density.
INTEGER nu !Type of neutrino.
C----------RUN OPTION.
INTEGER irun !Run network size.
INTEGER isize !Number of nuclides in computation.
INTEGER jsize !Number of reactions in computation.
C----------OUTPUT FILE STATUS.
INTEGER nout !Number of output requests.
LOGICAL outfile !Indicates if output file used.
C===========================PROCEDURE DIVISION==================================
C10--------OPEN FILE------------------------------------------------------------
IF (itime.eq.1) THEN !Beginning of program.
OPEN (unit=3, file='newint.dat', status='new')
END IF
C20--------WRITE INTO FILE------------------------------------------------------
IF (itime.eq.8) THEN !Right after a run.
xout(it,8) = xout(it,8) + xout(it,9) !Add beryllium to lithium.
xout(it,5) = xout(it,5) + xout(it,4) !Add tritium to helium-3.
xout(it,6) = xout(it,6) - 0.0003
! my correction for fitted rates+coarse steps
WRITE (3,200) c(3), c(2), etaout(it),xout(it,3),
| xout(it,5),xout(it,6),xout(it,8)
| !Output N_nu, tau_n, eta, H2, He3, He4, and Li7.
200 FORMAT (7(e13.5,' '))
END IF
C30--------CLOSE FILE-----------------------------------------------------------
IF (itime.eq.10) THEN !End of program.
CLOSE (unit=3)
END IF
RETURN
C----------REFERENCES-----------------------------------------------------------
C 1) D.A. Dicus, E.W. Kolb, A.M. Gleeson, E.C.G. Sudarshan, V.L. Teplitz,
C M.S. Turner, Phys. Rev. D26 (1982) 2694. (Rad corr, Coulomb Corr)
C 2) D. Seckel, Bartol preprint BA-93-16; G. Guyk and M.S. Turner,
C FERMILAB preprint FERMILAB-Pub-93/181-A. (Nucleon mass)
C 4) S. Dodelson and M.S. Turner, Phys. Rev. D46 (1992) 3372; B. Fields,
C S. Dodelson and M.S. Turner, Phys. Rev. D47 (1993) 4309. (Nu heating)
C 5) S. Sarkar, Rep. Prog Phys. 59 (1996) 1493 (review)
END