ERF
Energy Research and Forecasting: An Atmospheric Modeling Code
ERF_Kessler.H
Go to the documentation of this file.
1 #ifndef ERF_Kessler_H
2 #define ERF_Kessler_H
3 
4 #include <string>
5 #include <vector>
6 #include <memory>
7 
8 #include <AMReX_FArrayBox.H>
9 #include <AMReX_Geometry.H>
10 #include <AMReX_TableData.H>
11 #include <AMReX_MultiFabUtil.H>
12 
13 #include "ERF_Constants.H"
14 #include "ERF_KesslerUtils.H"
15 #include "ERF_MicrophysicsUtils.H"
16 #include "ERF_IndexDefines.H"
17 #include "ERF_DataStruct.H"
18 #include "ERF_NullMoist.H"
19 
20 namespace MicVar_Kess {
21  enum {
22  // independent variables
23  rho=0, // density
24  theta, // liquid/ice water potential temperature
25  tabs, // temperature
26  pres, // pressure
27  // non-precipitating vars
28  qt, // total cloud
29  qv, // cloud vapor
30  qcl, // cloud water
31  // precipitating vars
32  qp, // total precip
33  // derived vars
35  NumVars
36  };
37 }
38 
39 class Kessler : public NullMoist {
40 
41  using FabPtr = std::shared_ptr<amrex::MultiFab>;
42 
43 public:
44  // constructor
45  Kessler () {}
46 
47  // destructor
48  virtual ~Kessler () = default;
49 
50  // cloud physics
51  void AdvanceKessler (const SolverChoice &solverChoice);
52 
53  // Set up for first time
54  void
55  Define (SolverChoice& sc) override
56  {
57  // Use one latent-over-cp factor for both the saturation solve and theta
58  // update. L_v comes from ERF_Constants.H; c_p comes from SolverChoice.
59  m_fac_cond = L_v / sc.c_p;
60  m_do_cond = (!sc.use_shoc);
61  }
62 
63  // init
64  void
65  Init (const amrex::MultiFab& cons_in,
66  const amrex::BoxArray& grids,
67  const amrex::Geometry& geom,
68  const amrex::Real& dt_advance,
69  std::unique_ptr<amrex::MultiFab>& z_phys_nd,
70  std::unique_ptr<amrex::MultiFab>& detJ_cc) override;
71 
72  // Import minimum dz at this level
73  void
74  Set_dzmin (const amrex::Real dz_min) override
75  {
76  m_dzmin = dz_min;
77  }
78 
79  // Copy state into micro vars
80  void
81  Copy_State_to_Micro (const amrex::MultiFab& cons_in) override;
82 
83  // Copy state into micro vars
84  void
85  Copy_Micro_to_State (amrex::MultiFab& cons_in) override;
86 
87  // update micro vars
88  void
89  Update_Micro_Vars (amrex::MultiFab& cons_in) override
90  {
91  this->Copy_State_to_Micro(cons_in);
92  }
93 
94  // update state vars
95  void
96  Update_State_Vars (amrex::MultiFab& cons_in,
97  const amrex::MultiFab& /*z_phys_nd*/) override
98  {
99  this->Copy_Micro_to_State(cons_in);
100  }
101 
102  // wrapper to advance micro vars
103  void
104  Advance (const amrex::Real& dt_advance,
105  const SolverChoice& solverChoice) override
106  {
107  dt = dt_advance;
108 
109  this->AdvanceKessler(solverChoice);
110  }
111 
112  amrex::MultiFab*
113  Qmoist_Ptr (const int& varIdx) override
114  {
116  return mic_fab_vars[MicVarMap[varIdx]].get();
117  }
118 
119  int
120  Qmoist_Size () override { return Kessler::m_qmoist_size; }
121 
122  int
124 
125  int
127 
128  void
130  std::vector<int>& a_idx,
131  std::vector<std::string>& a_names) const override
132  {
133  a_idx.clear();
134  a_names.clear();
135 
136  // NOTE: These are the indices to access into qmoist (not mic_fab_vars)
137  a_idx.push_back(0); a_names.push_back("RainAccum");
138  }
139 
140 private:
141  // Number of qmoist variables (rain_accum)
142  int m_qmoist_size = 1;
143 
144  // Number of qstate variables
146 
147  // Number of qstate variables that are number concentrations
149 
150  // CFL MAX for vertical advection
152 
153  // MicVar map (Qmoist indices -> MicVar enum)
154  amrex::Vector<int> MicVarMap;
155 
156  // geometry
157  amrex::Geometry m_geom;
158 
159  // timestep
161 
162  // Minimum dz at this level
164 
165  // number of vertical levels
166  int nlev, zlo, zhi;
167 
168  // constants
170  bool m_do_cond;
171 
172  // Pointer to terrain data
173  amrex::MultiFab* m_z_phys_nd;
174  amrex::MultiFab* m_detJ_cc;
175 
176  // independent variables
177  amrex::Array<FabPtr, MicVar_Kess::NumVars> mic_fab_vars;
178 };
179 #endif
constexpr amrex::Real L_v
Definition: ERF_Constants.H:35
AMREX_ALWAYS_ASSERT(bx.length()[2]==khi+1)
static constexpr amrex::Real kessler_sedimentation_cfl_max
Definition: ERF_KesslerUtils.H:31
amrex::Real Real
Definition: ERF_ShocInterface.H:19
Definition: ERF_Kessler.H:39
int zlo
Definition: ERF_Kessler.H:166
void Update_Micro_Vars(amrex::MultiFab &cons_in) override
Definition: ERF_Kessler.H:89
amrex::MultiFab * Qmoist_Ptr(const int &varIdx) override
Definition: ERF_Kessler.H:113
amrex::Vector< int > MicVarMap
Definition: ERF_Kessler.H:154
void Copy_State_to_Micro(const amrex::MultiFab &cons_in) override
Definition: ERF_InitKessler.cpp:63
void Qmoist_Restart_Vars(const SolverChoice &, std::vector< int > &a_idx, std::vector< std::string > &a_names) const override
Definition: ERF_Kessler.H:129
void Set_dzmin(const amrex::Real dz_min) override
Definition: ERF_Kessler.H:74
int Qmoist_Size() override
Definition: ERF_Kessler.H:120
int n_qstate_moist_size
Definition: ERF_Kessler.H:145
virtual ~Kessler()=default
amrex::Geometry m_geom
Definition: ERF_Kessler.H:157
Kessler()
Definition: ERF_Kessler.H:45
amrex::MultiFab * m_detJ_cc
Definition: ERF_Kessler.H:174
void Define(SolverChoice &sc) override
Definition: ERF_Kessler.H:55
amrex::Real m_dzmin
Definition: ERF_Kessler.H:163
void Update_State_Vars(amrex::MultiFab &cons_in, const amrex::MultiFab &) override
Definition: ERF_Kessler.H:96
int Qstate_Moist_Size() override
Definition: ERF_Kessler.H:123
amrex::Real m_fac_cond
Definition: ERF_Kessler.H:169
void Copy_Micro_to_State(amrex::MultiFab &cons_in) override
Definition: ERF_UpdateKessler.cpp:14
amrex::Real dt
Definition: ERF_Kessler.H:160
int zhi
Definition: ERF_Kessler.H:166
int nlev
Definition: ERF_Kessler.H:166
bool m_do_cond
Definition: ERF_Kessler.H:170
amrex::Array< FabPtr, MicVar_Kess::NumVars > mic_fab_vars
Definition: ERF_Kessler.H:177
amrex::MultiFab * m_z_phys_nd
Definition: ERF_Kessler.H:173
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_InitKessler.cpp:21
static constexpr amrex::Real CFL_MAX
Definition: ERF_Kessler.H:151
void AdvanceKessler(const SolverChoice &solverChoice)
Definition: ERF_Kessler.cpp:14
std::shared_ptr< amrex::MultiFab > FabPtr
Definition: ERF_Kessler.H:41
void Advance(const amrex::Real &dt_advance, const SolverChoice &solverChoice) override
Definition: ERF_Kessler.H:104
int Qstate_Moist_NumConc_Size() override
Definition: ERF_Kessler.H:126
int m_qmoist_size
Definition: ERF_Kessler.H:142
int n_qstate_moist_numconc_size
Definition: ERF_Kessler.H:148
Definition: ERF_NullMoist.H:8
Definition: ERF_Kessler.H:20
@ qp
Definition: ERF_Kessler.H:32
@ qcl
Definition: ERF_Kessler.H:30
@ tabs
Definition: ERF_Kessler.H:25
@ pres
Definition: ERF_Kessler.H:26
@ rho
Definition: ERF_Kessler.H:23
@ theta
Definition: ERF_Kessler.H:24
@ qt
Definition: ERF_Kessler.H:28
@ rain_accum
Definition: ERF_Kessler.H:34
@ NumVars
Definition: ERF_Kessler.H:35
@ qv
Definition: ERF_Kessler.H:29
Definition: ERF_DataStruct.H:141
amrex::Real c_p
Definition: ERF_DataStruct.H:1221
bool use_shoc
Definition: ERF_DataStruct.H:1253