5 #ifndef ERF_LAGRANGIANMICROPHYSICS_H
6 #define ERF_LAGRANGIANMICROPHYSICS_H
8 #ifdef ERF_USE_PARTICLES
32 LagrangianMicrophysics () { }
35 ~LagrangianMicrophysics () =
default;
38 LagrangianMicrophysics (
const int& ,
39 const MoistureType& a_model_type )
42 if (a_model_type == MoistureType::SuperDroplets) {
43 SetModel<SuperDropletsMoist>();
44 amrex::Print() <<
"Super-Droplets moisture model!\n";
46 amrex::Abort(
"Unknown Lagrangian moisture model!") ;
51 void Define (
const int& lev,
55 m_moist_model->Define(sc);
59 void Init (
const int& lev,
60 const amrex::MultiFab& cons_in,
61 const amrex::BoxArray& grids,
62 const amrex::Geometry& geom,
64 std::unique_ptr<amrex::MultiFab>& z_phys_nd,
65 std::unique_ptr<amrex::MultiFab>& detJ_cc )
override
68 m_moist_model->Init(cons_in, grids, geom, dt_advance,
71 m_moist_model->InitLevel(lev, cons_in);
77 amrex::MultiFab& cons_in,
78 const amrex::Vector<std::unique_ptr<amrex::MultiFab>>& z_phys_nd )
override
81 m_moist_model->FinishInit( lev, cons_in, z_phys_nd );
90 amrex::Vector<amrex::Vector<amrex::MultiFab>>& a_vars,
91 const amrex::Vector<std::unique_ptr<amrex::MultiFab>>& a_z,
92 const amrex::GpuArray<ERF_BC, AMREX_SPACEDIM*2>& a_phys_bc_types )
override
94 m_moist_model->SetCurrentLevel(lev);
95 m_moist_model->Advance(dt_advance, iter, time, a_vars, a_z, a_phys_bc_types);
100 amrex::MultiFab& cons_in )
override
102 m_moist_model->SetCurrentLevel(lev);
103 m_moist_model->Update_Micro_Vars(cons_in);
108 amrex::MultiFab& cons_in,
109 const amrex::MultiFab& z_phys_nd )
override
111 m_moist_model->SetCurrentLevel(lev);
112 m_moist_model->Update_State_Vars(cons_in, z_phys_nd);
118 m_moist_model->AverageDownMicroVars(finest_level);
123 const int& varIdx )
override
125 m_moist_model->SetCurrentLevel(lev);
126 return m_moist_model->Qmoist_Ptr(varIdx);
132 return m_moist_model->Qmoist_Size();
138 return m_moist_model->Qstate_Moist_Size();
144 return m_moist_model->Qstate_NonMoist_Size();
148 inline void initParticles (
const int a_lev,
149 std::unique_ptr<amrex::MultiFab>& z_phys_nd )
151 m_moist_model->InitParticles(a_lev, z_phys_nd);
155 inline void restartParticles ( amrex::ParGDBBase* a_gdb,
const std::string& a_fname)
157 m_moist_model->RestartParticles(a_gdb, a_fname);
161 inline ERFPC* getParticleContainer ()
const
163 return m_moist_model->getParticleContainer();
167 inline const std::string& getName ()
const
169 return m_moist_model->getName();
176 std::vector<int>& a_idx,
177 std::vector<std::string>& a_names )
const override
180 m_moist_model->Qmoist_Restart_Vars( a_sc, a_idx, a_names );
188 virtual void GetPlotVarNames (amrex::Vector<std::string>& a_vec)
const override
190 m_moist_model->GetPlotVarNames(a_vec);
194 virtual void GetPlotVar (
const std::string& a_name,
195 amrex::MultiFab& a_mf,
196 const int a_lev)
const override
198 m_moist_model->SetCurrentLevel(a_lev);
199 m_moist_model->GetPlotVar(a_name, a_mf, a_lev);
203 inline int getDiagnosticsInterval ()
const
205 return m_moist_model->getDiagnosticsInterval();
212 m_moist_model->Set_dzmin(dz_min);
217 const int real_width)
const override
219 m_moist_model->Set_RealWidth(real_width);
225 template<
class NewMoistModel>
228 m_moist_model = std::make_unique<NewMoistModel>();
231 std::unique_ptr<NullMoistLagrangian> m_moist_model;
Contains the base class for microphysics.
Contains the Lagrangian moisture model base class.
amrex::Real Real
Definition: ERF_ShocInterface.H:19
Base class for microphysics interface.
Definition: ERF_Microphysics.H:15
virtual int Get_Qmoist_Size(const int &)=0
get the number of moisture model variables
virtual int Get_Qstate_NonMoist_Size()=0
get the number of microphysics conserved non-moist (non-water, i.e., other vapor/condensed species) s...
virtual void Define(const int &, SolverChoice &)=0
define the microphysics object
virtual void AverageDownMicroVars(const int)
average down moisture multifabs from finest_level to 0 (AMR coverage); no-op for non-Lagrangian model...
Definition: ERF_Microphysics.H:59
virtual void Init(const int &, const amrex::MultiFab &, const amrex::BoxArray &, const amrex::Geometry &, const amrex::Real &, std::unique_ptr< amrex::MultiFab > &, std::unique_ptr< amrex::MultiFab > &)=0
initialize the microphysics object
virtual int Get_Qstate_Moist_Size()=0
get the number of microphysics conserved moist (water-related) state variables
virtual void Update_Micro_Vars_Lev(const int &, amrex::MultiFab &)=0
update microphysics variables from ERF state variables
virtual void Update_State_Vars_Lev(const int &, amrex::MultiFab &, const amrex::MultiFab &)=0
update ERF state variables from microphysics variables
virtual amrex::MultiFab * Get_Qmoist_Ptr(const int &, const int &)=0
get pointer to a moisture variable
virtual void GetPlotVarNames(amrex::Vector< std::string > &a_vec) const =0
Returns a list of additional plot variable names.
virtual void Get_Qmoist_Restart_Vars(int, const SolverChoice &, std::vector< int > &, std::vector< std::string > &) const =0
get the indices and names of moisture model variables for restart at a given level
virtual void Set_dzmin(const int lev, const amrex::Real dz_min) const =0
Import minimum dz at this level.
static MoistureModelType modelType(const MoistureType a_moisture_type)
query if a specified moisture model is Eulerian or Lagrangian
Definition: ERF_Microphysics.H:103
virtual void FinishInit(const int &, amrex::MultiFab &, const amrex::Vector< std::unique_ptr< amrex::MultiFab >> &)=0
finish initializations steps that require flow variables
virtual void GetPlotVar(const std::string &a_name, amrex::MultiFab &a_mf, const int a_lev) const =0
Fills in a MultiFab for plotting.
virtual void Advance(const int &, const amrex::Real &, const int &, const amrex::Real &, const SolverChoice &, amrex::Vector< amrex::Vector< amrex::MultiFab >> &, const amrex::Vector< std::unique_ptr< amrex::MultiFab >> &, const amrex::GpuArray< ERF_BC, AMREX_SPACEDIM *2 > &)=0
advance microphysics for one time step
virtual void Set_RealWidth(const int lev, const int real_width) const =0
Define the nudging+set width for real BCs.
Definition: ERF_DataStruct.H:130