ERF
Energy Research and Forecasting: An Atmospheric Modeling Code
ERF_Morrison.H
Go to the documentation of this file.
1 /*
2  * Implementation of a 2-moment microphysics model
3  * This model is based on the Morrison model as implemented in WRF (in Fortran)
4  */
5 #ifndef ERF_Morrison_H
6 #define ERF_Morrison_H
7 
8 #include <string>
9 #include <vector>
10 #include <memory>
11 
12 #include <AMReX_FArrayBox.H>
13 #include <AMReX_Geometry.H>
14 #include <AMReX_TableData.H>
15 #include <AMReX_MultiFabUtil.H>
16 
17 #include "ERF_Constants.H"
18 #include "ERF_MicrophysicsUtils.H"
19 #include "ERF_IndexDefines.H"
20 #include "ERF_DataStruct.H"
21 #include "ERF_NullMoist.H"
23 
24 namespace MicVar_Morr {
25  enum {
26  // independent variables
27  rho=0, // density
28  theta, // liquid/ice water potential temperature
29  tabs, // temperature
30  pres, // pressure
31  // non-precipitating vars
32  qt, // total cloud
33  qn, // cloud condensate (liquid + ice)
34  qv, // cloud vapor
35  qcl, // cloud water
36  qci, // cloud ice
37  // precipitating vars
38  qp, // total precip
39  qpr, // precip rain
40  qps, // precip ice
41  qpg, // graupel
42  // The "numbers" and the "accums" are written/read at checkpoint/restart
43  // number concentrations
44  nc, // cloud droplet number
45  nr, // rain number
46  ni, // cloud ice number
47  ns, // snow number
48  ng, // graupel number
49  // derived vars
54  NumVars
55  };
56 }
57 
58 class Morrison : public NullMoist {
59 
60  using FabPtr = std::shared_ptr<amrex::MultiFab>;
61 
62 public:
63  // constructor
64  Morrison () {}
65 
66  // destructor
67  virtual ~Morrison () = default;
68 
69  // Set up for first time
70  void
71  Define (SolverChoice& sc) override
72  {
73  m_rdOcp = sc.rdOcp;
74  m_do_cond = (!sc.use_shoc);
75  }
76 
77  // init
78  void
79  Init (const amrex::MultiFab& cons_in,
80  const amrex::BoxArray& grids,
81  const amrex::Geometry& geom,
82  const amrex::Real& dt_advance,
83  std::unique_ptr<amrex::MultiFab>& z_phys_nd,
84  std::unique_ptr<amrex::MultiFab>& detJ_cc) override;
85 
86  // Import minimum dz at this level
87  void
88  Set_dzmin (const amrex::Real dz_min) override
89  {
90  m_dzmin = dz_min;
91  }
92 
93  // Copy state into micro vars
94  void
95  Copy_State_to_Micro (const amrex::MultiFab& cons_in) override;
96 
97  // Copy state into micro vars
98  void
99  Copy_Micro_to_State (amrex::MultiFab& cons_in) override;
100 
101  void
102  Update_Micro_Vars (amrex::MultiFab& cons_in) override
103  {
104  this->Copy_State_to_Micro(cons_in);
105  }
106 
107  void
108  Update_State_Vars (amrex::MultiFab& cons_in,
109  const amrex::MultiFab& /*z_phys_nd*/) override
110  {
111  this->Copy_Micro_to_State(cons_in);
112  }
113 
114  // wrapper to do all the updating
115  void
116  Advance (const amrex::Real& dt_advance,
117  const SolverChoice& sc) override;
118 
119  amrex::MultiFab*
120  Qmoist_Ptr (const int& varIdx) override
121  {
123  return mic_fab_vars[MicVarMap[varIdx]].get();
124  }
125 
126  int
127  Qmoist_Size () override { return Morrison::m_qmoist_size; }
128 
129  int
131 
132  int
134 
135  void
137  std::vector<int>& a_idx,
138  std::vector<std::string>& a_names) const override
139  {
140  a_idx.clear();
141  a_names.clear();
142 
143  // The ordering here needs to match that in
144  // MicVarMap = {MicVar_Morr::rain_accum, MicVar_Morr::snow_accum, MicVar_Morr::graup_accum};
145  //
146  a_idx.push_back(0); a_names.push_back("RainAccum");
147  a_idx.push_back(1); a_names.push_back("SnowAccum");
148  a_idx.push_back(2); a_names.push_back("GraupAccum");
149  }
150 
151  void
152  GetPlotVarNames (amrex::Vector<std::string>& a_vec) const override;
153 
154  void
155  GetPlotVar (const std::string& a_name,
156  amrex::MultiFab& a_mf) const override;
157 
158  void
159  GetPlotVar (const std::string& a_name,
160  amrex::MultiFab& a_mf,
161  const int /*a_lev*/) const override
162  {
163  GetPlotVar(a_name, a_mf);
164  }
165 
166 private:
167  // Number of qmoist variables (rain_accum, snow_accum, graup_accum)
168  int m_qmoist_size = 3;
169 
170  // Number of qstate variables
172 
173  // Number of qstate variables that are number concentrations
175 
176  // MicVar map (Qmoist indices -> MicVar enum)
177  amrex::Vector<int> MicVarMap;
178 
179  // geometry
180  amrex::Geometry m_geom;
181 
182  // constants
184  bool m_do_cond;
185 
186  // Minimum dz at this level
188 
189  // Pointer to terrain data
190  amrex::MultiFab* m_z_phys_nd;
191  amrex::MultiFab* m_detJ_cc;
192 
193  // independent variables
194  amrex::Array<FabPtr, MicVar_Morr::NumVars> mic_fab_vars;
195 };
196 #endif
AMREX_ALWAYS_ASSERT(bx.length()[2]==khi+1)
amrex::Real Real
Definition: ERF_ShocInterface.H:19
Definition: ERF_Morrison.H:58
virtual ~Morrison()=default
amrex::Geometry m_geom
Definition: ERF_Morrison.H:180
Morrison()
Definition: ERF_Morrison.H:64
void Advance(const amrex::Real &dt_advance, const SolverChoice &sc) override
Definition: ERF_AdvanceMorrison.cpp:164
void GetPlotVarNames(amrex::Vector< std::string > &a_vec) const override
Populate a vector with names of all available Morrison plot variables.
Definition: ERF_Morrison_Plot.cpp:101
void Qmoist_Restart_Vars(const SolverChoice &, std::vector< int > &a_idx, std::vector< std::string > &a_names) const override
Definition: ERF_Morrison.H:136
int Qstate_Moist_Size() override
Definition: ERF_Morrison.H:130
int n_qstate_moist_size
Definition: ERF_Morrison.H:171
void Update_Micro_Vars(amrex::MultiFab &cons_in) override
Definition: ERF_Morrison.H:102
void GetPlotVar(const std::string &a_name, amrex::MultiFab &a_mf, const int) const override
Definition: ERF_Morrison.H:159
void Update_State_Vars(amrex::MultiFab &cons_in, const amrex::MultiFab &) override
Definition: ERF_Morrison.H:108
int Qstate_Moist_NumConc_Size() override
Definition: ERF_Morrison.H:133
void Set_dzmin(const amrex::Real dz_min) override
Definition: ERF_Morrison.H:88
void Copy_State_to_Micro(const amrex::MultiFab &cons_in) override
Definition: ERF_InitMorrison.cpp:73
amrex::Real m_dzmin
Definition: ERF_Morrison.H:187
amrex::Vector< int > MicVarMap
Definition: ERF_Morrison.H:177
amrex::MultiFab * Qmoist_Ptr(const int &varIdx) override
Definition: ERF_Morrison.H:120
amrex::MultiFab * m_z_phys_nd
Definition: ERF_Morrison.H:190
void Copy_Micro_to_State(amrex::MultiFab &cons_in) override
Definition: ERF_UpdateMorrison.cpp:17
void Define(SolverChoice &sc) override
Definition: ERF_Morrison.H:71
amrex::MultiFab * m_detJ_cc
Definition: ERF_Morrison.H:191
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_InitMorrison.cpp:21
int Qmoist_Size() override
Definition: ERF_Morrison.H:127
void GetPlotVar(const std::string &a_name, amrex::MultiFab &a_mf) const override
int m_qmoist_size
Definition: ERF_Morrison.H:168
int n_qstate_moist_numconc_size
Definition: ERF_Morrison.H:174
amrex::Real m_rdOcp
Definition: ERF_Morrison.H:183
amrex::Array< FabPtr, MicVar_Morr::NumVars > mic_fab_vars
Definition: ERF_Morrison.H:194
std::shared_ptr< amrex::MultiFab > FabPtr
Definition: ERF_Morrison.H:60
bool m_do_cond
Definition: ERF_Morrison.H:184
Definition: ERF_NullMoist.H:8
Definition: ERF_Morrison.H:24
@ qv
Definition: ERF_Morrison.H:34
@ ng
Definition: ERF_Morrison.H:48
@ nc
Definition: ERF_Morrison.H:44
@ qpg
Definition: ERF_Morrison.H:41
@ pres
Definition: ERF_Morrison.H:30
@ nr
Definition: ERF_Morrison.H:45
@ qcl
Definition: ERF_Morrison.H:35
@ tabs
Definition: ERF_Morrison.H:29
@ theta
Definition: ERF_Morrison.H:28
@ qp
Definition: ERF_Morrison.H:38
@ ni
Definition: ERF_Morrison.H:46
@ ns
Definition: ERF_Morrison.H:47
@ omega
Definition: ERF_Morrison.H:53
@ qps
Definition: ERF_Morrison.H:40
@ qn
Definition: ERF_Morrison.H:33
@ graup_accum
Definition: ERF_Morrison.H:52
@ rho
Definition: ERF_Morrison.H:27
@ qpr
Definition: ERF_Morrison.H:39
@ qci
Definition: ERF_Morrison.H:36
@ NumVars
Definition: ERF_Morrison.H:54
@ rain_accum
Definition: ERF_Morrison.H:50
@ snow_accum
Definition: ERF_Morrison.H:51
@ qt
Definition: ERF_Morrison.H:32
Definition: ERF_DataStruct.H:141
amrex::Real rdOcp
Definition: ERF_DataStruct.H:1222
bool use_shoc
Definition: ERF_DataStruct.H:1253