pynucastro.screening package#
Screening routines
Submodules#
pynucastro.screening.screen module#
Python implementations of screening routines.
- class pynucastro.screening.screen.PlasmaState(*args, **kwargs)[source]#
Bases:
PlasmaState
Stores precomputed values that are reused for all screening correction factor calculations.
- Variables:
temp – temperature in K
dens – density in g/cm^3
qlam0z – TODO: from screen5
taufac – TODO: from screen5
aa – TODO: from screen5
abar – average atomic mass
zbar – average ion charge
z2bar – average (ion charge)^2
n_e – electron number density
gamma_e_fac – temperature-independent part of Gamma_e
- class_type = jitclass.PlasmaState#7f4ced45f710<temp:float64,dens:float64,qlam0z:float64,taufac:float64,aa:float64,abar:float64,zbar:float64,z2bar:float64,n_e:float64,gamma_e_fac:float64>#
- class pynucastro.screening.screen.ScreenFactors(*args, **kwargs)[source]#
Bases:
ScreenFactors
Stores values that will be used to calculate the screening correction factor for a specific pair of nuclei.
- Variables:
z1 – atomic number of first nucleus
z2 – atomic number of second nucleus
a1 – atomic mass of first nucleus
a2 – atomic mass of second nucleus
zs13 – (z1+z2)**(1/3)
zhat – combination of z1 and z2 raised to the 5/3 power
zhat2 – combination of z1 and z2 raised to the 5/12 power
lzav – log of effective charge
aznut – combination of a1, z1, a2, z2 raised to 1/3 power
ztilde – effective ion radius factor for a MCP
- class_type = jitclass.ScreenFactors#7f4cbbd11790<z1:int64,z2:int64,a1:int64,a2:int64,zs13:float64,zhat:float64,zhat2:float64,lzav:float64,aznut:float64,ztilde:float64>#
- pynucastro.screening.screen.chugunov_2007(state, scn_fac)[source]#
Calculates screening factors based on Chugunov et al. [2007].
Follows the approach in Yakovlev et al. [2006] to extend to a multi-component plasma.
- Parameters:
state (PlasmaState) – the precomputed plasma state factors
scn_fac (ScreenFactors) – the precomputed ion pair factors
- Returns:
screening correction factor
- pynucastro.screening.screen.chugunov_2009(state, scn_fac)[source]#
Calculates screening factors based on Chugunov and DeWitt [2009].
- Parameters:
state (PlasmaState) – the precomputed plasma state factors
scn_fac (ScreenFactors) – the precomputed ion pair factors
- Returns:
screening correction factor
- pynucastro.screening.screen.debye_huckel(state, scn_fac) float [source]#
Calculates the Debye-Huckel enhancement factor for weak Coloumb coupling, following the appendix of Chugunov and DeWitt [2009].
- Parameters:
state (PlasmaState) – the precomputed plasma state factors
scn_fac (ScreenFactors) – the precomputed ion pair factors
- Returns:
screening correction factor
- pynucastro.screening.screen.make_plasma_state(temp, dens, molar_fractions)[source]#
Construct a PlasmaState object from simulation data.
- Parameters:
temp – temperature in K
dens – density in g/cm^3
molar_fractions – dictionary of molar abundances for each ion, as returned by
Composition.get_molar()
- pynucastro.screening.screen.make_screen_factors(n1, n2)[source]#
Construct a ScreenFactors object from a pair of nuclei.
- pynucastro.screening.screen.potekhin_1998(state, scn_fac)[source]#
Calculates screening factors based on Chabrier and Potekhin [1998].
- Parameters:
state (PlasmaState) – the precomputed plasma state factors
scn_fac (ScreenFactors) – the precomputed ion pair factors
- Returns:
screening correction factor
- pynucastro.screening.screen.screen5(state: PlasmaState, scn_fac)[source]#
Calculates screening factors following the appendix of Wallace et al. [1982].
Based on Graboske et al. [1973] for weak screening. Based on Alastuey and Jancovici [1978] with plasma parameters from Itoh et al. [1979], for strong screening.
- pynucastro.screening.screen.screening_check(check_func=CPUDispatcher(<function debye_huckel>), threshold: float = 1.01)[source]#
A decorator factory that wraps a screening function with a check that determines whether that function can be skipped for a given plasma state and screening pair.
- Parameters:
func – the function to check against the threshold
threshold – the threshold to check against. If screen_check is less than the threshold, skip screen_func
- Returns:
a decorator for wrapping screening functions
pynucastro.screening.screening_util module#
Some helper functions for determining which rates need screening
- class pynucastro.screening.screening_util.ScreeningPair(name, nuc1, nuc2, rate=None)[source]#
Bases:
object
a pair of nuclei that will have rate screening applied. We store a list of all rates that match this pair of nuclei
- pynucastro.screening.screening_util.get_screening_map(rates, *, symmetric_screening=False)[source]#
a screening map is just a list of ScreeningPair objects containing the information about nuclei pairs for screening If symmetric_screening=True, then for reverse rates, we screen using the forward rate nuclei (assuming that we got here via detailed balance).