-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathnucdatamod.f
66 lines (66 loc) · 3.2 KB
/
nucdatamod.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
* © 2023. Triad National Security, LLC. All rights reserved.
* This program was produced under U.S. Government contract 89233218CNA000001 for Los Alamos National
* Laboratory (LANL), which is operated by Triad National Security, LLC for the U.S. Department of
* Energy/National Nuclear Security Administration. All rights in the program are reserved by Triad
* National Security, LLC, and the U.S. Department of Energy/National Nuclear Security Administration.
* The Government is granted for itself and others acting on its behalf a nonexclusive, paid-up,
* irrevocable worldwide license in this material to reproduce, prepare. derivative works, distribute
* copies to the public, perform publicly and display publicly, and to permit others to do so.
*This file is part of SuperNu. SuperNu is released under the terms of the GNU GPLv3, see COPYING.
*Copyright (c) 2013-2022 Ryan T. Wollaeger and Daniel R. van Rossum. All rights reserved.
module nucdatamod
c -----------------
use physconstmod, only:pc_kev
private pc_kev
c
c-- nuclear data: http://ie.lbl.gov/
c-- nuclear decay half-life times
real*8,parameter :: nuc_thl_ni56 = 7.575d5 !sec, 6.077 days, converted to 1/exp life
real*8,parameter :: nuc_thl_co56 = 9.632d6 !sec, 77.27 days, converted to 1/exp life
real*8,parameter :: nuc_thl_fe52 = 4.298d4 !sec, 8.275(8) h, converted to 1/exp life
real*8,parameter :: nuc_thl_mn52 = 1.828d3 !sec, 21.1(2) min, converted to 1/exp life
real*8,parameter :: nuc_thl_cr48 = 1.119d5 !sec, 21.56 h, converted to 1/exp life
real*8,parameter :: nuc_thl_v48 = 1.991d6 !sec, 15.973 days, converted to 1/exp life
c
c-- nuclear decay gamma emission, 1MeV=1.602176d-6 erg
real*8,parameter :: nuc_qhl_ni56 = 1720d0*pc_kev !total gamma ray production
real*8,parameter :: nuc_qhl_co56 = (3440d0 + .19d0*2*511d0)*pc_kev!direct gamma's plus positron annihilation
c-- average kinetic energy of co56->fe56 emergent positron
real*8,parameter :: nuc_q_poskin = .19d0*116*pc_kev
c
contains
c
c
c
subroutine nucdecay3(ncell,t,thl3,thl2,x)
c -------------------------------------------
implicit none
integer,intent(in) :: ncell
real*8,intent(in) :: t,thl3,thl2 !half-life of ni56 and co56 (or other 3-level chains)
real*8,intent(inout) :: x(ncell,3) !(fe56,co56,ni56)
************************************************************************
* Calculate x 3-level decay chain, such as ni56->co56->fe56
* x input: ni56/co56 at t=0
* x output: ni56/co56/fe56 at t=t
************************************************************************
real*8 :: help,exp3,exp2
c
exp3 = exp(-t/thl3) !ni56
exp2 = exp(-t/thl2) !co56
c
c-- calculate fe
help = 1d0 + (thl2*exp2 - thl3*exp3)/(thl3 - thl2)
if(help.lt.0) stop 'nucdecay3: ni->fe < 0'
x(:,1) = x(:,3)*help + x(:,2)*(1d0-exp2) !initial ni56 + initial co56
c
c-- update co56
help = thl2*(exp3 - exp2)/(thl3 - thl2)
if(help.lt.0) stop 'nucdecay3: ni->co < 0'
x(:,2) = x(:,3)*help + x(:,2)*exp2 !initial ni56 + initial co56
c
c-- update ni56
x(:,3) = x(:,3)*exp3 !initial ni56
end subroutine nucdecay3
c
end module nucdatamod
c vim: fdm=marker