ERF
Energy Research and Forecasting: An Atmospheric Modeling Code
ERF_Microphysics.H
Go to the documentation of this file.
1 /*! @file ERF_Microphysics.H
2  * \brief Contains the base class for microphysics
3  */
4 
5 #ifndef ERF_MICROPHYSICS_H
6 #define ERF_MICROPHYSICS_H
7 
8 #include <vector>
9 #include <string>
10 #include <AMReX_MultiFab.H>
11 #include "ERF_DataStruct.H"
12 #include "ERF_IndexDefines.H"
13 
14 /*! \brief Base class for microphysics interface */
15 class Microphysics {
16 
17 public:
18 
19  /*! \brief Null constructor */
20  Microphysics () { }
21 
22  /*! \brief default destructor */
23  virtual ~Microphysics () = default;
24 
25  /*! \brief define the microphysics object */
26  virtual void Define (const int&, SolverChoice&) = 0;
27 
28  /*! \brief initialize the microphysics object */
29  virtual void Init (const int&,
30  const amrex::MultiFab&,
31  const amrex::BoxArray&,
32  const amrex::Geometry&,
33  const amrex::Real&,
34  std::unique_ptr<amrex::MultiFab>&,
35  std::unique_ptr<amrex::MultiFab>&) = 0;
36 
37  /*! \brief finish initializations steps that require flow variables */
38  virtual void FinishInit (const int&,
39  amrex::MultiFab&,
40  const amrex::Vector<std::unique_ptr<amrex::MultiFab>>& ) = 0;
41 
42  /*! \brief advance microphysics for one time step */
43  virtual void Advance (const int&,
44  const amrex::Real&,
45  const int&,
46  const amrex::Real&,
47  const SolverChoice&,
48  amrex::Vector<amrex::Vector<amrex::MultiFab>>&,
49  const amrex::Vector<std::unique_ptr<amrex::MultiFab>>&,
50  const amrex::GpuArray<ERF_BC, AMREX_SPACEDIM*2>& ) = 0;
51 
52  /*! \brief update microphysics variables from ERF state variables */
53  virtual void Update_Micro_Vars_Lev (const int&, amrex::MultiFab&) = 0;
54 
55  /*! \brief update ERF state variables from microphysics variables */
56  virtual void Update_State_Vars_Lev (const int&, amrex::MultiFab&, const amrex::MultiFab&) = 0;
57 
58  /*! \brief average down moisture multifabs from finest_level to 0 (AMR coverage); no-op for non-Lagrangian models */
59  virtual void AverageDownMicroVars (const int /*finest_level*/) { }
60 
61  /*! \brief get pointer to a moisture variable */
62  virtual amrex::MultiFab* Get_Qmoist_Ptr (const int&, const int&) = 0;
63 
64  /*! \brief get the number of moisture model variables */
65  virtual int Get_Qmoist_Size (const int&) = 0;
66 
67  /*! \brief get the number of microphysics conserved moist (water-related) state variables */
68  virtual int Get_Qstate_Moist_Size () = 0;
69 
70  /*! \brief get the number of microphysics conserved non-moist (non-water, i.e., other vapor/condensed species) state variables */
71  virtual int Get_Qstate_NonMoist_Size () = 0;
72 
73  /*! \brief get total number of conserved state variables */
74  inline int Get_Qstate_Size()
75  {
77  }
78 
79  /*! \brief get the indices and names of moisture model variables for restart
80  at a given level */
81  virtual void Get_Qmoist_Restart_Vars (int,
82  const SolverChoice&,
83  std::vector<int>&,
84  std::vector<std::string>& ) const = 0;
85 
86  /*! \brief Returns a list of additional plot variable names */
87  virtual void GetPlotVarNames (amrex::Vector<std::string>& a_vec) const = 0;
88 
89  /*! \brief Fills in a MultiFab for plotting */
90  virtual void GetPlotVar (const std::string& a_name,
91  amrex::MultiFab& a_mf,
92  const int a_lev) const = 0;
93 
94  /*! \brief Import minimum dz at this level */
95  virtual void Set_dzmin (const int lev,
96  const amrex::Real dz_min) const = 0;
97 
98  /*! \brief Define the nudging+set width for real BCs */
99  virtual void Set_RealWidth (const int lev,
100  const int real_width) const = 0;
101 
102  /*! \brief query if a specified moisture model is Eulerian or Lagrangian */
103  static MoistureModelType modelType (const MoistureType a_moisture_type)
104  {
105  if ( (a_moisture_type == MoistureType::SAM)
106  || (a_moisture_type == MoistureType::SAM_NoIce)
107  || (a_moisture_type == MoistureType::SAM_NoPrecip_NoIce)
108  || (a_moisture_type == MoistureType::Morrison)
109  || (a_moisture_type == MoistureType::Morrison_NoIce)
110  || (a_moisture_type == MoistureType::WSM6)
111  || (a_moisture_type == MoistureType::Kessler)
112  || (a_moisture_type == MoistureType::Kessler_NoRain)
113  || (a_moisture_type == MoistureType::SatAdj)
114  || (a_moisture_type == MoistureType::None) ) {
115  return MoistureModelType::Eulerian;
116  } else if ( (a_moisture_type == MoistureType::SuperDroplets) ) {
117  return MoistureModelType::Lagrangian;
118  } else {
119  amrex::Abort("Dont know this moisture_type!") ;
120  return MoistureModelType::Undefined;
121  }
122  }
123 private:
124 
125 };
126 #endif
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 ~Microphysics()=default
default destructor
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
Microphysics()
Null constructor.
Definition: ERF_Microphysics.H:20
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
int Get_Qstate_Size()
get total number of conserved state variables
Definition: ERF_Microphysics.H:74
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