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;
120 std::vector<int>& a_idx,
121 std::vector<std::string>& a_names)
const override
127 AMREX_GPU_HOST_DEVICE
132 const amrex::Array4<amrex::Real>& tabs_array,
133 const amrex::Array4<amrex::Real>& pres_array,
134 const amrex::Array4<amrex::Real>& qv_array,
135 const amrex::Array4<amrex::Real>& qc_array)
165 fff = -
tabs + tabs_array(i,j,k) + fac_cond*(qv_array(i,j,k) - qsat);
168 dfff = -1.0 - fac_cond*dqsat;
176 }
while(std::abs(dtabs) > tol && niter < 20);
182 delta_qv = qv_array(i,j,k) - qsat;
185 qv_array(i,j,k) = qsat;
186 qc_array(i,j,k) += delta_qv;
constexpr amrex::Real lcond
Definition: ERF_Constants.H:66
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE void erf_dtqsatw(amrex::Real t, amrex::Real p, amrex::Real &dtqsatw)
Definition: ERF_MicrophysicsUtils.H:181
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE void erf_qsatw(amrex::Real t, amrex::Real p, amrex::Real &qsatw)
Definition: ERF_MicrophysicsUtils.H:166
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:197
amrex::Real m_fac_cond
Definition: ERF_SatAdj.H:206
int Qmoist_Size() override
Definition: ERF_SatAdj.H:113
void Update_Micro_Vars(amrex::MultiFab &cons_in) override
Definition: ERF_SatAdj.H:83
amrex::Geometry m_geom
Definition: ERF_SatAdj.H:200
void Qmoist_Restart_Vars(const SolverChoice &, std::vector< int > &a_idx, std::vector< std::string > &a_names) const override
Definition: ERF_SatAdj.H:119
amrex::Array< FabPtr, MicVar_SatAdj::NumVars > mic_fab_vars
Definition: ERF_SatAdj.H:211
amrex::Real m_rdOcp
Definition: ERF_SatAdj.H:207
SatAdj()
Definition: ERF_SatAdj.H:47
virtual ~SatAdj()=default
amrex::MultiFab * Qmoist_Ptr(const int &varIdx) override
Definition: ERF_SatAdj.H:106
AMREX_GPU_HOST_DEVICE static AMREX_FORCE_INLINE amrex::Real NewtonIterSat(int &i, int &j, int &k, const amrex::Real &fac_cond, const amrex::Array4< amrex::Real > &tabs_array, const amrex::Array4< amrex::Real > &pres_array, const amrex::Array4< amrex::Real > &qv_array, const amrex::Array4< amrex::Real > &qc_array)
Definition: ERF_SatAdj.H:130
int Qstate_Moist_Size() override
Definition: ERF_SatAdj.H:116
std::shared_ptr< amrex::MultiFab > FabPtr
Definition: ERF_SatAdj.H:43
void Update_State_Vars(amrex::MultiFab &cons_in) override
Definition: ERF_SatAdj.H:90
void Copy_Micro_to_State(amrex::MultiFab &cons_in) override
Definition: ERF_UpdateSatAdj.cpp:12
bool m_do_cond
Definition: ERF_SatAdj.H:208
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:97
int m_qmoist_size
Definition: ERF_SatAdj.H:194
void AdvanceSatAdj(const SolverChoice &)
Definition: ERF_SatAdj.cpp:8
amrex::Real dt
Definition: ERF_SatAdj.H:203
void Define(SolverChoice &sc) override
Definition: ERF_SatAdj.H:57
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:123
amrex::Real rdOcp
Definition: ERF_DataStruct.H:913
amrex::Real c_p
Definition: ERF_DataStruct.H:912
bool use_shoc
Definition: ERF_DataStruct.H:942