14 #include <AMReX_FArrayBox.H>
15 #include <AMReX_Geometry.H>
16 #include <AMReX_MultiFabUtil.H>
17 #include <AMReX_GpuContainers.H>
43 using FabPtr = std::shared_ptr<amrex::MultiFab>;
66 Init (
const amrex::MultiFab& cons_in,
67 const amrex::BoxArray& ,
68 const amrex::Geometry& geom,
70 std::unique_ptr<amrex::MultiFab>& ,
71 std::unique_ptr<amrex::MultiFab>& )
override;
91 const amrex::MultiFab& )
override
121 std::vector<int>& a_idx,
122 std::vector<std::string>& a_names)
const override
131 AMREX_GPU_HOST_DEVICE
141 constexpr
int max_niter = 20;
161 fff = -
tabs + tabs_old + fac_cond*(qv_old - qsat);
164 dfff = -
one - fac_cond*dqsat;
172 }
while(std::abs(dtabs) > tol && niter < max_niter);
180 AMREX_GPU_HOST_DEVICE
194 if ((
qv +
qc) > qsat) {
195 #if defined(AMREX_DEBUG)
211 #if defined(AMREX_DEBUG)
214 AMREX_ASSERT(std::abs(
qv-qsatnew) < 1e-12);
215 AMREX_ASSERT(std::abs(
qv+
qc-qvprev-qcprev) < 1e-14);
225 tabs -= fac_cond * delta_qc;
230 #if defined(AMREX_DEBUG)
242 #if defined(AMREX_DEBUG)
245 AMREX_ASSERT(
qv < qvprev);
246 AMREX_ASSERT(
qc > qcprev);
247 AMREX_ASSERT(
tabs > Tprev);
248 AMREX_ASSERT(std::abs(
qv-qsatnew) < 1e-14);
249 AMREX_ASSERT(std::abs(
qv+
qc-qvprev-qcprev) < 1e-14);
constexpr amrex::Real one
Definition: ERF_Constants.H:7
constexpr amrex::Real zero
Definition: ERF_Constants.H:6
constexpr amrex::Real lcond
Definition: ERF_Constants.H:77
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real getThgivenTandP(const amrex::Real T, const amrex::Real P, const amrex::Real rdOcp)
Definition: ERF_EOS.H:18
const Real rdOcp
Definition: ERF_InitCustomPert_Bomex.H:16
AMREX_ALWAYS_ASSERT(bx.length()[2]==khi+1)
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE void erf_dtqsatw(amrex::Real t, amrex::Real p, amrex::Real &dtqsatw)
Definition: ERF_MicrophysicsUtils.H:244
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE void erf_qsatw(amrex::Real t, amrex::Real p, amrex::Real &qsatw)
Definition: ERF_MicrophysicsUtils.H:228
amrex::Real Real
Definition: ERF_ShocInterface.H:19
Definition: ERF_NullMoist.H:8
Definition: ERF_SatAdj.H:41
int n_qstate_moist_size
Definition: ERF_SatAdj.H:262
AMREX_GPU_HOST_DEVICE static AMREX_FORCE_INLINE void AdjustSatAdjCell(const amrex::Real fac_cond, const amrex::Real rdOcp, amrex::Real &tabs, const amrex::Real pres_mbar, amrex::Real &theta, amrex::Real &qv, amrex::Real &qc)
Definition: ERF_SatAdj.H:183
amrex::Real m_fac_cond
Definition: ERF_SatAdj.H:274
int Qmoist_Size() override
Definition: ERF_SatAdj.H:114
void Update_Micro_Vars(amrex::MultiFab &cons_in) override
Definition: ERF_SatAdj.H:83
amrex::Geometry m_geom
Definition: ERF_SatAdj.H:265
void Qmoist_Restart_Vars(const SolverChoice &, std::vector< int > &a_idx, std::vector< std::string > &a_names) const override
Definition: ERF_SatAdj.H:120
amrex::Array< FabPtr, MicVar_SatAdj::NumVars > mic_fab_vars
Definition: ERF_SatAdj.H:279
amrex::Real m_rdOcp
Definition: ERF_SatAdj.H:275
SatAdj()
Definition: ERF_SatAdj.H:47
virtual ~SatAdj()=default
void Update_State_Vars(amrex::MultiFab &cons_in, const amrex::MultiFab &) override
Definition: ERF_SatAdj.H:90
amrex::MultiFab * Qmoist_Ptr(const int &varIdx) override
Definition: ERF_SatAdj.H:107
void Set_RealWidth(const int real_width) override
Definition: ERF_SatAdj.H:129
int Qstate_Moist_Size() override
Definition: ERF_SatAdj.H:117
std::shared_ptr< amrex::MultiFab > FabPtr
Definition: ERF_SatAdj.H:43
void Copy_Micro_to_State(amrex::MultiFab &cons_in) override
Definition: ERF_UpdateSatAdj.cpp:12
bool m_do_cond
Definition: ERF_SatAdj.H:276
void Init(const amrex::MultiFab &cons_in, const amrex::BoxArray &, const amrex::Geometry &geom, const amrex::Real &dt_advance, std::unique_ptr< amrex::MultiFab > &, std::unique_ptr< amrex::MultiFab > &) override
Definition: ERF_InitSatAdj.cpp:17
void Advance(const amrex::Real &dt_advance, const SolverChoice &solverChoice) override
Definition: ERF_SatAdj.H:98
int m_qmoist_size
Definition: ERF_SatAdj.H:259
void AdvanceSatAdj(const SolverChoice &)
Definition: ERF_SatAdj.cpp:8
amrex::Real dt
Definition: ERF_SatAdj.H:271
void Define(SolverChoice &sc) override
Definition: ERF_SatAdj.H:57
AMREX_GPU_HOST_DEVICE static AMREX_FORCE_INLINE amrex::Real NewtonSolveSatTemperature(const amrex::Real fac_cond, const amrex::Real tabs_old, const amrex::Real pres_mbar, const amrex::Real qv_old, amrex::Real &qsat)
Definition: ERF_SatAdj.H:134
int m_real_width
Definition: ERF_SatAdj.H:268
void Copy_State_to_Micro(const amrex::MultiFab &cons_in) override
Definition: ERF_InitSatAdj.cpp:40
Definition: ERF_SatAdj.H:27
@ theta
Definition: ERF_SatAdj.H:31
@ rho
Definition: ERF_SatAdj.H:30
@ pres
Definition: ERF_SatAdj.H:33
@ NumVars
Definition: ERF_SatAdj.H:37
@ qv
Definition: ERF_SatAdj.H:35
@ tabs
Definition: ERF_SatAdj.H:32
@ qc
Definition: ERF_SatAdj.H:36
Definition: ERF_DataStruct.H:130
amrex::Real rdOcp
Definition: ERF_DataStruct.H:1169
amrex::Real c_p
Definition: ERF_DataStruct.H:1168
bool use_shoc
Definition: ERF_DataStruct.H:1200