ERF
Energy Research and Forecasting: An Atmospheric Modeling Code
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Macros Pages
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_MicrophysicsUtils.H"
15 #include "ERF_IndexDefines.H"
16 #include "ERF_DataStruct.H"
17 #include "ERF_NullMoist.H"
18 
19 namespace MicVar_Kess {
20  enum {
21  // independent variables
22  rho=0, // density
23  theta, // liquid/ice water potential temperature
24  tabs, // temperature
25  pres, // pressure
26  // non-precipitating vars
27  qt, // total cloud
28  qv, // cloud vapor
29  qcl, // cloud water
30  // precipitating vars
31  qp, // total precip
32  // derived vars
34  NumVars
35  };
36 }
37 
38 class Kessler : public NullMoist {
39 
40  using FabPtr = std::shared_ptr<amrex::MultiFab>;
41 
42 public:
43  // constructor
44  Kessler () {}
45 
46  // destructor
47  virtual ~Kessler () = default;
48 
49  // cloud physics
50  void AdvanceKessler (const SolverChoice &solverChoice);
51 
52  // Set up for first time
53  void
54  Define (SolverChoice& sc) override
55  {
56  m_fac_cond = lcond / sc.c_p;
57  m_fac_fus = lfus / sc.c_p;
58  m_fac_sub = lsub / sc.c_p;
59  m_gOcp = CONST_GRAV / sc.c_p;
60  m_axis = sc.ave_plane;
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  // Copy state into micro vars
73  void
74  Copy_State_to_Micro (const amrex::MultiFab& cons_in) override;
75 
76  // Copy state into micro vars
77  void
78  Copy_Micro_to_State (amrex::MultiFab& cons_in) override;
79 
80  // update micro vars
81  void
82  Update_Micro_Vars (amrex::MultiFab& cons_in) override
83  {
84  this->Copy_State_to_Micro(cons_in);
85  }
86 
87  // update state vars
88  void
89  Update_State_Vars (amrex::MultiFab& cons_in) override
90  {
91  this->Copy_Micro_to_State(cons_in);
92  }
93 
94  // wrapper to advance micro vars
95  void
96  Advance (const amrex::Real& dt_advance,
97  const SolverChoice& solverChoice) override
98  {
99  dt = dt_advance;
100 
101  this->AdvanceKessler(solverChoice);
102  }
103 
104  amrex::MultiFab*
105  Qmoist_Ptr (const int& varIdx) override
106  {
107  AMREX_ALWAYS_ASSERT(varIdx < m_qmoist_size);
108  return mic_fab_vars[MicVarMap[varIdx]].get();
109  }
110 
111  int
112  Qmoist_Size () override { return Kessler::m_qmoist_size; }
113 
114  int
115  Qstate_Size () override { return Kessler::m_qstate_size; }
116 
117  void
119  std::vector<int>& a_idx,
120  std::vector<std::string>& a_names) const override
121  {
122  a_idx.clear();
123  a_names.clear();
124 
125  // NOTE: These are the indices to access into qmoist (not mic_fab_vars)
126  a_idx.push_back(0); a_names.push_back("RainAccum");
127  }
128 
129 private:
130  // Number of qmoist variables (rain_accum)
131  int m_qmoist_size = 1;
132 
133  // Number of qstate variables
134  int m_qstate_size = 3;
135 
136  // CFL MAX for vertical advection
137  static constexpr amrex::Real CFL_MAX = 0.5;
138 
139  // MicVar map (Qmoist indices -> MicVar enum)
140  amrex::Vector<int> MicVarMap;
141 
142  // geometry
143  amrex::Geometry m_geom;
144 
145  // valid boxes on which to evolve the solution
146  amrex::BoxArray m_gtoe;
147 
148  // timestep
149  amrex::Real dt;
150 
151  // number of vertical levels
152  int nlev, zlo, zhi;
153 
154  // plane average axis
155  int m_axis;
156 
157  // constants
158  amrex::Real m_fac_cond;
159  amrex::Real m_fac_fus;
160  amrex::Real m_fac_sub;
161  amrex::Real m_gOcp;
162 
163  // Pointer to terrain data
164  amrex::MultiFab* m_z_phys_nd;
165  amrex::MultiFab* m_detJ_cc;
166 
167  // independent variables
168  amrex::Array<FabPtr, MicVar_Kess::NumVars> mic_fab_vars;
169 };
170 #endif
constexpr amrex::Real lfus
Definition: ERF_Constants.H:67
constexpr amrex::Real lsub
Definition: ERF_Constants.H:68
constexpr amrex::Real lcond
Definition: ERF_Constants.H:66
constexpr amrex::Real CONST_GRAV
Definition: ERF_Constants.H:21
Definition: ERF_Kessler.H:38
int zlo
Definition: ERF_Kessler.H:152
void Update_Micro_Vars(amrex::MultiFab &cons_in) override
Definition: ERF_Kessler.H:82
amrex::MultiFab * Qmoist_Ptr(const int &varIdx) override
Definition: ERF_Kessler.H:105
amrex::Vector< int > MicVarMap
Definition: ERF_Kessler.H:140
void Copy_State_to_Micro(const amrex::MultiFab &cons_in) override
Definition: ERF_InitKessler.cpp:64
int Qstate_Size() override
Definition: ERF_Kessler.H:115
amrex::Real m_fac_sub
Definition: ERF_Kessler.H:160
void Qmoist_Restart_Vars(const SolverChoice &, std::vector< int > &a_idx, std::vector< std::string > &a_names) const override
Definition: ERF_Kessler.H:118
int Qmoist_Size() override
Definition: ERF_Kessler.H:112
virtual ~Kessler()=default
amrex::Geometry m_geom
Definition: ERF_Kessler.H:143
Kessler()
Definition: ERF_Kessler.H:44
amrex::MultiFab * m_detJ_cc
Definition: ERF_Kessler.H:165
void Define(SolverChoice &sc) override
Definition: ERF_Kessler.H:54
amrex::Real m_fac_cond
Definition: ERF_Kessler.H:158
void Copy_Micro_to_State(amrex::MultiFab &cons_in) override
Definition: ERF_UpdateKessler.cpp:14
amrex::Real dt
Definition: ERF_Kessler.H:149
int zhi
Definition: ERF_Kessler.H:152
int nlev
Definition: ERF_Kessler.H:152
amrex::Array< FabPtr, MicVar_Kess::NumVars > mic_fab_vars
Definition: ERF_Kessler.H:168
amrex::Real m_gOcp
Definition: ERF_Kessler.H:161
amrex::MultiFab * m_z_phys_nd
Definition: ERF_Kessler.H:164
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:22
static constexpr amrex::Real CFL_MAX
Definition: ERF_Kessler.H:137
void AdvanceKessler(const SolverChoice &solverChoice)
Definition: ERF_Kessler.cpp:11
amrex::Real m_fac_fus
Definition: ERF_Kessler.H:159
int m_qstate_size
Definition: ERF_Kessler.H:134
std::shared_ptr< amrex::MultiFab > FabPtr
Definition: ERF_Kessler.H:40
void Advance(const amrex::Real &dt_advance, const SolverChoice &solverChoice) override
Definition: ERF_Kessler.H:96
void Update_State_Vars(amrex::MultiFab &cons_in) override
Definition: ERF_Kessler.H:89
amrex::BoxArray m_gtoe
Definition: ERF_Kessler.H:146
int m_qmoist_size
Definition: ERF_Kessler.H:131
int m_axis
Definition: ERF_Kessler.H:155
Definition: ERF_NullMoist.H:8
Definition: ERF_Kessler.H:19
@ qp
Definition: ERF_Kessler.H:31
@ qcl
Definition: ERF_Kessler.H:29
@ tabs
Definition: ERF_Kessler.H:24
@ pres
Definition: ERF_Kessler.H:25
@ rho
Definition: ERF_Kessler.H:22
@ theta
Definition: ERF_Kessler.H:23
@ qt
Definition: ERF_Kessler.H:27
@ rain_accum
Definition: ERF_Kessler.H:33
@ NumVars
Definition: ERF_Kessler.H:34
@ qv
Definition: ERF_Kessler.H:28
Definition: ERF_DataStruct.H:86
amrex::Real c_p
Definition: ERF_DataStruct.H:710
int ave_plane
Definition: ERF_DataStruct.H:773