ERF
Energy Research and Forecasting: An Atmospheric Modeling Code
ERF_EulerianMicrophysics.H
Go to the documentation of this file.
1 /*! @file ERF_EulerianMicrophysics.H
2  * \brief Contains the Eulerian microphysics class
3  */
4 
5 #ifndef ERF_EULERIANMICROPHYSICS_H
6 #define ERF_EULERIANMICROPHYSICS_H
7 
8 #include "ERF_NullMoist.H"
9 #include "ERF_SAM.H"
10 #include "ERF_Kessler.H"
11 #include "ERF_Morrison.H"
12 #include "ERF_WSM6.H"
13 #include "ERF_SatAdj.H"
15 #include "ERF_Microphysics.H"
16 
17 /*! \brief Eulerian microphysics interface */
19 
20 public:
21 
22  /*! \brief Null constructor */
24 
25  /*! \brief default destructor */
26  ~EulerianMicrophysics () = default;
27 
28  /*! \brief Constructor: create the moisture model */
29  EulerianMicrophysics (const int& nlev, /*!< Number of AMR levels */
30  const MoistureType& a_model_type /*!< moisture model */)
31  {
32  AMREX_ASSERT( Microphysics::modelType(a_model_type) == MoistureModelType::Eulerian );
33  m_moist_model.resize(nlev);
34  if (a_model_type == MoistureType::SAM ||
35  a_model_type == MoistureType::SAM_NoIce ||
36  a_model_type == MoistureType::SAM_NoPrecip_NoIce) {
37  SetModel<SAM>();
38  } else if (a_model_type == MoistureType::Kessler ||
39  a_model_type == MoistureType::Kessler_NoRain) {
40  SetModel<Kessler>();
41  } else if (a_model_type == MoistureType::Morrison ||
42  a_model_type == MoistureType::Morrison_NoIce) {
43  SetModel<Morrison>();
44  } else if (a_model_type == MoistureType::WSM6) {
45  SetModel<WSM6>();
46  } else if (a_model_type == MoistureType::SatAdj) {
47  SetModel<SatAdj>();
48  } else if (a_model_type == MoistureType::MoistNoCondensation) {
49  SetModel<MoistNoCondensation>();
50  } else if (a_model_type == MoistureType::None) {
51  SetModel<NullMoist>();
52  } else {
53  amrex::Abort("EulerianMicrophysics: Dont know this moisture_type!") ;
54  }
55  }
56 
57  /*! \brief Define the moisture model */
58  void Define (const int& lev, /*!< AMR level */
59  SolverChoice& sc /*!< Solver choice object */) override
60  {
61  m_moist_model[lev]->Define(sc);
62  }
63 
64  /*! \brief Initialize the moisture model */
65  void Init (const int& lev, /*!< AMR level */
66  const amrex::MultiFab& cons_in, /*!< Conserved state variables */
67  const amrex::BoxArray& grids, /*!< Grids */
68  const amrex::Geometry& geom, /*!< Geometry */
69  const amrex::Real& dt_advance, /*!< Time step */
70  std::unique_ptr<amrex::MultiFab>& z_phys_nd, /*< Nodal z heights */
71  std::unique_ptr<amrex::MultiFab>& detJ_cc /*< CC Jacobian determinants */) override
72  {
73  m_moist_model[lev]->Init(cons_in, grids, geom, dt_advance,
74  z_phys_nd, detJ_cc);
75  }
76 
77  /*! \brief finish initializations steps that require flow variables */
78  virtual void FinishInit (const int&,
79  amrex::MultiFab&,
80  const amrex::Vector<std::unique_ptr<amrex::MultiFab>>& ) override { }
81 
82  /*! \brief Advance the moisture model for one time step */
83  void Advance (const int& lev, /*!< AMR level */
84  const amrex::Real& dt_advance, /*!< Time step */
85  const int&, /*!< iteration number */
86  const amrex::Real&, /*!< current time */
87  const SolverChoice &solverChoice, /*!< Solver choice object */
88  amrex::Vector<amrex::Vector<amrex::MultiFab>>&, /*!< Dycore state variables */
89  const amrex::Vector<std::unique_ptr<amrex::MultiFab>>&, /*!< terrain */
90  const amrex::GpuArray<ERF_BC, AMREX_SPACEDIM*2>& ) override
91  {
92  m_moist_model[lev]->Advance(dt_advance, solverChoice);
93  }
94 
95  /*! \brief update microphysics variables from ERF state variables */
96  void Update_Micro_Vars_Lev (const int& lev, /*! AMR level */
97  amrex::MultiFab& cons_in /*!< Conserved state variables */) override
98  {
99  m_moist_model[lev]->Update_Micro_Vars(cons_in);
100  }
101 
102  /*! \brief update ERF state variables from microphysics variables */
103  void Update_State_Vars_Lev (const int& lev, /*!< AMR level */
104  amrex::MultiFab& cons_in, /*!< Conserved state variables */
105  const amrex::MultiFab& z_phys_nd /*!< Nodal terrain heights */) override
106  {
107  m_moist_model[lev]->Update_State_Vars(cons_in, z_phys_nd);
108  }
109 
110  /*! \brief get pointer to a moisture variable */
111  amrex::MultiFab* Get_Qmoist_Ptr (const int& lev, /*!< AMR level */
112  const int& varIdx /*!< moisture variable index */) override
113  {
114  return m_moist_model[lev]->Qmoist_Ptr(varIdx);
115  }
116 
117  /*! \brief get the number of moisture model variables */
118  int Get_Qmoist_Size (const int& /* lev */) override
119  {
120  return m_moist_model[0]->Qmoist_Size();
121  }
122 
123  /*! \brief get the number of microphysics conserved moist (water-related) state variables */
124  int Get_Qstate_Moist_Size () override
125  {
126  return m_moist_model[0]->Qstate_Moist_Size();
127  }
128 
129  /*! \brief get the number of microphysics conserved moist (water-related) state variables that are number concentrations */
131  {
132  return m_moist_model[0]->Qstate_Moist_NumConc_Size();
133  }
134 
135  /*! \brief get the number of microphysics conserved non-moist (non-water, i.e., other vapor/condensed species) state variables */
136  int Get_Qstate_NonMoist_Size () override
137  {
138  return m_moist_model[0]->Qstate_NonMoist_Size();
139  }
140 
141  /*! \brief get the indices and names of moisture model variables for restart
142  at a given level */
143  void Get_Qmoist_Restart_Vars (const int a_lev, /*!< level */
144  const SolverChoice& a_sc, /*!< Solver choice object */
145  std::vector<int>& a_idx, /*!< indices */
146  std::vector<std::string>& a_names /*!< names */ ) const override
147  {
148  m_moist_model[a_lev]->Qmoist_Restart_Vars(a_sc, a_idx, a_names);
149  }
150 
151  /*! \brief Returns a list of additional plot variable names */
152  virtual void GetPlotVarNames (amrex::Vector<std::string>& a_vec) const override
153  {
154  m_moist_model[0]->GetPlotVarNames(a_vec);
155  }
156 
157  /*! \brief Fills in a MultiFab for plotting */
158  virtual void GetPlotVar (const std::string& a_name,
159  amrex::MultiFab& a_mf,
160  const int a_lev) const override
161  {
162  m_moist_model[a_lev]->GetPlotVar(a_name, a_mf);
163  }
164 
165  /*! \brief Populates dz_min in micro model for precipitation */
166  virtual void Set_dzmin (const int a_lev,
167  const amrex::Real dz_min) const override
168  {
169  m_moist_model[a_lev]->Set_dzmin(dz_min);
170  }
171 
172 protected:
173 
174  /*! \brief Create and set the specified moisture model */
175  template<class NewMoistModel>
176  void SetModel ()
177  {
178  for (int lev(0); lev<m_moist_model.size(); ++lev) {
179  m_moist_model[lev] = std::make_unique<NewMoistModel>();
180  }
181  }
182 
183 private:
184  amrex::Vector<std::unique_ptr<NullMoist>> m_moist_model; /*!< moisture model */
185 };
186 #endif
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