Function for computing the slow RHS for the evolution equations for the scalars other than density or potential temperature
94 BL_PROFILE_REGION(
"erf_slow_rhs_post()");
96 const BCRec* bc_ptr_d = domain_bcs_type_d.data();
97 const BCRec* bc_ptr_h = domain_bcs_type_h.data();
103 const MultiFab* t_mean_mf =
nullptr;
104 if (SurfLayer) { t_mean_mf = SurfLayer->get_mac_avg(level,2); }
106 const bool l_use_terrain = (solverChoice.
mesh_type != MeshType::ConstantDz);
107 const bool l_moving_terrain = (solverChoice.
terrain_type == TerrainType::MovingFittedMesh);
108 const bool l_reflux = ( (solverChoice.
coupling_type == CouplingType::TwoWay) && (nrk == 2) && (finest_level > 0) );
111 const bool l_anelastic = solverChoice.
anelastic[level];
113 const bool l_use_KE = ( tc.
use_tke );
114 const bool l_need_SmnSmn = ( tc.
les_type == LESType::Deardorff ||
124 amrex::ignore_unused(m_r2d);
126 const Box& domain = geom.Domain();
128 bool l_apply_surface_layer_fluxes_in_diffusion = (SurfLayer !=
nullptr);
129 #ifdef ERF_USE_EAMXX_SHOC
131 l_apply_surface_layer_fluxes_in_diffusion =
false;
134 #ifdef ERF_USE_NATIVE_SHOC
137 l_apply_surface_layer_fluxes_in_diffusion =
138 l_apply_surface_layer_fluxes_in_diffusion &&
139 native_shoc_lev->uses_host_diffusion();
143 const GpuArray<Real, AMREX_SPACEDIM>
dxInv = geom.InvCellSizeArray();
144 const Real*
dx = geom.CellSize();
149 const Array<Real,AMREX_SPACEDIM> grav{
zero,
zero, -solverChoice.
gravity};
150 const GpuArray<Real,AMREX_SPACEDIM> grav_gpu{grav[0], grav[1], grav[2]};
157 const DistributionMapping& dm = S_data[
IntVars::cons].DistributionMap();
159 std::unique_ptr<MultiFab> dflux_x;
160 std::unique_ptr<MultiFab> dflux_y;
161 std::unique_ptr<MultiFab> dflux_z;
165 dflux_x = std::make_unique<MultiFab>(convert(ba,IntVect(1,0,0)), dm, 1,
ng);
166 dflux_y = std::make_unique<MultiFab>(convert(ba,IntVect(0,1,0)), dm, 1,
ng);
167 dflux_z = std::make_unique<MultiFab>(convert(ba,IntVect(0,0,1)), dm, 1, 0);
175 Vector<int> is_valid_slow_var; is_valid_slow_var.resize(
RhoQ1_comp+1,0);
176 if (l_use_KE) { is_valid_slow_var[
RhoKE_comp] = 1; }
198 #pragma omp parallel if (Gpu::notInLaunchRegion())
201 std::array<FArrayBox,AMREX_SPACEDIM> flux;
207 iMultiFab physbnd_mask;
208 bool already_on_centroids =
false;
211 physbnd_mask.BuildMask(geom.Domain(), geom.periodicity(), 1, 1, 0, 1);
214 for (MFIter mfi(S_data[
IntVars::cons],TilingIfNotGPU()); mfi.isValid(); ++mfi) {
216 Box tbx = mfi.tilebox();
221 for (
int dir = 0; dir < AMREX_SPACEDIM; ++dir) {
223 flux[dir].resize(surroundingNodes(tbx,dir),
nvars,The_Async_Arena());
225 flux[dir].resize(surroundingNodes(tbx,dir).grow(1),
nvars,The_Async_Arena());
227 flux[dir].setVal<RunOn::Device>(0);
229 const GpuArray<const Array4<Real>, AMREX_SPACEDIM>
230 flx_arr{{AMREX_D_DECL(flux[0].array(), flux[1].array(), flux[2].array())}};
235 const Array4<const Real> & old_cons = S_old[
IntVars::cons].array(mfi);
236 const Array4< Real> & cell_rhs = S_rhs[
IntVars::cons].array(mfi);
238 const Array4< Real> & new_cons = S_new[
IntVars::cons].array(mfi);
239 const Array4< Real> & new_xmom = S_new[
IntVars::xmom].array(mfi);
240 const Array4< Real> & new_ymom = S_new[
IntVars::ymom].array(mfi);
241 const Array4< Real> & new_zmom = S_new[
IntVars::zmom].array(mfi);
243 const Array4< Real> & cur_cons = S_data[
IntVars::cons].array(mfi);
244 const Array4<const Real> & cur_prim = S_prim.array(mfi);
245 const Array4< Real> & cur_xmom = S_data[
IntVars::xmom].array(mfi);
246 const Array4< Real> & cur_ymom = S_data[
IntVars::ymom].array(mfi);
247 const Array4< Real> & cur_zmom = S_data[
IntVars::zmom].array(mfi);
249 Array4<Real> avg_xmom_arr = avg_xmom.array(mfi);
250 Array4<Real> avg_ymom_arr = avg_ymom.array(mfi);
251 Array4<Real> avg_zmom_arr = avg_zmom.array(mfi);
253 const Array4<const Real> & u =
xvel.array(mfi);
254 const Array4<const Real> & v =
yvel.array(mfi);
256 const Array4<const Real>& z_nd = z_phys_nd->const_array(mfi);
257 const Array4<const Real>& z_cc = z_phys_cc->const_array(mfi);
258 const Array4<const Real>& detJ_new_arr = l_moving_terrain ? detJ_new->const_array(mfi) : Array4<const Real>{};
261 const Array4<const Real>& mf_mx = mapfac[
MapFacType::m_x]->const_array(mfi);
262 const Array4<const Real>& mf_ux = mapfac[
MapFacType::u_x]->const_array(mfi);
263 const Array4<const Real>& mf_vx = mapfac[
MapFacType::v_x]->const_array(mfi);
264 const Array4<const Real>& mf_my = mapfac[
MapFacType::m_y]->const_array(mfi);
265 const Array4<const Real>& mf_uy = mapfac[
MapFacType::u_y]->const_array(mfi);
266 const Array4<const Real>& mf_vy = mapfac[
MapFacType::v_y]->const_array(mfi);
269 const Array4<const Real>& SmnSmn_a = l_need_SmnSmn ? SmnSmn->const_array(mfi) : Array4<const Real>{};
275 const GpuArray<int, IntVars::NumTypes> scomp_slow = { 2,0,0,0};
276 const GpuArray<int, IntVars::NumTypes> ncomp_slow = {nsv,0,0,0};
282 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k,
int nn) {
284 cur_cons(i,j,k,n) = new_cons(i,j,k,n);
291 Box tbx_inc = mfi.nodaltilebox(0);
292 Box tby_inc = mfi.nodaltilebox(1);
293 Box tbz_inc = mfi.nodaltilebox(2);
296 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept {
297 avg_xmom_arr(i,j,k) = cur_xmom(i,j,k);
299 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept {
300 avg_ymom_arr(i,j,k) = cur_ymom(i,j,k);
302 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept {
303 avg_zmom_arr(i,j,k) = cur_zmom(i,j,k);
310 bool l_eb_terrain_cc =
false;
311 Array4<const int> mask_arr{};
312 Array4<const EBCellFlag> cfg_arr{};
313 Array4<const Real> ax_arr{};
314 Array4<const Real> ay_arr{};
315 Array4<const Real> az_arr{};
316 Array4<const Real> fcx_arr{};
317 Array4<const Real> fcy_arr{};
318 Array4<const Real> fcz_arr{};
319 Array4<const Real> detJ_arr{};
321 EBCellFlagFab
const& cfg = ebfact.getMultiEBCellFlagFab()[mfi];
322 cfg_arr = cfg.const_array();
323 if (cfg.getType(tbx) == FabType::singlevalued) {
324 l_eb_terrain_cc =
true;
325 ax_arr = ebfact.getAreaFrac()[0]->const_array(mfi);
326 ay_arr = ebfact.getAreaFrac()[1]->const_array(mfi);
327 az_arr = ebfact.getAreaFrac()[2]->const_array(mfi);
328 fcx_arr = ebfact.getFaceCent()[0]->const_array(mfi);
329 fcy_arr = ebfact.getFaceCent()[1]->const_array(mfi);
330 fcz_arr = ebfact.getFaceCent()[2]->const_array(mfi);
331 detJ_arr = ebfact.getVolFrac().const_array(mfi);
333 mask_arr = physbnd_mask.const_array(mfi);
336 if (!l_eb_terrain_cc) {
337 ax_arr = ax->const_array(mfi);
338 ay_arr = ay->const_array(mfi);
339 az_arr = az->const_array(mfi);
340 detJ_arr = detJ->const_array(mfi);
343 AdvType horiz_adv_type, vert_adv_type;
344 Real horiz_upw_frac, vert_upw_frac;
346 Array4<Real> diffflux_x, diffflux_y, diffflux_z;
347 Array4<Real> hfx_x, hfx_y, hfx_z, diss;
348 Array4<Real> q1fx_x, q1fx_y, q1fx_z, q2fx_z;
351 diffflux_x = dflux_x->array(mfi);
352 diffflux_y = dflux_y->array(mfi);
353 diffflux_z = dflux_z->array(mfi);
355 hfx_x = Hfx1->array(mfi);
356 hfx_y = Hfx2->array(mfi);
357 hfx_z = Hfx3->array(mfi);
358 diss = Diss->array(mfi);
360 if (Q1fx1) q1fx_x = Q1fx1->array(mfi);
361 if (Q1fx2) q1fx_y = Q1fx2->array(mfi);
362 if (Q1fx3) q1fx_z = Q1fx3->array(mfi);
363 if (Q2fx3) q2fx_z = Q2fx3->array(mfi);
366 if (l_use_diff && l_use_turb) {
367 AMREX_ALWAYS_ASSERT_WITH_MESSAGE(
368 eddyDiffs !=
nullptr,
369 "erf_slow_rhs_post: active turbulence requires non-null eddyDiffs");
371 const Array4<const Real>& mu_turb =
372 l_use_turb ? eddyDiffs->const_array(mfi) : Array4<const Real>{};
379 if (is_valid_slow_var[ivar])
385 horiz_adv_type =
ac.moistscal_horiz_adv_type;
386 vert_adv_type =
ac.moistscal_vert_adv_type;
387 horiz_upw_frac =
ac.moistscal_horiz_upw_frac;
388 vert_upw_frac =
ac.moistscal_vert_upw_frac;
390 if (
ac.use_efficient_advection){
398 horiz_adv_type =
ac.dryscal_horiz_adv_type;
399 vert_adv_type =
ac.dryscal_vert_adv_type;
400 horiz_upw_frac =
ac.dryscal_horiz_upw_frac;
401 vert_upw_frac =
ac.dryscal_vert_upw_frac;
403 if (
ac.use_efficient_advection){
416 if (!l_eb_terrain_cc){
418 avg_xmom_arr, avg_ymom_arr, avg_zmom_arr,
420 detJ_arr,
dxInv, mf_mx, mf_my,
421 horiz_adv_type, vert_adv_type,
422 horiz_upw_frac, vert_upw_frac,
423 flx_arr, domain, bc_ptr_h);
426 avg_xmom_arr, avg_ymom_arr, avg_zmom_arr,
428 mask_arr, cfg_arr, ax_arr, ay_arr, az_arr,
429 fcx_arr, fcy_arr, fcz_arr,
430 detJ_arr,
dxInv, mf_mx, mf_my,
431 horiz_adv_type, vert_adv_type,
432 horiz_upw_frac, vert_upw_frac,
433 flx_arr, domain, bc_ptr_h,
434 already_on_centroids);
447 const Array4<const Real> tm_arr = t_mean_mf ? t_mean_mf->const_array(mfi) : Array4<const Real>{};
449 if (solverChoice.
mesh_type == MeshType::StretchedDz && solverChoice.
terrain_type != TerrainType::EB) {
451 new_cons, cur_prim, cell_rhs,
452 diffflux_x, diffflux_y, diffflux_z,
453 stretched_dz_d,
dxInv, SmnSmn_a,
456 hfx_z, q1fx_z, q2fx_z, diss,
457 mu_turb, solverChoice, level,
458 tm_arr, grav_gpu, bc_ptr_d, l_apply_surface_layer_fluxes_in_diffusion,
l_vert_implicit_fac);
459 }
else if (l_use_terrain) {
461 new_cons, cur_prim, cell_rhs,
462 diffflux_x, diffflux_y, diffflux_z,
463 z_nd, z_cc, ax_arr, ay_arr, az_arr,
464 detJ_arr,
dxInv, SmnSmn_a,
467 hfx_x, hfx_y, hfx_z, q1fx_x, q1fx_y, q1fx_z,q2fx_z, diss,
468 mu_turb, solverChoice, level,
469 tm_arr, grav_gpu, bc_ptr_d, l_apply_surface_layer_fluxes_in_diffusion,
l_vert_implicit_fac);
472 new_cons, cur_prim, cell_rhs,
473 diffflux_x, diffflux_y, diffflux_z,
dxInv, SmnSmn_a,
476 hfx_z, q1fx_z, q2fx_z, diss,
477 mu_turb, solverChoice, level,
478 tm_arr, grav_gpu, bc_ptr_d, l_apply_surface_layer_fluxes_in_diffusion,
l_vert_implicit_fac);
484 #ifdef ERF_USE_EAMXX_SHOC
486 eamxx_shoc_lev->add_slow_tend(mfi,tbx,cell_rhs);
489 #ifdef ERF_USE_NATIVE_SHOC
498 BL_PROFILE(
"rhs_post_8");
502 auto const& src_arr = source.const_array(mfi);
506 if (is_valid_slow_var[ivar])
516 if (l_moving_terrain)
519 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k,
int nn) noexcept {
520 const int n = start_comp + nn;
521 cell_rhs(i,j,k,n) += src_arr(i,j,k,n);
522 Real temp_val = detJ_arr(i,j,k) * old_cons(i,j,k,n) + dt * detJ_arr(i,j,k) * cell_rhs(i,j,k,n);
523 cur_cons(i,j,k,n) = temp_val / detJ_new_arr(i,j,k);
525 cur_cons(i,j,k,n) = amrex::max(cur_cons(i,j,k,n), eps);
529 }
else if (l_anelastic && (nrk == 1)) {
532 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k,
int nn) noexcept {
533 const int n = start_comp + nn;
534 cell_rhs(i,j,k,n) += src_arr(i,j,k,n);
537 Real dt_times_old_cell_rhs = cur_cons(i,j,k,n) - old_cons(i,j,k,n);
540 cur_cons(i,j,k,n) = old_cons(i,j,k,n) +
myhalf * (dt_times_old_cell_rhs + dt * cell_rhs(i,j,k,n));
543 cur_cons(i,j,k,n) = amrex::max(cur_cons(i,j,k,n), eps);
545 cur_cons(i,j,k,n) = amrex::max(cur_cons(i,j,k,n),
amrex::Real(0));
552 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k,
int nn) noexcept {
553 const int n = start_comp + nn;
554 cell_rhs(i,j,k,n) += src_arr(i,j,k,n);
555 cur_cons(i,j,k,n) = old_cons(i,j,k,n) + dt * cell_rhs(i,j,k,n);
557 cur_cons(i,j,k,n) = amrex::max(cur_cons(i,j,k,n), eps);
559 cur_cons(i,j,k,n) = amrex::max(cur_cons(i,j,k,n),
amrex::Real(0));
570 BL_PROFILE(
"rhs_post_9");
574 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k,
int n) noexcept {
575 new_cons(i,j,k,n) = cur_cons(i,j,k,n);
579 Box xtbx = mfi.nodaltilebox(0);
580 Box ytbx = mfi.nodaltilebox(1);
581 Box ztbx = mfi.nodaltilebox(2);
584 BL_PROFILE(
"rhs_post_10()");
586 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept {
587 new_xmom(i,j,k) = cur_xmom(i,j,k);
589 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept {
590 new_ymom(i,j,k) = cur_ymom(i,j,k);
592 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept {
593 new_zmom(i,j,k) = cur_zmom(i,j,k);
598 BL_PROFILE(
"rhs_post_10");
602 int num_comp_reflux =
nvars - strt_comp_reflux;
603 if (level < finest_level) {
604 fr_as_crse->CrseAdd(mfi,
605 {{AMREX_D_DECL(&(flux[0]), &(flux[1]), &(flux[2]))}},
606 dx, dt, strt_comp_reflux, strt_comp_reflux, num_comp_reflux, RunOn::Device);
609 fr_as_fine->FineAdd(mfi,
610 {{AMREX_D_DECL(&(flux[0]), &(flux[1]), &(flux[2]))}},
611 dx, dt, strt_comp_reflux, strt_comp_reflux, num_comp_reflux, RunOn::Device);
617 Gpu::streamSynchronize();
void AdvectionSrcForScalars(const amrex::Box &bx, const int icomp, const int ncomp, const amrex::Array4< const amrex::Real > &avg_xmom, const amrex::Array4< const amrex::Real > &avg_ymom, const amrex::Array4< const amrex::Real > &avg_zmom, const amrex::Array4< const amrex::Real > &cell_prim, const amrex::Array4< amrex::Real > &src, const amrex::Array4< const amrex::Real > &vf_arr, const amrex::GpuArray< amrex::Real, AMREX_SPACEDIM > &cellSizeInv, const amrex::Array4< const amrex::Real > &mf_mx, const amrex::Array4< const amrex::Real > &mf_my, const AdvType horiz_adv_type, const AdvType vert_adv_type, const amrex::Real horiz_upw_frac, const amrex::Real vert_upw_frac, const amrex::GpuArray< const amrex::Array4< amrex::Real >, AMREX_SPACEDIM > &flx_arr, const amrex::Box &domain, const amrex::BCRec *bc_ptr_h)
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE AdvType EfficientAdvType(int nrk, AdvType adv_type)
Definition: ERF_Advection.H:281
constexpr amrex::Real zero
Definition: ERF_Constants.H:8
constexpr amrex::Real myhalf
Definition: ERF_Constants.H:13
@ nvars
Definition: ERF_DataStruct.H:98
@ v_x
Definition: ERF_DataStruct.H:24
@ u_y
Definition: ERF_DataStruct.H:25
@ v_y
Definition: ERF_DataStruct.H:25
@ m_y
Definition: ERF_DataStruct.H:25
@ u_x
Definition: ERF_DataStruct.H:24
@ m_x
Definition: ERF_DataStruct.H:24
void DiffusionSrcForState_S(const amrex::Box &bx, const amrex::Box &domain, int start_comp, int num_comp, const amrex::Array4< const amrex::Real > &u, const amrex::Array4< const amrex::Real > &v, const amrex::Array4< const amrex::Real > &cell_data, const amrex::Array4< const amrex::Real > &cell_prim, const amrex::Array4< amrex::Real > &cell_rhs, const amrex::Array4< amrex::Real > &xflux, const amrex::Array4< amrex::Real > &yflux, const amrex::Array4< amrex::Real > &zflux, const amrex::Gpu::DeviceVector< amrex::Real > &stretched_dz_d, const amrex::GpuArray< amrex::Real, AMREX_SPACEDIM > &dxInv, const amrex::Array4< const amrex::Real > &SmnSmn_a, const amrex::Array4< const amrex::Real > &mf_mx, const amrex::Array4< const amrex::Real > &mf_ux, const amrex::Array4< const amrex::Real > &mf_vx, const amrex::Array4< const amrex::Real > &mf_my, const amrex::Array4< const amrex::Real > &mf_uy, const amrex::Array4< const amrex::Real > &mf_vy, amrex::Array4< amrex::Real > &hfx_z, amrex::Array4< amrex::Real > &qfx1_z, amrex::Array4< amrex::Real > &qfx2_z, amrex::Array4< amrex::Real > &diss, const amrex::Array4< const amrex::Real > &mu_turb, const SolverChoice &solverChoice, const int level, const amrex::Array4< const amrex::Real > &tm_arr, const amrex::GpuArray< amrex::Real, AMREX_SPACEDIM > grav_gpu, const amrex::BCRec *bc_ptr, const bool use_SurfLayer, const amrex::Real implicit_fac)
void DiffusionSrcForState_T(const amrex::Box &bx, const amrex::Box &domain, int start_comp, int num_comp, const bool &rotate, const amrex::Array4< const amrex::Real > &u, const amrex::Array4< const amrex::Real > &v, const amrex::Array4< const amrex::Real > &cell_data, const amrex::Array4< const amrex::Real > &cell_prim, const amrex::Array4< amrex::Real > &cell_rhs, const amrex::Array4< amrex::Real > &xflux, const amrex::Array4< amrex::Real > &yflux, const amrex::Array4< amrex::Real > &zflux, const amrex::Array4< const amrex::Real > &z_nd, const amrex::Array4< const amrex::Real > &z_cc, const amrex::Array4< const amrex::Real > &ax, const amrex::Array4< const amrex::Real > &ay, const amrex::Array4< const amrex::Real > &az, const amrex::Array4< const amrex::Real > &detJ, const amrex::GpuArray< amrex::Real, AMREX_SPACEDIM > &dxInv, const amrex::Array4< const amrex::Real > &SmnSmn_a, const amrex::Array4< const amrex::Real > &mf_mx, const amrex::Array4< const amrex::Real > &mf_ux, const amrex::Array4< const amrex::Real > &mf_vx, const amrex::Array4< const amrex::Real > &mf_my, const amrex::Array4< const amrex::Real > &mf_uy, const amrex::Array4< const amrex::Real > &mf_vy, amrex::Array4< amrex::Real > &hfx_x, amrex::Array4< amrex::Real > &hfx_y, amrex::Array4< amrex::Real > &hfx_z, amrex::Array4< amrex::Real > &qfx1_x, amrex::Array4< amrex::Real > &qfx1_y, amrex::Array4< amrex::Real > &qfx1_z, amrex::Array4< amrex::Real > &qfx2_z, amrex::Array4< amrex::Real > &diss, const amrex::Array4< const amrex::Real > &mu_turb, const SolverChoice &solverChoice, const int level, const amrex::Array4< const amrex::Real > &tm_arr, const amrex::GpuArray< amrex::Real, AMREX_SPACEDIM > grav_gpu, const amrex::BCRec *bc_ptr, const bool use_SurfLayer, const amrex::Real implicit_fac)
void DiffusionSrcForState_N(const amrex::Box &bx, const amrex::Box &domain, int start_comp, int num_comp, const amrex::Array4< const amrex::Real > &u, const amrex::Array4< const amrex::Real > &v, const amrex::Array4< const amrex::Real > &cell_data, const amrex::Array4< const amrex::Real > &cell_prim, const amrex::Array4< amrex::Real > &cell_rhs, const amrex::Array4< amrex::Real > &xflux, const amrex::Array4< amrex::Real > &yflux, const amrex::Array4< amrex::Real > &zflux, const amrex::GpuArray< amrex::Real, AMREX_SPACEDIM > &cellSizeInv, const amrex::Array4< const amrex::Real > &SmnSmn_a, const amrex::Array4< const amrex::Real > &mf_mx, const amrex::Array4< const amrex::Real > &mf_ux, const amrex::Array4< const amrex::Real > &mf_vx, const amrex::Array4< const amrex::Real > &mf_my, const amrex::Array4< const amrex::Real > &mf_uy, const amrex::Array4< const amrex::Real > &mf_vy, amrex::Array4< amrex::Real > &hfx_z, amrex::Array4< amrex::Real > &qfx1_z, amrex::Array4< amrex::Real > &qfx2_z, amrex::Array4< amrex::Real > &diss, const amrex::Array4< const amrex::Real > &mu_turb, const SolverChoice &solverChoice, const int level, const amrex::Array4< const amrex::Real > &tm_arr, const amrex::GpuArray< amrex::Real, AMREX_SPACEDIM > grav_gpu, const amrex::BCRec *bc_ptr, const bool use_SurfLayer, const amrex::Real implicit_fac)
void EBAdvectionSrcForScalars(const amrex::Box &bx, const int icomp, const int ncomp, const amrex::Array4< const amrex::Real > &avg_xmom, const amrex::Array4< const amrex::Real > &avg_ymom, const amrex::Array4< const amrex::Real > &avg_zmom, const amrex::Array4< const amrex::Real > &cell_prim, const amrex::Array4< amrex::Real > &src, const amrex::Array4< const int > &mask_arr, const amrex::Array4< const amrex::EBCellFlag > &cfg_arr, const amrex::Array4< const amrex::Real > &ax_arr, const amrex::Array4< const amrex::Real > &ay_arr, const amrex::Array4< const amrex::Real > &az_arr, const amrex::Array4< const amrex::Real > &fcx_arr, const amrex::Array4< const amrex::Real > &fcy_arr, const amrex::Array4< const amrex::Real > &fcz_arr, const amrex::Array4< const amrex::Real > &vf_arr, const amrex::GpuArray< amrex::Real, AMREX_SPACEDIM > &cellSizeInv, const amrex::Array4< const amrex::Real > &mf_mx, const amrex::Array4< const amrex::Real > &mf_my, const AdvType horiz_adv_type, const AdvType vert_adv_type, const amrex::Real horiz_upw_frac, const amrex::Real vert_upw_frac, const amrex::GpuArray< const amrex::Array4< amrex::Real >, AMREX_SPACEDIM > &flx_arr, const amrex::Box &domain, const amrex::BCRec *bc_ptr_h, bool already_on_centroids)
const Real l_vert_implicit_fac
Definition: ERF_ImplicitPost.H:6
#define RhoScalar_comp
Definition: ERF_IndexDefines.H:40
#define RhoTheta_comp
Definition: ERF_IndexDefines.H:37
#define NSCALARS
Definition: ERF_IndexDefines.H:16
#define RhoQ1_comp
Definition: ERF_IndexDefines.H:42
AdvType
Definition: ERF_IndexDefines.H:255
#define RhoKE_comp
Definition: ERF_IndexDefines.H:38
amrex::GpuArray< Real, AMREX_SPACEDIM > dxInv
Definition: ERF_InitCustomPertVels_ParticleTests.H:17
const Real dx
Definition: ERF_InitCustomPert_ABL.H:23
AMREX_ALWAYS_ASSERT(bx.length()[2]==khi+1)
ParallelFor(grown_box, [=] AMREX_GPU_DEVICE(int i, int j, int k) { qrcuten_arr(i, j, k)=Real(0);qscuten_arr(i, j, k)=Real(0);qicuten_arr(i, j, k)=Real(0);})
amrex::Real Real
Definition: ERF_ShocInterface.H:19
@ ymom
Definition: ERF_IndexDefines.H:194
@ cons
Definition: ERF_IndexDefines.H:192
@ zmom
Definition: ERF_IndexDefines.H:195
@ xmom
Definition: ERF_IndexDefines.H:193
@ ng
Definition: ERF_Morrison.H:48
@ xvel
Definition: ERF_IndexDefines.H:175
@ yvel
Definition: ERF_IndexDefines.H:176
real(c_double), parameter epsilon
Definition: ERF_module_model_constants.F90:12
real(c_double), private ac
Definition: ERF_module_mp_morr_two_moment.F90:181
Definition: ERF_AdvStruct.H:19
Definition: ERF_DiffStruct.H:19
MolecDiffType molec_diff_type
Definition: ERF_DiffStruct.H:84
static MeshType mesh_type
Definition: ERF_DataStruct.H:1211
DiffChoice diffChoice
Definition: ERF_DataStruct.H:1220
amrex::Real gravity
Definition: ERF_DataStruct.H:1299
bool implicit_ke_diffusion
Definition: ERF_DataStruct.H:1251
bool implicit_moisture_diffusion
Definition: ERF_DataStruct.H:1250
amrex::Vector< TurbChoice > turbChoice
Definition: ERF_DataStruct.H:1223
amrex::Vector< int > anelastic
Definition: ERF_DataStruct.H:1229
AdvChoice advChoice
Definition: ERF_DataStruct.H:1219
MoistureType moisture_type
Definition: ERF_DataStruct.H:1389
static TerrainType terrain_type
Definition: ERF_DataStruct.H:1202
amrex::Vector< amrex::Vector< amrex::Real > > vert_implicit_fac
Definition: ERF_DataStruct.H:1246
bool use_rotate_surface_flux
Definition: ERF_DataStruct.H:1329
CouplingType coupling_type
Definition: ERF_DataStruct.H:1388
bool transport_scalar
Definition: ERF_DataStruct.H:1336
Definition: ERF_TurbStruct.H:82
PBLType pbl_type
Definition: ERF_TurbStruct.H:478
RANSType rans_type
Definition: ERF_TurbStruct.H:473
bool uses_eamxx_shoc() const noexcept
Definition: ERF_TurbStruct.H:480
bool advect_tke
Definition: ERF_TurbStruct.H:552
bool uses_native_shoc() const noexcept
Definition: ERF_TurbStruct.H:485
bool use_tke
Definition: ERF_TurbStruct.H:519
LESType les_type
Definition: ERF_TurbStruct.H:431
bool use_kturb
Definition: ERF_TurbStruct.H:513