Skip to content

Commit

Permalink
Merge pull request #1585 from zhichen3/factor_out_terms_chabrier1998
Browse files Browse the repository at this point in the history
Factor out some sqrt terms in chabrier1998 screening.
  • Loading branch information
zingale authored Jun 21, 2024
2 parents f9e2e1d + c86a060 commit e1a89f6
Show file tree
Hide file tree
Showing 2 changed files with 68 additions and 64 deletions.
16 changes: 10 additions & 6 deletions screening/screen.H
Original file line number Diff line number Diff line change
Expand Up @@ -802,15 +802,18 @@ void chabrier1998_helmholtz_F(const amrex::Real gamma, const amrex::Real dgamma_
// Helmholtz free energy, See Chabrier & Potekhin 1998 Eq. 28

// Fitted parameters, see Chabrier & Potekhin 1998 Sec.IV

constexpr amrex::Real A_1 = -0.9052_rt;
constexpr amrex::Real A_2 = 0.6322_rt;
constexpr amrex::Real A_3 = -0.5_rt * gcem::sqrt(3.0_rt) - A_1 / gcem::sqrt(A_2);
constexpr amrex::Real sqrt_A2 = gcem::sqrt(A_2);
constexpr amrex::Real A_3 = -0.5_rt * gcem::sqrt(3.0_rt) - A_1 / sqrt_A2;

// Precompute some expressions that are reused in the derivative

const amrex::Real sqrt_gamma = std::sqrt(gamma);
const amrex::Real sqrt_1_gamma_A2 = std::sqrt(1.0_rt + gamma/A_2);
const amrex::Real sqrt_gamma_A2_gamma = std::sqrt(gamma * (A_2 + gamma));
const amrex::Real sqrt_gamma_A2 = std::sqrt(gamma/A_2);
const amrex::Real sqrt_gamma_A2_gamma = sqrt_gamma * sqrt_A2 * sqrt_1_gamma_A2;
const amrex::Real sqrt_gamma_A2 = sqrt_gamma / sqrt_A2;

f = A_1 * (sqrt_gamma_A2_gamma -
A_2 * std::log(sqrt_gamma_A2 + sqrt_1_gamma_A2)) +
Expand Down Expand Up @@ -873,8 +876,8 @@ void chabrier1998 (const plasma_state_t& state,
// Now we add quantum correction terms discussed in Alastuey 1978.
// Notice in Alastuey 1978, they have a different classical term,
// which is implemented in the strong screening limit of our screen5 routine.
amrex::Real quantum_corr_1 = 0.0_rt;

amrex::Real quantum_corr_1 = 0.0_rt;
amrex::Real quantum_corr_2 = 0.0_rt;

[[maybe_unused]] amrex::Real quantum_corr_1_dT = 0.0_rt;
Expand All @@ -883,8 +886,9 @@ void chabrier1998 (const plasma_state_t& state,
if (screening_rp::enable_chabrier1998_quantum_corr) {
// See Wallace1982, Eq. A13

amrex::Real Gamma_eff = std::cbrt(2.0_rt) * scn_fac.z1 * scn_fac.z2 *
scn_fac.zs13inv * Gamma_e;
constexpr amrex::Real CBRT_2 = gcem::pow(2.0_rt, 1.0_rt/3.0_rt);
amrex::Real Gamma_eff = CBRT_2 * scn_fac.z1 * scn_fac.z2 *
scn_fac.zs13inv * Gamma_e;
[[maybe_unused]] amrex::Real Gamma_eff_dT;

if constexpr (do_T_derivatives) {
Expand Down
Loading

0 comments on commit e1a89f6

Please sign in to comment.