1 #ifndef SUPERDROPLETSMOIST_H
2 #define SUPERDROPLETSMOIST_H
4 #ifdef ERF_USE_PARTICLES
8 #include <AMReX_Enum.H>
9 #include <AMReX_Geometry.H>
30 namespace MicVar_SD_Species {
41 namespace MicVar_SD_Aerosols {
48 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
49 static int s_qt_idx (
const int a_i )
57 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
58 static int s_qv_idx (
const int a_i )
63 + MicVar_SD_Species::q_v;
66 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
67 static int s_qc_idx (
const int a_i )
72 + MicVar_SD_Species::q_c;
75 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
76 static int s_sr_idx (
const int a_i )
81 + MicVar_SD_Species::sr;
84 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
85 static int s_accum_idx (
const int a_i )
90 + MicVar_SD_Species::accum;
93 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
94 static int a_accum_idx (
const int a_ns,
101 + MicVar_SD_Aerosols::accum;
111 one_d_z, two_d_xz, two_d_yz, three_d
114 class SuperDropletsMoist :
public NullMoistLagrangian {
116 using FabPtr = std::shared_ptr<amrex::MultiFab>;
117 using MFPtr = std::unique_ptr<amrex::MultiFab>;
118 using BCTypeArr = amrex::GpuArray<ERF_BC, AMREX_SPACEDIM*2>;
126 m_qstate_moist_size = 3;
127 m_qstate_nonmoist_size = -1;
128 m_name =
"super_droplets_moisture";
136 virtual ~SuperDropletsMoist() =
default;
142 virtual void Init (
const amrex::MultiFab&,
143 const amrex::BoxArray&,
144 const amrex::Geometry&,
150 virtual void InitParticles ( MFPtr& )
override;
153 virtual void RestartParticles ( amrex::ParGDBBase*,
const std::string& )
override;
156 virtual void FinishInit(
const int&,
158 const amrex::Vector<MFPtr>&)
override;
162 amrex::Abort(
"Do not use this advance() for Lagrangian microphysics.");
174 const int& iteration,
176 amrex::Vector<amrex::Vector<amrex::MultiFab>>& cons_vars,
177 const amrex::Vector<MFPtr>& mf_array,
178 const BCTypeArr& bc_arr)
override;
183 virtual void Update_Micro_Vars (amrex::MultiFab& a_cons_vars)
override;
189 virtual void Update_State_Vars (amrex::MultiFab& a_cons_vars,
190 const amrex::MultiFab& a_z_phys_nd)
override;
195 virtual void Copy_State_to_Micro (
const amrex::MultiFab& a_state)
override;
200 virtual void Copy_Micro_to_State (amrex::MultiFab& a_state)
override;
203 inline virtual amrex::MultiFab* Qmoist_Ptr (
const int& a_idx)
override
206 return m_mic_fab_vars[m_mic_var_map[a_idx]].get();
210 inline virtual int Qmoist_Size ()
override
212 return m_qmoist_size;
216 inline virtual int Qstate_Moist_Size ()
override
218 return m_qstate_moist_size;
222 inline virtual int Qstate_NonMoist_Size ()
override
225 return m_qstate_nonmoist_size;
229 inline virtual ERFPC* getParticleContainer()
override
231 return m_super_droplets;
234 inline virtual const std::string& getName()
const override
240 virtual void computeQcQrWater (
const amrex::MultiFab& a_z_phys_nd);
243 virtual void computeQcSpecies (
const amrex::MultiFab& a_z_phys_nd)
245 for (
int is = 1; is <
m_num_species; is++) { computeQcSpecies(is, a_z_phys_nd); }
249 virtual void computeQcSpecies (
const int a_i,
const amrex::MultiFab& a_z_phys_nd);
252 virtual void computeQc (
const int a_i,
const amrex::MultiFab& a_z_phys_nd)
254 if (a_i == m_idx_w) { computeQcQrWater(a_z_phys_nd); }
255 else { computeQcSpecies(a_i, a_z_phys_nd); }
259 virtual void computeQtWater ();
262 virtual void computeQtSpecies ()
264 for (
int is = 1; is <
m_num_species; is++) { computeQtSpecies(is); }
268 virtual void computeQtSpecies (
const int a_i);
271 virtual void computeQt (
const int a_i)
273 if (a_i == m_idx_w) { computeQtWater(); }
274 else { computeQtSpecies(a_i); }
278 virtual void rainAccumulation (
const amrex::MultiFab& a_z_phys_nd);
281 virtual void speciesAccumulation (
const amrex::MultiFab& a_z_phys_nd);
284 virtual void aerosolAccumulation (
const amrex::MultiFab& a_z_phys_nd);
287 void densityToRatio ( amrex::MultiFab&,
const int a_comp = 0 );
289 void ratioToDensity ( amrex::MultiFab&,
const int a_comp = 0 );
296 virtual void phaseChange (
const amrex::Real& a_dt,
297 const amrex::Vector<MFPtr>& a_z,
298 const bool a_update_qv);
300 virtual void GetPlotVarNames (amrex::Vector<std::string>& a_names)
const override
303 a_names.push_back(
"qv_"+amrex::getEnumNameString(
m_species[v]));
304 a_names.push_back(
"qc_"+amrex::getEnumNameString(
m_species[v]));
305 a_names.push_back(
"qt_"+amrex::getEnumNameString(
m_species[v]));
306 a_names.push_back(
"sat_ratio_"+amrex::getEnumNameString(
m_species[v]));
307 a_names.push_back(
"accum_"+amrex::getEnumNameString(
m_species[v]));
309 for (
int v = 0; v < m_num_aerosols; v++) {
310 a_names.push_back(
"accum_"+amrex::getEnumNameString(m_aerosols[v]));
314 virtual void GetPlotVar (
const std::string& a_name,
315 amrex::MultiFab& a_mf )
const override
317 AMREX_ASSERT(a_mf.nComp() >= 1);
320 auto try_copy = [&](
const std::string& prefix,
int idx) ->
bool {
321 if (a_name == prefix) {
322 amrex::MultiFab::Copy(a_mf, *m_mic_fab_vars[
idx],
323 0, 0, 1, amrex::IntVect::TheZeroVector());
331 std::string sp_name = amrex::getEnumNameString(
m_species[v]);
332 if (try_copy(
"qv_" + sp_name, s_qv_idx(v)) ||
333 try_copy(
"qc_" + sp_name, s_qc_idx(v)) ||
334 try_copy(
"qt_" + sp_name, s_qt_idx(v)) ||
335 try_copy(
"sat_ratio_" + sp_name, s_sr_idx(v)) ||
336 try_copy(
"accum_" + sp_name, s_accum_idx(v))) {
342 for (
int v = 0; v < m_num_aerosols; v++) {
343 std::string ae_name = amrex::getEnumNameString(m_aerosols[v]);
344 if (try_copy(
"accum_" + ae_name, a_accum_idx(
m_num_species, v))) {
return; }
347 amrex::Abort(
"SuperDropletsMoist::GetPlotVar() called with invalid name");
350 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
351 int q_qv_idx (
const int a_i )
354 return RhoQ1_comp + m_qstate_moist_size + 2*(a_i-1) + 0;
357 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
358 int q_qc_idx (
const int a_i )
361 return RhoQ1_comp + m_qstate_moist_size + 2*(a_i-1) + 1;
366 bool m_flag_phase_change;
367 bool m_flag_advection;
368 bool m_flag_coalescence;
375 bool m_init_phase_change;
379 int m_diagnostics_iter;
382 SDMoistInit m_init_type;
387 amrex::Geometry m_geom;
392 int m_qstate_moist_size;
394 int m_qstate_nonmoist_size;
397 amrex::Vector<int> m_mic_var_map;
400 amrex::Vector<FabPtr> m_mic_fab_vars;
407 std::vector<Species::Name> m_aerosols;
411 int m_num_substeps_phase_change;
414 bool m_kinematic_mode;
417 SDMSimulationDim m_dimensionality;
420 bool m_recycle_particles;
428 SuperDropletPC* m_super_droplets;
431 virtual void readInputs();
AMREX_ENUM(InitType, None, Input_Sounding, NCFile, WRFInput, Metgrid, Uniform, ConstantDensity, ConstantDensityLinearTheta, Isentropic, MoistBaseState, HindCast)
#define RhoQ1_comp
Definition: ERF_IndexDefines.H:42
AMREX_ALWAYS_ASSERT(bx.length()[2]==khi+1)
rho
Definition: ERF_InitCustomPert_Bubble.H:106
int m_num_species
Definition: ERF_InitCustomPert_MultiSpeciesBubble.H:28
std::vector< std::string > m_species
Definition: ERF_InitCustomPert_MultiSpeciesBubble.H:27
Real q_t
Definition: ERF_InitCustomPert_SquallLine.H:24
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE int idx(int i, int j, int k, int nx, int ny)
Definition: ERF_InitForEnsemble.cpp:287
Contains the Lagrangian moisture model base class.
amrex::Real Real
Definition: ERF_ShocInterface.H:19
@ NumVars
Definition: ERF_MM5.H:21
@ theta
Definition: ERF_MM5.H:20
@ rain_accum
Definition: ERF_Kessler.H:33
Definition: ERF_DataStruct.H:130