8 #include <AMReX_FArrayBox.H>
9 #include <AMReX_Geometry.H>
10 #include <AMReX_TableData.H>
11 #include <AMReX_MultiFabUtil.H>
41 using FabPtr = std::shared_ptr<amrex::MultiFab>;
65 Init (
const amrex::MultiFab& cons_in,
66 const amrex::BoxArray& grids,
67 const amrex::Geometry& geom,
69 std::unique_ptr<amrex::MultiFab>& z_phys_nd,
70 std::unique_ptr<amrex::MultiFab>& detJ_cc)
override;
97 const amrex::MultiFab& )
override
130 std::vector<int>& a_idx,
131 std::vector<std::string>& a_names)
const override
137 a_idx.push_back(0); a_names.push_back(
"RainAccum");
constexpr amrex::Real L_v
Definition: ERF_Constants.H:35
AMREX_ALWAYS_ASSERT(bx.length()[2]==khi+1)
static constexpr amrex::Real kessler_sedimentation_cfl_max
Definition: ERF_KesslerUtils.H:31
amrex::Real Real
Definition: ERF_ShocInterface.H:19
Definition: ERF_Kessler.H:39
int zlo
Definition: ERF_Kessler.H:166
void Update_Micro_Vars(amrex::MultiFab &cons_in) override
Definition: ERF_Kessler.H:89
amrex::MultiFab * Qmoist_Ptr(const int &varIdx) override
Definition: ERF_Kessler.H:113
amrex::Vector< int > MicVarMap
Definition: ERF_Kessler.H:154
void Copy_State_to_Micro(const amrex::MultiFab &cons_in) override
Definition: ERF_InitKessler.cpp:63
void Qmoist_Restart_Vars(const SolverChoice &, std::vector< int > &a_idx, std::vector< std::string > &a_names) const override
Definition: ERF_Kessler.H:129
void Set_dzmin(const amrex::Real dz_min) override
Definition: ERF_Kessler.H:74
int Qmoist_Size() override
Definition: ERF_Kessler.H:120
int n_qstate_moist_size
Definition: ERF_Kessler.H:145
virtual ~Kessler()=default
amrex::Geometry m_geom
Definition: ERF_Kessler.H:157
Kessler()
Definition: ERF_Kessler.H:45
amrex::MultiFab * m_detJ_cc
Definition: ERF_Kessler.H:174
void Define(SolverChoice &sc) override
Definition: ERF_Kessler.H:55
amrex::Real m_dzmin
Definition: ERF_Kessler.H:163
void Update_State_Vars(amrex::MultiFab &cons_in, const amrex::MultiFab &) override
Definition: ERF_Kessler.H:96
int Qstate_Moist_Size() override
Definition: ERF_Kessler.H:123
amrex::Real m_fac_cond
Definition: ERF_Kessler.H:169
void Copy_Micro_to_State(amrex::MultiFab &cons_in) override
Definition: ERF_UpdateKessler.cpp:14
amrex::Real dt
Definition: ERF_Kessler.H:160
int zhi
Definition: ERF_Kessler.H:166
int nlev
Definition: ERF_Kessler.H:166
bool m_do_cond
Definition: ERF_Kessler.H:170
amrex::Array< FabPtr, MicVar_Kess::NumVars > mic_fab_vars
Definition: ERF_Kessler.H:177
amrex::MultiFab * m_z_phys_nd
Definition: ERF_Kessler.H:173
void Init(const amrex::MultiFab &cons_in, const amrex::BoxArray &grids, const amrex::Geometry &geom, const amrex::Real &dt_advance, std::unique_ptr< amrex::MultiFab > &z_phys_nd, std::unique_ptr< amrex::MultiFab > &detJ_cc) override
Definition: ERF_InitKessler.cpp:21
static constexpr amrex::Real CFL_MAX
Definition: ERF_Kessler.H:151
void AdvanceKessler(const SolverChoice &solverChoice)
Definition: ERF_Kessler.cpp:14
std::shared_ptr< amrex::MultiFab > FabPtr
Definition: ERF_Kessler.H:41
void Advance(const amrex::Real &dt_advance, const SolverChoice &solverChoice) override
Definition: ERF_Kessler.H:104
int Qstate_Moist_NumConc_Size() override
Definition: ERF_Kessler.H:126
int m_qmoist_size
Definition: ERF_Kessler.H:142
int n_qstate_moist_numconc_size
Definition: ERF_Kessler.H:148
Definition: ERF_NullMoist.H:8
Definition: ERF_Kessler.H:20
@ qp
Definition: ERF_Kessler.H:32
@ qcl
Definition: ERF_Kessler.H:30
@ tabs
Definition: ERF_Kessler.H:25
@ pres
Definition: ERF_Kessler.H:26
@ rho
Definition: ERF_Kessler.H:23
@ theta
Definition: ERF_Kessler.H:24
@ qt
Definition: ERF_Kessler.H:28
@ rain_accum
Definition: ERF_Kessler.H:34
@ NumVars
Definition: ERF_Kessler.H:35
@ qv
Definition: ERF_Kessler.H:29
Definition: ERF_DataStruct.H:141
amrex::Real c_p
Definition: ERF_DataStruct.H:1221
bool use_shoc
Definition: ERF_DataStruct.H:1253