5 #ifndef ERF_EULERIANMICROPHYSICS_H
6 #define ERF_EULERIANMICROPHYSICS_H
30 const MoistureType& a_model_type )
34 if (a_model_type == MoistureType::SAM ||
35 a_model_type == MoistureType::SAM_NoIce ||
36 a_model_type == MoistureType::SAM_NoPrecip_NoIce) {
38 }
else if (a_model_type == MoistureType::Kessler ||
39 a_model_type == MoistureType::Kessler_NoRain) {
41 }
else if (a_model_type == MoistureType::Morrison ||
42 a_model_type == MoistureType::Morrison_NoIce) {
44 }
else if (a_model_type == MoistureType::WSM6) {
46 }
else if (a_model_type == MoistureType::SatAdj) {
48 }
else if (a_model_type == MoistureType::MoistNoCondensation) {
49 SetModel<MoistNoCondensation>();
50 }
else if (a_model_type == MoistureType::None) {
51 SetModel<NullMoist>();
53 amrex::Abort(
"EulerianMicrophysics: Dont know this moisture_type!") ;
66 const amrex::MultiFab& cons_in,
67 const amrex::BoxArray& grids,
68 const amrex::Geometry& geom,
70 std::unique_ptr<amrex::MultiFab>& z_phys_nd,
71 std::unique_ptr<amrex::MultiFab>& detJ_cc )
override
80 const amrex::Vector<std::unique_ptr<amrex::MultiFab>>& )
override { }
88 amrex::Vector<amrex::Vector<amrex::MultiFab>>&,
89 const amrex::Vector<std::unique_ptr<amrex::MultiFab>>&,
90 const amrex::GpuArray<ERF_BC, AMREX_SPACEDIM*2>& )
override
97 amrex::MultiFab& cons_in )
override
104 amrex::MultiFab& cons_in,
105 const amrex::MultiFab& z_phys_nd )
override
112 const int& varIdx )
override
145 std::vector<int>& a_idx,
146 std::vector<std::string>& a_names )
const override
148 m_moist_model[a_lev]->Qmoist_Restart_Vars(a_sc, a_idx, a_names);
159 amrex::MultiFab& a_mf,
160 const int a_lev)
const override
175 template<
class NewMoistModel>
Contains the base class for microphysics.
amrex::Real Real
Definition: ERF_ShocInterface.H:19
Eulerian microphysics interface.
Definition: ERF_EulerianMicrophysics.H:18
void Get_Qmoist_Restart_Vars(const int a_lev, const SolverChoice &a_sc, std::vector< int > &a_idx, std::vector< std::string > &a_names) const override
get the indices and names of moisture model variables for restart at a given level
Definition: ERF_EulerianMicrophysics.H:143
virtual void Set_dzmin(const int a_lev, const amrex::Real dz_min) const override
Populates dz_min in micro model for precipitation.
Definition: ERF_EulerianMicrophysics.H:166
void Update_Micro_Vars_Lev(const int &lev, amrex::MultiFab &cons_in) override
update microphysics variables from ERF state variables
Definition: ERF_EulerianMicrophysics.H:96
void Update_State_Vars_Lev(const int &lev, amrex::MultiFab &cons_in, const amrex::MultiFab &z_phys_nd) override
update ERF state variables from microphysics variables
Definition: ERF_EulerianMicrophysics.H:103
EulerianMicrophysics(const int &nlev, const MoistureType &a_model_type)
Constructor: create the moisture model.
Definition: ERF_EulerianMicrophysics.H:29
~EulerianMicrophysics()=default
default destructor
amrex::Vector< std::unique_ptr< NullMoist > > m_moist_model
Definition: ERF_EulerianMicrophysics.H:184
amrex::MultiFab * Get_Qmoist_Ptr(const int &lev, const int &varIdx) override
get pointer to a moisture variable
Definition: ERF_EulerianMicrophysics.H:111
void Define(const int &lev, SolverChoice &sc) override
Define the moisture model.
Definition: ERF_EulerianMicrophysics.H:58
int Get_Qstate_NonMoist_Size() override
get the number of microphysics conserved non-moist (non-water, i.e., other vapor/condensed species) s...
Definition: ERF_EulerianMicrophysics.H:136
int Get_Qstate_Moist_NumConc_Size() override
get the number of microphysics conserved moist (water-related) state variables that are number concen...
Definition: ERF_EulerianMicrophysics.H:130
virtual void GetPlotVar(const std::string &a_name, amrex::MultiFab &a_mf, const int a_lev) const override
Fills in a MultiFab for plotting.
Definition: ERF_EulerianMicrophysics.H:158
void SetModel()
Create and set the specified moisture model.
Definition: ERF_EulerianMicrophysics.H:176
virtual void GetPlotVarNames(amrex::Vector< std::string > &a_vec) const override
Returns a list of additional plot variable names.
Definition: ERF_EulerianMicrophysics.H:152
virtual void FinishInit(const int &, amrex::MultiFab &, const amrex::Vector< std::unique_ptr< amrex::MultiFab >> &) override
finish initializations steps that require flow variables
Definition: ERF_EulerianMicrophysics.H:78
void Advance(const int &lev, const amrex::Real &dt_advance, const int &, const amrex::Real &, const SolverChoice &solverChoice, amrex::Vector< amrex::Vector< amrex::MultiFab >> &, const amrex::Vector< std::unique_ptr< amrex::MultiFab >> &, const amrex::GpuArray< ERF_BC, AMREX_SPACEDIM *2 > &) override
Advance the moisture model for one time step.
Definition: ERF_EulerianMicrophysics.H:83
void Init(const int &lev, 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
Initialize the moisture model.
Definition: ERF_EulerianMicrophysics.H:65
int Get_Qmoist_Size(const int &) override
get the number of moisture model variables
Definition: ERF_EulerianMicrophysics.H:118
int Get_Qstate_Moist_Size() override
get the number of microphysics conserved moist (water-related) state variables
Definition: ERF_EulerianMicrophysics.H:124
EulerianMicrophysics()
Null constructor.
Definition: ERF_EulerianMicrophysics.H:23
Base class for microphysics interface.
Definition: ERF_Microphysics.H:15
static MoistureModelType modelType(const MoistureType a_moisture_type)
query if a specified moisture model is Eulerian or Lagrangian
Definition: ERF_Microphysics.H:102
Definition: ERF_DataStruct.H:141