1 #ifndef SUPERDROPLETSMOIST_H
2 #define SUPERDROPLETSMOIST_H
4 #ifdef ERF_USE_PARTICLES
8 #include <AMReX_Enum.H>
9 #include <AMReX_Geometry.H>
10 #include <AMReX_iMultiFab.H>
11 #include <AMReX_MultiFabUtil.H>
32 namespace MicVar_SD_Species {
43 namespace MicVar_SD_Aerosols {
50 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
51 static int s_qt_idx (
const int a_i )
59 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
60 static int s_qv_idx (
const int a_i )
65 + MicVar_SD_Species::q_v;
68 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
69 static int s_qc_idx (
const int a_i )
74 + MicVar_SD_Species::q_c;
77 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
78 static int s_sr_idx (
const int a_i )
83 + MicVar_SD_Species::sr;
86 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
87 static int s_accum_idx (
const int a_i )
92 + MicVar_SD_Species::accum;
95 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
96 static int a_accum_idx (
const int a_ns,
103 + MicVar_SD_Aerosols::accum;
113 one_d_z, two_d_xz, two_d_yz, three_d
116 class SuperDropletsMoist :
public NullMoistLagrangian {
118 using FabPtr = std::shared_ptr<amrex::MultiFab>;
119 using MFPtr = std::unique_ptr<amrex::MultiFab>;
120 using BCTypeArr = amrex::GpuArray<ERF_BC, AMREX_SPACEDIM*2>;
128 m_qstate_moist_size = 3;
129 m_qstate_nonmoist_size = -1;
130 m_name =
"super_droplets_moisture";
138 virtual ~SuperDropletsMoist() =
default;
144 virtual void Init (
const amrex::MultiFab&,
145 const amrex::BoxArray&,
146 const amrex::Geometry&,
152 virtual void InitParticles (
const int, MFPtr& )
override;
155 virtual void RestartParticles ( amrex::ParGDBBase*,
const std::string& )
override;
158 virtual void FinishInit(
const int&,
160 const amrex::Vector<MFPtr>&)
override;
164 amrex::Abort(
"Do not use this advance() for Lagrangian microphysics.");
168 void SetCurrentLevel (
const int& a_lev)
override { m_current_lev = a_lev; }
171 int getDiagnosticsInterval ()
const override {
return m_diagnostics_iter; }
174 void EnsureMicFabVars (
const int a_lev,
const amrex::MultiFab& a_cons_vars);
177 amrex::iMultiFab buildFineMask (
const int a_lev)
const;
180 void InitLevel (
const int a_lev,
const amrex::MultiFab& a_cons_vars)
override;
191 const int& iteration,
193 amrex::Vector<amrex::Vector<amrex::MultiFab>>& cons_vars,
194 const amrex::Vector<MFPtr>& mf_array,
195 const BCTypeArr& bc_arr)
override;
200 virtual void Update_Micro_Vars (amrex::MultiFab& a_cons_vars)
override;
206 virtual void Update_State_Vars (amrex::MultiFab& a_cons_vars,
207 const amrex::MultiFab& a_z_phys_nd)
override;
210 virtual void AverageDownMicroVars (
const int finest_level)
override;
215 virtual void Copy_State_to_Micro (
const amrex::MultiFab& a_state)
override;
220 virtual void Copy_Micro_to_State (amrex::MultiFab& a_state)
override;
223 inline virtual amrex::MultiFab* Qmoist_Ptr (
const int& a_idx)
override
226 const int lev = m_current_lev;
227 if (lev < 0 || lev >=
static_cast<int>(m_mic_fab_vars.size()) ||
228 m_mic_var_map[a_idx] < 0 || m_mic_var_map[a_idx] >=
static_cast<int>(m_mic_fab_vars[lev].size())) {
231 return m_mic_fab_vars[lev][m_mic_var_map[a_idx]].get();
235 inline virtual int Qmoist_Size ()
override
237 return m_qmoist_size;
241 inline virtual int Qstate_Moist_Size ()
override
243 return m_qstate_moist_size;
247 inline virtual int Qstate_NonMoist_Size ()
override
250 return m_qstate_nonmoist_size;
254 inline virtual ERFPC* getParticleContainer()
override
256 return m_super_droplets;
259 inline virtual const std::string& getName()
const override
265 virtual void computeQcQrWater (
const amrex::MultiFab& a_z_phys_nd);
268 virtual void computeQcSpecies (
const amrex::MultiFab& a_z_phys_nd)
270 for (
int is = 1; is <
m_num_species; is++) { computeQcSpecies(is, a_z_phys_nd); }
274 virtual void computeQcSpecies (
const int a_i,
const amrex::MultiFab& a_z_phys_nd);
277 virtual void computeQc (
const int a_i,
const amrex::MultiFab& a_z_phys_nd)
279 if (a_i == m_idx_w) { computeQcQrWater(a_z_phys_nd); }
280 else { computeQcSpecies(a_i, a_z_phys_nd); }
284 virtual void computeQtWater ();
287 virtual void computeQtSpecies ()
289 for (
int is = 1; is <
m_num_species; is++) { computeQtSpecies(is); }
293 virtual void computeQtSpecies (
const int a_i);
296 virtual void computeQt (
const int a_i)
298 if (a_i == m_idx_w) { computeQtWater(); }
299 else { computeQtSpecies(a_i); }
303 virtual void rainAccumulation (
const amrex::MultiFab& a_z_phys_nd);
306 virtual void speciesAccumulation (
const amrex::MultiFab& a_z_phys_nd);
309 virtual void aerosolAccumulation (
const amrex::MultiFab& a_z_phys_nd);
312 void densityToRatio ( amrex::MultiFab&,
const int a_comp = 0 );
314 void ratioToDensity ( amrex::MultiFab&,
const int a_comp = 0 );
321 virtual void phaseChange (
const amrex::Real& a_dt,
322 const amrex::Vector<MFPtr>& a_z,
325 virtual void GetPlotVarNames (amrex::Vector<std::string>& a_names)
const override
328 a_names.push_back(
"qv_"+amrex::getEnumNameString(
m_species[v]));
329 a_names.push_back(
"qc_"+amrex::getEnumNameString(
m_species[v]));
330 a_names.push_back(
"qt_"+amrex::getEnumNameString(
m_species[v]));
331 a_names.push_back(
"sat_ratio_"+amrex::getEnumNameString(
m_species[v]));
332 a_names.push_back(
"accum_"+amrex::getEnumNameString(
m_species[v]));
334 for (
int v = 0; v < m_num_aerosols; v++) {
335 a_names.push_back(
"accum_"+amrex::getEnumNameString(m_aerosols[v]));
339 virtual void GetPlotVar (
const std::string& ,
340 amrex::MultiFab& )
const override
342 amrex::Abort(
"SuperDropletsMoist::GetPlotVar() requires a level argument");
345 virtual void GetPlotVar (
const std::string& a_name,
346 amrex::MultiFab& a_mf,
347 const int a_lev)
const override
350 AMREX_ASSERT(a_mf.nComp() >= 1);
352 const int lev = a_lev;
353 if (lev < 0 || lev >=
static_cast<int>(m_mic_fab_vars.size()) ||
354 m_mic_fab_vars[lev].empty()) {
358 const auto& lev_vec = m_mic_fab_vars[lev];
361 auto try_copy = [&](
const std::string& prefix,
int idx) ->
bool {
362 if (a_name == prefix) {
363 if (
idx >= 0 &&
idx <
static_cast<int>(lev_vec.size()) && lev_vec[
idx] &&
364 lev_vec[
idx]->boxArray() == a_mf.boxArray() &&
365 lev_vec[
idx]->DistributionMap() == a_mf.DistributionMap()) {
366 amrex::MultiFab::Copy(a_mf, *lev_vec[
idx],
367 0, 0, 1, amrex::IntVect::TheZeroVector());
376 std::string sp_name = amrex::getEnumNameString(
m_species[v]);
377 if (try_copy(
"qv_" + sp_name, s_qv_idx(v)) ||
378 try_copy(
"qc_" + sp_name, s_qc_idx(v)) ||
379 try_copy(
"qt_" + sp_name, s_qt_idx(v)) ||
380 try_copy(
"sat_ratio_" + sp_name, s_sr_idx(v)) ||
381 try_copy(
"accum_" + sp_name, s_accum_idx(v))) {
387 for (
int v = 0; v < m_num_aerosols; v++) {
388 std::string ae_name = amrex::getEnumNameString(m_aerosols[v]);
389 if (try_copy(
"accum_" + ae_name, a_accum_idx(
m_num_species, v))) {
return; }
392 amrex::Abort(
"SuperDropletsMoist::GetPlotVar() called with invalid name");
395 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
396 int q_qv_idx (
const int a_i )
399 return RhoQ1_comp + m_qstate_moist_size + 2*(a_i-1) + 0;
402 AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE
403 int q_qc_idx (
const int a_i )
406 return RhoQ1_comp + m_qstate_moist_size + 2*(a_i-1) + 1;
411 bool m_flag_phase_change;
412 bool m_flag_advection;
413 bool m_flag_coalescence;
420 bool m_init_phase_change;
424 int m_diagnostics_iter;
427 SDMoistInit m_init_type;
432 amrex::Geometry m_geom;
437 int m_qstate_moist_size;
439 int m_qstate_nonmoist_size;
442 amrex::Vector<int> m_mic_var_map;
445 amrex::Vector<amrex::Vector<FabPtr>> m_mic_fab_vars;
448 mutable int m_current_lev = 0;
455 std::vector<Species::Name> m_aerosols;
459 int m_num_substeps_phase_change;
462 bool m_kinematic_mode;
465 SDMSimulationDim m_dimensionality;
468 bool m_recycle_particles;
476 SuperDropletPC* m_super_droplets;
479 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