18 #include <AMReX_FArrayBox.H>
19 #include <AMReX_Geometry.H>
20 #include <AMReX_MultiFabUtil.H>
21 #include <AMReX_GpuContainers.H>
47 using FabPtr = std::shared_ptr<amrex::MultiFab>;
70 Init (
const amrex::MultiFab& cons_in,
71 const amrex::BoxArray& ,
72 const amrex::Geometry& geom,
74 std::unique_ptr<amrex::MultiFab>& ,
75 std::unique_ptr<amrex::MultiFab>& )
override;
95 const amrex::MultiFab& )
override
128 std::vector<int>& a_idx,
129 std::vector<std::string>& a_names)
const override
135 AMREX_GPU_HOST_DEVICE
157 constexpr
int max_niter = 20;
177 fff = -
tabs + tabs_old + fac_cond*(qv_old - qsat);
180 dfff = -
one - fac_cond*dqsat;
188 }
while(std::abs(dtabs) > tol && niter < max_niter);
196 AMREX_GPU_HOST_DEVICE
215 if ((
qv +
qc) > qsat) {
220 #if defined(AMREX_DEBUG)
238 #if defined(AMREX_DEBUG)
241 AMREX_ASSERT(std::abs(
qv-qsatnew) < 1e-12);
242 AMREX_ASSERT(std::abs(
qv+
qc-qvprev-qcprev) < 1e-14);
255 tabs -= fac_cond * delta_qc;
260 #if defined(AMREX_DEBUG)
272 #if defined(AMREX_DEBUG)
275 AMREX_ASSERT(
qv < qvprev);
276 AMREX_ASSERT(
qc > qcprev);
277 AMREX_ASSERT(
tabs > Tprev);
278 AMREX_ASSERT(std::abs(
qv-qsatnew) < 1e-14);
279 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:85
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:45
int n_qstate_moist_size
Definition: ERF_SatAdj.H:292
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:204
amrex::Real m_fac_cond
Definition: ERF_SatAdj.H:304
int Qmoist_Size() override
Definition: ERF_SatAdj.H:118
void Update_Micro_Vars(amrex::MultiFab &cons_in) override
Definition: ERF_SatAdj.H:87
amrex::Geometry m_geom
Definition: ERF_SatAdj.H:298
void Qmoist_Restart_Vars(const SolverChoice &, std::vector< int > &a_idx, std::vector< std::string > &a_names) const override
Definition: ERF_SatAdj.H:127
amrex::Array< FabPtr, MicVar_SatAdj::NumVars > mic_fab_vars
Definition: ERF_SatAdj.H:309
amrex::Real m_rdOcp
Definition: ERF_SatAdj.H:305
SatAdj()
Definition: ERF_SatAdj.H:51
virtual ~SatAdj()=default
void Update_State_Vars(amrex::MultiFab &cons_in, const amrex::MultiFab &) override
Definition: ERF_SatAdj.H:94
amrex::MultiFab * Qmoist_Ptr(const int &varIdx) override
Definition: ERF_SatAdj.H:111
int n_qstate_moist_numconc_size
Definition: ERF_SatAdj.H:295
int Qstate_Moist_NumConc_Size() override
Definition: ERF_SatAdj.H:124
int Qstate_Moist_Size() override
Definition: ERF_SatAdj.H:121
std::shared_ptr< amrex::MultiFab > FabPtr
Definition: ERF_SatAdj.H:47
void Copy_Micro_to_State(amrex::MultiFab &cons_in) override
Definition: ERF_UpdateSatAdj.cpp:13
bool m_do_cond
Definition: ERF_SatAdj.H:306
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:102
int m_qmoist_size
Definition: ERF_SatAdj.H:289
void AdvanceSatAdj(const SolverChoice &)
Definition: ERF_SatAdj.cpp:11
amrex::Real dt
Definition: ERF_SatAdj.H:301
void Define(SolverChoice &sc) override
Definition: ERF_SatAdj.H:61
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:150
void Copy_State_to_Micro(const amrex::MultiFab &cons_in) override
Definition: ERF_InitSatAdj.cpp:44
Definition: ERF_SatAdj.H:31
@ theta
Definition: ERF_SatAdj.H:35
@ rho
Definition: ERF_SatAdj.H:34
@ pres
Definition: ERF_SatAdj.H:37
@ NumVars
Definition: ERF_SatAdj.H:41
@ qv
Definition: ERF_SatAdj.H:39
@ tabs
Definition: ERF_SatAdj.H:36
@ qc
Definition: ERF_SatAdj.H:40
Definition: ERF_DataStruct.H:141
amrex::Real rdOcp
Definition: ERF_DataStruct.H:1222
amrex::Real c_p
Definition: ERF_DataStruct.H:1221
bool use_shoc
Definition: ERF_DataStruct.H:1253