Function for computing the slow RHS for the evolution equations for the density, potential temperature and momentum.
118 BL_PROFILE_REGION(
"erf_slow_rhs_pre()");
120 const BCRec* bc_ptr_d = domain_bcs_type_d.data();
121 const BCRec* bc_ptr_h = domain_bcs_type_h.data();
126 const MultiFab* t_mean_mf =
nullptr;
127 if (SurfLayer) { t_mean_mf = SurfLayer->get_mac_avg(level,2); }
129 const Box& domain = geom.Domain();
130 int klo = domain.smallEnd(2);
131 int khi = domain.bigEnd(2);
137 const bool l_use_stretched_dz = (solverChoice.
mesh_type == MeshType::StretchedDz);
138 const bool l_use_terrain_fitted_coords = (solverChoice.
mesh_type == MeshType::VariableDz);
139 const bool l_moving_terrain = (solverChoice.
terrain_type == TerrainType::MovingFittedMesh);
140 if (l_moving_terrain)
AMREX_ALWAYS_ASSERT (l_use_stretched_dz || l_use_terrain_fitted_coords);
147 const bool l_need_SmnSmn = tc.
use_keqn;
152 const bool l_use_moisture = (solverChoice.
moisture_type != MoistureType::None);
153 const bool l_use_SurfLayer = (SurfLayer !=
nullptr);
154 bool l_apply_surface_layer_fluxes_in_diffusion = l_use_SurfLayer;
157 const bool l_anelastic = (solverChoice.
anelastic[level] == 1);
158 const bool l_fixed_rho = (solverChoice.
fixed_density[level] == 1);
160 const bool l_reflux = ( (solverChoice.
coupling_type == CouplingType::TwoWay) && (finest_level > 0) &&
161 ( (l_anelastic && nrk == 1) || (!l_anelastic && nrk == 2) ) );
163 const bool l_use_eb = (solverChoice.
terrain_type == TerrainType::EB);
165 const GpuArray<Real, AMREX_SPACEDIM>
dxInv = geom.InvCellSizeArray();
166 const Real*
dx = geom.CellSize();
171 const Array<Real,AMREX_SPACEDIM> grav{
zero,
zero, -solverChoice.
gravity};
172 const GpuArray<Real,AMREX_SPACEDIM> grav_gpu{grav[0], grav[1], grav[2]};
188 const DistributionMapping& dm = S_data[
IntVars::cons].DistributionMap();
190 int nGhost = (l_use_eb) ? 2 : 1;
191 MultiFab Omega(convert(ba,IntVect(0,0,1)), dm, 1, nGhost);
193 std::unique_ptr<MultiFab> expr;
194 std::unique_ptr<MultiFab> dflux_x;
195 std::unique_ptr<MultiFab> dflux_y;
196 std::unique_ptr<MultiFab> dflux_z;
199 #ifdef ERF_USE_EAMXX_SHOC
204 eamxx_shoc_lev->set_eddy_diffs();
207 #ifdef ERF_USE_NATIVE_SHOC
213 native_shoc_lev->set_eddy_diffs();
219 Tau_lev,Tau_corr_lev,
220 SmnSmn,eddyDiffs,geom,solverChoice,SurfLayer,
221 stretched_dz_d, detJ,mapfac, ax, ay, az, ebfact);
224 dflux_x = std::make_unique<MultiFab>(convert(ba,IntVect(1,0,0)), dm,
nvars,
ng);
225 dflux_y = std::make_unique<MultiFab>(convert(ba,IntVect(0,1,0)), dm,
nvars,
ng);
226 dflux_z = std::make_unique<MultiFab>(convert(ba,IntVect(0,0,1)), dm,
nvars, 0);
228 bool surface_layer_handled =
false;
229 #ifdef ERF_USE_EAMXX_SHOC
234 eamxx_shoc_lev->set_diff_stresses();
235 surface_layer_handled =
true;
238 #ifdef ERF_USE_NATIVE_SHOC
241 if (native_shoc_lev->owns_scalar_surface_fluxes()) {
242 l_apply_surface_layer_fluxes_in_diffusion =
false;
244 if (!native_shoc_lev->needs_host_surface_momentum_stresses()) {
245 surface_layer_handled =
true;
249 if (!surface_layer_handled && l_use_SurfLayer) {
252 SurfLayer->impose_SurfaceLayer_bcs(level, mfs, Tau_lev,
261 SurfLayer->impose_SurfaceLayer_bcs_EB(level, mfs, Tau_EB,
263 Q1fx1, Q1fx2, Q1fx3);
266 if (tc.
uses_native_shoc() && native_shoc_lev && native_shoc_lev->owns_scalar_surface_fluxes()) {
270 native_shoc_lev->set_diff_stresses();
281 bool already_on_centroids =
false;
282 Vector<iMultiFab> physbnd_mask;
286 physbnd_mask[
IntVars::cons].BuildMask(geom.Domain(), geom.periodicity(), 1, 1, 0, 1);
288 for (
int dir = 0; dir < AMREX_SPACEDIM; ++dir) {
289 physbnd_mask[1+dir].define(S_data[1+dir].boxArray(), S_data[1+dir].DistributionMap(), 1, 1);
290 physbnd_mask[1+dir].BuildMask(geom.Domain(), geom.periodicity(), 1, 1, 0, 1);
296 #pragma omp parallel if (Gpu::notInLaunchRegion())
299 BL_PROFILE(
"slow_rhs_making_omega");
302 Box bx = mfi.tilebox();
304 IntVect nGrowVect = (l_use_eb)
305 ? IntVect(AMREX_D_DECL(2, 2, 2)) : IntVect(AMREX_D_DECL(1, 1, 1));
306 Box gbxo = surroundingNodes(bx,2); gbxo.grow(nGrowVect);
308 const Array4<const Real>& rho_u = S_data[
IntVars::xmom].array(mfi);
309 const Array4<const Real>& rho_v = S_data[
IntVars::ymom].array(mfi);
310 const Array4<const Real>& rho_w = S_data[
IntVars::zmom].array(mfi);
311 const Array4< Real>& omega_arr = Omega.array(mfi);
318 if (!l_use_terrain_fitted_coords) {
319 ParallelFor(gbxo, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept {
320 omega_arr(i,j,k) = rho_w(i,j,k);
325 Box gbxo_lo = gbxo; gbxo_lo.setBig(2,domain.smallEnd(2));
326 int lo_z_face = domain.smallEnd(2);
327 if (gbxo_lo.smallEnd(2) <= lo_z_face) {
328 ParallelFor(gbxo_lo, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept {
329 omega_arr(i,j,k) =
zero;
332 Box gbxo_hi = gbxo; gbxo_hi.setSmall(2,gbxo.bigEnd(2));
333 int hi_z_face = domain.bigEnd(2)+1;
334 if (gbxo_hi.bigEnd(2) >= hi_z_face) {
335 ParallelFor(gbxo_hi, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept {
336 omega_arr(i,j,k) = rho_w(i,j,k);
340 const Array4<const Real>& z_nd = z_phys_nd.const_array(mfi);
341 const Array4<const Real>& mf_ux = mapfac[
MapFacType::u_x]->const_array(mfi);
342 const Array4<const Real>& mf_vy = mapfac[
MapFacType::v_y]->const_array(mfi);
345 Box gbxo_mid = gbxo; gbxo_mid.setSmall(2,1); gbxo_mid.setBig(2,gbxo.bigEnd(2)-1);
346 Array4<const Real> z_t = z_t_mf->array(mfi);
347 const Array4<const Real>& cell_data = S_data[
IntVars::cons].array(mfi);
348 ParallelFor(gbxo_mid, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept {
351 omega_arr(i,j,k) =
OmegaFromW(i,j,k,rho_w(i,j,k),
352 rho_u,rho_v,mf_ux,mf_vy,z_nd,
dxInv) -
353 rho_at_face * z_t(i,j,k);
357 if (gbxo_mid.smallEnd(2) <= domain.smallEnd(2)) {
358 gbxo_mid.setSmall(2,1);
360 if (gbxo_mid.bigEnd(2) >= domain.bigEnd(2)+1) {
361 gbxo_mid.setBig(2,gbxo.bigEnd(2)-1);
363 ParallelFor(gbxo_mid, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept {
364 omega_arr(i,j,k) =
OmegaFromW(i,j,k,rho_w(i,j,k),
365 rho_u,rho_v,mf_ux,mf_vy,z_nd,
dxInv);
373 Omega.FillBoundary(geom.periodicity());
376 #pragma omp parallel if (Gpu::notInLaunchRegion())
381 Box bx = mfi.tilebox();
382 Box tbx = mfi.nodaltilebox(0);
383 Box tby = mfi.nodaltilebox(1);
384 Box tbz = mfi.nodaltilebox(2);
387 Vector<Box> tbx_grown(AMREX_SPACEDIM);
388 Vector<Box> tby_grown(AMREX_SPACEDIM);
389 Vector<Box> tbz_grown(AMREX_SPACEDIM);
391 for (
int dir = 0; dir < AMREX_SPACEDIM; ++dir) {
392 tbx_grown[dir] = tbx;
393 tby_grown[dir] = tby;
394 tbz_grown[dir] = tbz;
397 tbx_grown[dir] = (tbx_grown[dir].growHi(dir,1)).grow(iv);
398 tby_grown[dir] = (tby_grown[dir].growHi(dir,1)).grow(iv);
399 tbz_grown[dir] = (tbz_grown[dir].growHi(dir,1)).grow(iv);
404 if (tbz.smallEnd(2) == domain.smallEnd(2)) {
407 if (tbz.bigEnd(2) == domain.bigEnd(2)+1) {
411 const Array4<const Real> & cell_data = S_data[
IntVars::cons].array(mfi);
412 const Array4<const Real> & cell_prim = S_prim.array(mfi);
413 const Array4<Real> & cell_rhs = S_rhs[
IntVars::cons].array(mfi);
415 const Array4<const Real> & cell_old = S_old[
IntVars::cons].array(mfi);
417 const Array4<Real const>& xmom_src_arr = xmom_src.const_array(mfi);
418 const Array4<Real const>& ymom_src_arr = ymom_src.const_array(mfi);
419 const Array4<Real const>& zmom_src_arr = zmom_src.const_array(mfi);
420 const Array4<Real const>& buoyancy_arr = buoyancy.const_array(mfi);
422 const Array4<Real const>& gpx_arr = gradp[
GpVars::gpx].const_array(mfi);
423 const Array4<Real const>& gpy_arr = gradp[
GpVars::gpy].const_array(mfi);
424 const Array4<Real const>& gpz_arr = gradp[
GpVars::gpz].const_array(mfi);
426 const Array4<Real const>& qt_arr =
qt.const_array(mfi);
428 const Array4<Real>& rho_u_old = S_old[
IntVars::xmom].array(mfi);
429 const Array4<Real>& rho_v_old = S_old[
IntVars::ymom].array(mfi);
433 avg_xmom[mfi].template setVal<RunOn::Device>(0,tbx);
434 avg_ymom[mfi].template setVal<RunOn::Device>(0,tby);
435 avg_zmom[mfi].template setVal<RunOn::Device>(0,tbz);
438 Array4<Real> avg_xmom_arr = avg_xmom.array(mfi);
439 Array4<Real> avg_ymom_arr = avg_ymom.array(mfi);
440 Array4<Real> avg_zmom_arr = avg_zmom.array(mfi);
442 const Array4<const Real> & u =
xvel.array(mfi);
443 const Array4<const Real> & v =
yvel.array(mfi);
444 const Array4<const Real> & w =
zvel.array(mfi);
446 const Array4<const Real>& rho_u = S_data[
IntVars::xmom].array(mfi);
447 const Array4<const Real>& rho_v = S_data[
IntVars::ymom].array(mfi);
450 const Array4<const Real>& mf_mx = mapfac[
MapFacType::m_x]->const_array(mfi);
451 const Array4<const Real>& mf_ux = mapfac[
MapFacType::u_x]->const_array(mfi);
452 const Array4<const Real>& mf_vx = mapfac[
MapFacType::v_x]->const_array(mfi);
453 const Array4<const Real>& mf_my = mapfac[
MapFacType::m_y]->const_array(mfi);
454 const Array4<const Real>& mf_uy = mapfac[
MapFacType::u_y]->const_array(mfi);
455 const Array4<const Real>& mf_vy = mapfac[
MapFacType::v_y]->const_array(mfi);
457 const Array4< Real>& omega_arr = Omega.array(mfi);
459 Array4<const Real> z_t;
461 z_t = z_t_mf->array(mfi);
463 z_t = Array4<const Real>{};
466 const Array4<Real>& rho_u_rhs = S_rhs[
IntVars::xmom].array(mfi);
467 const Array4<Real>& rho_v_rhs = S_rhs[
IntVars::ymom].array(mfi);
468 const Array4<Real>& rho_w_rhs = S_rhs[
IntVars::zmom].array(mfi);
470 const Array4<Real const>& mu_turb = l_use_turb ? eddyDiffs->const_array(mfi) : Array4<const Real>{};
473 const Array4<const Real>& z_nd = z_phys_nd.const_array(mfi);
474 const Array4<const Real>& z_cc = z_phys_cc.const_array(mfi);
479 std::array<FArrayBox,AMREX_SPACEDIM> flux;
480 std::array<FArrayBox,AMREX_SPACEDIM> flux_u;
481 std::array<FArrayBox,AMREX_SPACEDIM> flux_v;
482 std::array<FArrayBox,AMREX_SPACEDIM> flux_w;
484 for (
int dir = 0; dir < AMREX_SPACEDIM; ++dir) {
486 flux[dir].resize(surroundingNodes(bx,dir),2,The_Async_Arena());
488 flux[dir].resize(surroundingNodes(bx,dir).grow(1),2,The_Async_Arena());
490 flux[dir].setVal<RunOn::Device>(0);
492 const GpuArray<const Array4<Real>, AMREX_SPACEDIM>
493 flx_arr{{AMREX_D_DECL(flux[0].array(), flux[1].array(), flux[2].array())}};
496 GpuArray<Array4<Real>, AMREX_SPACEDIM> flx_u_arr{};
497 GpuArray<Array4<Real>, AMREX_SPACEDIM> flx_v_arr{};
498 GpuArray<Array4<Real>, AMREX_SPACEDIM> flx_w_arr{};
501 for (
int dir = 0; dir < AMREX_SPACEDIM; ++dir) {
502 flux_u[dir].resize(tbx_grown[dir],1,The_Async_Arena());
503 flux_v[dir].resize(tby_grown[dir],1,The_Async_Arena());
504 flux_w[dir].resize(tbz_grown[dir],1,The_Async_Arena());
505 flux_u[dir].setVal<RunOn::Device>(0);
506 flux_v[dir].setVal<RunOn::Device>(0);
507 flux_w[dir].setVal<RunOn::Device>(0);
508 flx_u_arr[dir] = flux_u[dir].array();
509 flx_v_arr[dir] = flux_v[dir].array();
510 flx_w_arr[dir] = flux_w[dir].array();
525 tau11 = Array4<Real>{};
tau22 = Array4<Real>{};
tau33 = Array4<Real>{};
526 tau12 = Array4<Real>{};
tau13 = Array4<Real>{};
tau23 = Array4<Real>{};
535 tau21 = Array4<Real>{};
tau31 = Array4<Real>{};
tau32 = Array4<Real>{};
539 Array4<Real> u_tau_eb13, u_tau_eb23;
540 Array4<Real> v_tau_eb13, v_tau_eb23;
541 Array4<Real> w_tau_eb13, w_tau_eb23;
555 Array4<Real> SmnSmn_a;
557 SmnSmn_a = SmnSmn->array(mfi);
559 SmnSmn_a = Array4<Real>{};
565 bool l_eb_terrain_cc =
false;
566 Array4<const int> mask_arr{};
567 Array4<const EBCellFlag> cfg_arr{};
568 Array4<const Real> ax_arr{};
569 Array4<const Real> ay_arr{};
570 Array4<const Real> az_arr{};
571 Array4<const Real> fcx_arr{};
572 Array4<const Real> fcy_arr{};
573 Array4<const Real> fcz_arr{};
574 Array4<const Real> detJ_arr{};
575 Array4<const Real> barea_arr{};
576 Array4<const Real> bcent_arr{};
580 EBCellFlagFab
const& cfg = (ebfact.
get_const_factory())->getMultiEBCellFlagFab()[mfi];
581 cfg_arr = cfg.const_array();
582 if (cfg.getType(bx) == FabType::singlevalued) {
583 l_eb_terrain_cc =
true;
595 ax_arr = ax.const_array(mfi);
596 ay_arr = ay.const_array(mfi);
597 az_arr = az.const_array(mfi);
598 detJ_arr = detJ.const_array(mfi);
601 ax_arr = ax.const_array(mfi);
602 ay_arr = ay.const_array(mfi);
603 az_arr = az.const_array(mfi);
604 detJ_arr = detJ.const_array(mfi);
608 if (!l_eb_terrain_cc){
610 rho_u, rho_v, omega_arr,
611 avg_xmom_arr, avg_ymom_arr, avg_zmom_arr,
612 ax_arr, ay_arr, az_arr, detJ_arr,
613 dxInv, mf_mx, mf_my, mf_uy, mf_vx,
614 flx_arr, l_fixed_rho);
616 avg_xmom_arr, avg_ymom_arr, avg_zmom_arr,
618 detJ_arr,
dxInv, mf_mx, mf_my,
619 l_horiz_adv_type, l_vert_adv_type,
620 l_horiz_upw_frac, l_vert_upw_frac,
621 flx_arr, domain, bc_ptr_h);
624 rho_u, rho_v, omega_arr,
625 avg_xmom_arr, avg_ymom_arr, avg_zmom_arr,
627 ax_arr, ay_arr, az_arr,
628 fcx_arr, fcy_arr, fcz_arr, detJ_arr,
629 dxInv, mf_mx, mf_my, mf_uy, mf_vx,
630 flx_arr, l_fixed_rho,
631 already_on_centroids);
633 avg_xmom_arr, avg_ymom_arr, avg_zmom_arr,
635 mask_arr, cfg_arr, ax_arr, ay_arr, az_arr,
636 fcx_arr, fcy_arr, fcz_arr,
637 detJ_arr,
dxInv, mf_mx, mf_my,
638 l_horiz_adv_type, l_vert_adv_type,
639 l_horiz_upw_frac, l_vert_upw_frac,
640 flx_arr, domain, bc_ptr_h,
641 already_on_centroids);
645 Array4<Real> diffflux_x = dflux_x->array(mfi);
646 Array4<Real> diffflux_y = dflux_y->array(mfi);
647 Array4<Real> diffflux_z = dflux_z->array(mfi);
649 Array4<Real> hfx_x = Hfx1->array(mfi);
650 Array4<Real> hfx_y = Hfx2->array(mfi);
651 Array4<Real> hfx_z = Hfx3->array(mfi);
652 Array4<Real> hfx_EB{};
654 hfx_EB = Hfx3_EB->array(mfi);
657 Array4<Real> q1fx_x = (Q1fx1) ? Q1fx1->array(mfi) : Array4<Real>{};
658 Array4<Real> q1fx_y = (Q1fx2) ? Q1fx2->array(mfi) : Array4<Real>{};
659 Array4<Real> q1fx_z = (Q1fx3) ? Q1fx3->array(mfi) : Array4<Real>{};
661 Array4<Real> q2fx_z = (Q2fx3) ? Q2fx3->array(mfi) : Array4<Real>{};
662 Array4<Real> diss = Diss->array(mfi);
664 const Array4<const Real> tm_arr = t_mean_mf ? t_mean_mf->const_array(mfi) : Array4<const Real>{};
673 if (l_use_stretched_dz) {
675 cell_data, cell_prim, cell_rhs,
676 diffflux_x, diffflux_y, diffflux_z,
677 stretched_dz_d,
dxInv, SmnSmn_a,
680 hfx_z, q1fx_z, q2fx_z, diss,
681 mu_turb, solverChoice, level,
682 tm_arr, grav_gpu, bc_ptr_d, l_apply_surface_layer_fluxes_in_diffusion,
l_vert_implicit_fac);
683 }
else if (l_use_terrain_fitted_coords) {
685 cell_data, cell_prim, cell_rhs,
686 diffflux_x, diffflux_y, diffflux_z,
687 z_nd, z_cc, ax_arr, ay_arr, az_arr, detJ_arr,
691 hfx_x, hfx_y, hfx_z, q1fx_x, q1fx_y, q1fx_z, q2fx_z, diss,
692 mu_turb, solverChoice, level,
693 tm_arr, grav_gpu, bc_ptr_d, l_apply_surface_layer_fluxes_in_diffusion,
l_vert_implicit_fac);
694 }
else if (l_use_eb) {
696 cell_data, cell_prim, cell_rhs,
697 diffflux_x, diffflux_y, diffflux_z,
698 cfg_arr, ax_arr, ay_arr, az_arr, detJ_arr,
699 barea_arr, bcent_arr,
701 hfx_z, q1fx_z, q2fx_z, hfx_EB,
702 mu_turb, solverChoice, level,
703 bc_ptr_d, l_apply_surface_layer_fluxes_in_diffusion);
706 cell_data, cell_prim, cell_rhs,
707 diffflux_x, diffflux_y, diffflux_z,
711 hfx_z, q1fx_z, q2fx_z, diss,
712 mu_turb, solverChoice, level,
713 tm_arr, grav_gpu, bc_ptr_d, l_apply_surface_layer_fluxes_in_diffusion,
l_vert_implicit_fac);
717 const Array4<Real const>& source_arr = cc_src.const_array(mfi);
718 ParallelFor(bx, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept
725 if ( l_anelastic && (nrk == 1) )
727 ParallelFor(bx, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept
740 int lo_z_face = domain.smallEnd(2);
741 int hi_z_face = domain.bigEnd(2)+1;
744 rho_u_rhs, rho_v_rhs, rho_w_rhs,
746 rho_u, rho_v, omega_arr,
747 z_nd, ax_arr, ay_arr, az_arr,
748 detJ_arr, stretched_dz_d,
749 dxInv, mf_mx, mf_ux, mf_vx, mf_my, mf_uy, mf_vy,
750 l_horiz_adv_type, l_vert_adv_type,
751 l_horiz_upw_frac, l_vert_upw_frac,
753 ebfact, flx_u_arr, flx_v_arr, flx_w_arr,
754 physbnd_mask, already_on_centroids,
755 lo_z_face, hi_z_face, domain, bc_ptr_h);
765 rho_u_rhs, rho_v_rhs, rho_w_rhs,
768 detJ_arr, stretched_dz_d,
dxInv,
772 l_use_terrain_fitted_coords);
775 rho_u_rhs, rho_v_rhs, rho_w_rhs,
779 u_tau_eb13, u_tau_eb23, v_tau_eb13, v_tau_eb23, w_tau_eb13, w_tau_eb23,
783 solverChoice, ebfact, bc_ptr_d);
790 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k)
795 Real q = (l_use_moisture) ?
myhalf * (qt_arr(i,j,k) + qt_arr(i-1,j,k)) :
zero;
797 rho_u_rhs(i, j, k) += (-gpx_arr(i,j,k) - abl_pressure_grad[0]) / (
one +
q) + xmom_src_arr(i,j,k);
799 if (l_moving_terrain) {
801 rho_u_rhs(i, j, k) *= h_zeta;
804 if ( l_anelastic && (nrk == 1) ) {
805 rho_u_rhs(i,j,k) *=
myhalf;
806 rho_u_rhs(i,j,k) +=
myhalf / dt * (rho_u(i,j,k) - rho_u_old(i,j,k));
809 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k)
814 Real q = (l_use_moisture) ?
myhalf * (qt_arr(i,j,k) + qt_arr(i,j-1,k)) :
zero;
816 rho_v_rhs(i, j, k) += (-gpy_arr(i,j,k) - abl_pressure_grad[1]) / (
one +
q) + ymom_src_arr(i,j,k);
818 if (l_moving_terrain) {
820 rho_v_rhs(i, j, k) *= h_zeta;
823 if ( l_anelastic && (nrk == 1) ) {
824 rho_v_rhs(i,j,k) *=
myhalf;
825 rho_v_rhs(i,j,k) +=
myhalf / dt * (rho_v(i,j,k) - rho_v_old(i,j,k));
834 if (bx.smallEnd(0) == domain.smallEnd(0)) {
835 Box lo_x_dom_face(bx); lo_x_dom_face.setBig(0,bx.smallEnd(0));
837 ParallelFor(lo_x_dom_face, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) {
838 rho_u_rhs(i,j,k) =
zero;
841 ParallelFor(lo_x_dom_face, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) {
842 if (u(i,j,k) >=
zero) {
843 rho_u_rhs(i,j,k) =
zero;
848 if (bx.bigEnd(0) == domain.bigEnd(0)) {
849 Box hi_x_dom_face(bx); hi_x_dom_face.setSmall(0,bx.bigEnd(0)+1); hi_x_dom_face.setBig(0,bx.bigEnd(0)+1);
851 ParallelFor(hi_x_dom_face, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) {
852 rho_u_rhs(i,j,k) =
zero;
855 ParallelFor(hi_x_dom_face, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) {
856 if (u(i,j,k) <=
zero) {
857 rho_u_rhs(i,j,k) =
zero;
862 if (bx.smallEnd(1) == domain.smallEnd(1)) {
863 Box lo_y_dom_face(bx); lo_y_dom_face.setBig(1,bx.smallEnd(1));
865 ParallelFor(lo_y_dom_face, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) {
866 rho_v_rhs(i,j,k) =
zero;
869 ParallelFor(lo_y_dom_face, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) {
870 if (v(i,j,k) >=
zero) {
871 rho_v_rhs(i,j,k) =
zero;
876 if (bx.bigEnd(1) == domain.bigEnd(1)) {
877 Box hi_y_dom_face(bx); hi_y_dom_face.setSmall(1,bx.bigEnd(1)+1); hi_y_dom_face.setBig(1,bx.bigEnd(1)+1);
879 ParallelFor(hi_y_dom_face, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) {
880 rho_v_rhs(i,j,k) =
zero;
883 ParallelFor(hi_y_dom_face, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) {
884 if (v(i,j,k) <=
zero) {
885 rho_v_rhs(i,j,k) =
zero;
891 ParallelFor(tbz, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k)
896 Real q = (l_use_moisture) ?
myhalf * (qt_arr(i,j,k) + qt_arr(i,j,k-1)) :
zero;
898 rho_w_rhs(i, j, k) += (-
gpz - abl_pressure_grad[2] + buoyancy_arr(i,j,k)) / (
one +
q) + zmom_src_arr(i,j,k);
900 if (l_moving_terrain) {
901 rho_w_rhs(i, j, k) *=
myhalf * (detJ_arr(i,j,k) + detJ_arr(i,j,k-1));
905 auto const lo = lbound(bx);
906 auto const hi = ubound(bx);
911 const Array4<const Real>& rho_w_rhs_crse = zmom_crse_rhs->const_array(mfi);
913 Box b2d = bx; b2d.setRange(2,0);
916 ParallelFor(b2d, [=] AMREX_GPU_DEVICE (
int i,
int j,
int )
918 rho_w_rhs(i,j,lo.z) = rho_w_rhs_crse(i,j,lo.z);
923 ParallelFor(b2d, [=] AMREX_GPU_DEVICE (
int i,
int j,
int )
925 rho_w_rhs(i,j,hi.z+1) = rho_w_rhs_crse(i,j,hi.z+1);
931 BL_PROFILE(
"slow_rhs_pre_fluxreg");
936 int strt_comp_reflux = (l_fixed_rho) ? 1 : 0;
937 int num_comp_reflux = 1;
938 if (level < finest_level) {
939 fr_as_crse->CrseAdd(mfi,
940 {{AMREX_D_DECL(&(flux[0]), &(flux[1]), &(flux[2]))}},
941 dx, dt, strt_comp_reflux, strt_comp_reflux, num_comp_reflux, RunOn::Device);
944 fr_as_fine->FineAdd(mfi,
945 {{AMREX_D_DECL(&(flux[0]), &(flux[1]), &(flux[2]))}},
946 dx, dt, strt_comp_reflux, strt_comp_reflux, num_comp_reflux, RunOn::Device);
void AdvectionSrcForRho(const amrex::Box &bx, const amrex::Array4< amrex::Real > &src, const amrex::Array4< const amrex::Real > &rho_u, const amrex::Array4< const amrex::Real > &rho_v, const amrex::Array4< const amrex::Real > &omega, const amrex::Array4< amrex::Real > &avg_xmom, const amrex::Array4< amrex::Real > &avg_ymom, const amrex::Array4< amrex::Real > &avg_zmom, 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 > &detJ, 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 amrex::Array4< const amrex::Real > &mf_uy, const amrex::Array4< const amrex::Real > &mf_vx, const amrex::GpuArray< const amrex::Array4< amrex::Real >, AMREX_SPACEDIM > &flx_arr, const bool fixed_rho)
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)
void AdvectionSrcForMom(const amrex::MFIter &mfi, const amrex::Box &bx, const amrex::Box &bxx, const amrex::Box &bxy, const amrex::Box &bxz, const amrex::Vector< amrex::Box > &bxx_grown, const amrex::Vector< amrex::Box > &bxy_grown, const amrex::Vector< amrex::Box > &bxz_grown, const amrex::Array4< amrex::Real > &rho_u_rhs, const amrex::Array4< amrex::Real > &rho_v_rhs, const amrex::Array4< amrex::Real > &rho_w_rhs, const amrex::Array4< const amrex::Real > &rho, const amrex::Array4< const amrex::Real > &u, const amrex::Array4< const amrex::Real > &v, const amrex::Array4< const amrex::Real > &w, const amrex::Array4< const amrex::Real > &rho_u, const amrex::Array4< const amrex::Real > &rho_v, const amrex::Array4< const amrex::Real > &Omega, const amrex::Array4< const amrex::Real > &z_nd, 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, amrex::Gpu::DeviceVector< amrex::Real > &stretched_dz_d, const amrex::GpuArray< amrex::Real, AMREX_SPACEDIM > &cellSizeInv, 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, const AdvType horiz_adv_type, const AdvType vert_adv_type, const amrex::Real horiz_upw_frac, const amrex::Real vert_upw_frac, MeshType &mesh_type, TerrainType &terrain_type, const eb_ &ebfact, amrex::GpuArray< amrex::Array4< amrex::Real >, AMREX_SPACEDIM > &flx_u_arr, amrex::GpuArray< amrex::Array4< amrex::Real >, AMREX_SPACEDIM > &flx_v_arr, amrex::GpuArray< amrex::Array4< amrex::Real >, AMREX_SPACEDIM > &flx_w_arr, const amrex::Vector< amrex::iMultiFab > &physbnd_mask, const bool already_on_centroids, const int lo_z_face, const int hi_z_face, const amrex::Box &domain, const amrex::BCRec *bc_ptr_h)
constexpr amrex::Real one
Definition: ERF_Constants.H:9
constexpr amrex::Real zero
Definition: ERF_Constants.H:8
constexpr amrex::Real myhalf
Definition: ERF_Constants.H:13
@ tau12
Definition: ERF_DataStruct.H:32
@ tau23
Definition: ERF_DataStruct.H:32
@ tau33
Definition: ERF_DataStruct.H:32
@ tau22
Definition: ERF_DataStruct.H:32
@ tau11
Definition: ERF_DataStruct.H:32
@ tau32
Definition: ERF_DataStruct.H:32
@ tau31
Definition: ERF_DataStruct.H:32
@ tau21
Definition: ERF_DataStruct.H:32
@ tau13
Definition: ERF_DataStruct.H:32
@ 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 DiffusionSrcForMom(const amrex::Box &bxx, const amrex::Box &bxy, const amrex::Box &bxz, const amrex::Array4< amrex::Real > &rho_u_rhs, const amrex::Array4< amrex::Real > &rho_v_rhs, const amrex::Array4< amrex::Real > &rho_w_rhs, const amrex::Array4< const amrex::Real > &tau11, const amrex::Array4< const amrex::Real > &tau22, const amrex::Array4< const amrex::Real > &tau33, const amrex::Array4< const amrex::Real > &tau12, const amrex::Array4< const amrex::Real > &tau21, const amrex::Array4< const amrex::Real > &tau13, const amrex::Array4< const amrex::Real > &tau31, const amrex::Array4< const amrex::Real > &tau23, const amrex::Array4< const amrex::Real > &tau32, const amrex::Array4< const amrex::Real > &detJ_arr, const amrex::Gpu::DeviceVector< amrex::Real > &stretched_dz_d, const amrex::GpuArray< amrex::Real, AMREX_SPACEDIM > &dxInv, 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, const bool use_stretched_dz, const bool use_variable_dz)
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 DiffusionSrcForState_EB(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::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 > &detJ, const amrex::Array4< const amrex::Real > &barea_arr, const amrex::Array4< const amrex::Real > &bcent_arr, const amrex::Real *dx_arr, const amrex::GpuArray< amrex::Real, AMREX_SPACEDIM > &cellSizeInv, amrex::Array4< amrex::Real > &hfx_z, amrex::Array4< amrex::Real > &qfx1_z, amrex::Array4< amrex::Real > &qfx2_z, amrex::Array4< amrex::Real > &hfx_EB, const amrex::Array4< const amrex::Real > &mu_turb, const SolverChoice &solverChoice, const int level, const amrex::BCRec *bc_ptr, const bool use_SurfLayer)
void DiffusionSrcForMom_EB(const amrex::MFIter &mfi, [[maybe_unused]] const amrex::Box &domain, const amrex::Box &bxx, const amrex::Box &bxy, const amrex::Box &bxz, const amrex::Array4< amrex::Real > &rho_u_rhs, const amrex::Array4< amrex::Real > &rho_v_rhs, const amrex::Array4< amrex::Real > &rho_w_rhs, const amrex::Array4< const amrex::Real > &u_arr, const amrex::Array4< const amrex::Real > &v_arr, const amrex::Array4< const amrex::Real > &w_arr, const amrex::Array4< const amrex::Real > &tau11, const amrex::Array4< const amrex::Real > &tau22, const amrex::Array4< const amrex::Real > &tau33, const amrex::Array4< const amrex::Real > &tau12, const amrex::Array4< const amrex::Real > &tau13, const amrex::Array4< const amrex::Real > &tau23, const amrex::Array4< const amrex::Real > &u_tau_eb13, const amrex::Array4< const amrex::Real > &u_tau_eb23, const amrex::Array4< const amrex::Real > &v_tau_eb13, const amrex::Array4< const amrex::Real > &v_tau_eb23, const amrex::Array4< const amrex::Real > &w_tau_eb13, const amrex::Array4< const amrex::Real > &w_tau_eb23, const amrex::Real *dx_arr, const amrex::GpuArray< amrex::Real, AMREX_SPACEDIM > &dxInv, 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, const SolverChoice &solverChoice, const eb_ &ebfact, [[maybe_unused]] const amrex::BCRec *bc_ptr)
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)
void EBAdvectionSrcForRho(const amrex::Box &bx, const amrex::Array4< amrex::Real > &src, const amrex::Array4< const amrex::Real > &rho_u, const amrex::Array4< const amrex::Real > &rho_v, const amrex::Array4< const amrex::Real > &omega, const amrex::Array4< amrex::Real > &avg_xmom, const amrex::Array4< amrex::Real > &avg_ymom, const amrex::Array4< amrex::Real > &avg_zmom, 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 > &detJ, 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 amrex::Array4< const amrex::Real > &mf_uy, const amrex::Array4< const amrex::Real > &mf_vx, const amrex::GpuArray< const amrex::Array4< amrex::Real >, AMREX_SPACEDIM > &flx_arr, const bool fixed_rho, bool already_on_centroids)
@ tau_eb23
Definition: ERF_EBStruct.H:16
@ tau_eb13
Definition: ERF_EBStruct.H:16
@ yface
Definition: ERF_EBStruct.H:20
@ zface
Definition: ERF_EBStruct.H:20
@ xface
Definition: ERF_EBStruct.H:20
const Real l_vert_implicit_fac
Definition: ERF_ImplicitPost.H:6
#define Rho_comp
Definition: ERF_IndexDefines.H:36
#define RhoTheta_comp
Definition: ERF_IndexDefines.H:37
AdvType
Definition: ERF_IndexDefines.H:255
amrex::GpuArray< Real, AMREX_SPACEDIM > dxInv
Definition: ERF_InitCustomPertVels_ParticleTests.H:17
const Real dx
Definition: ERF_InitCustomPert_ABL.H:23
const int khi
Definition: ERF_InitCustomPert_Bubble.H:21
AMREX_ALWAYS_ASSERT(bx.length()[2]==khi+1)
void erf_make_tau_terms(int level, int nrk, const Vector< BCRec > &domain_bcs_type_h, const MultiFab &z_phys_nd, Vector< MultiFab > &S_data, const MultiFab &xvel, const MultiFab &yvel, const MultiFab &zvel, Vector< std::unique_ptr< MultiFab >> &Tau_lev, Vector< std::unique_ptr< MultiFab >> &Tau_corr_lev, MultiFab *SmnSmn, MultiFab *eddyDiffs, const Geometry geom, const SolverChoice &solverChoice, std::unique_ptr< SurfaceLayer > &, Gpu::DeviceVector< Real > &stretched_dz_d, const MultiFab &detJ, Vector< std::unique_ptr< MultiFab >> &mapfac, const MultiFab &ax, const MultiFab &ay, const MultiFab &az, const eb_ &ebfact)
Definition: ERF_MakeTauTerms.cpp:12
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
AMREX_GPU_DEVICE AMREX_FORCE_INLINE amrex::Real OmegaFromW(int &i, int &j, int &k, amrex::Real w, const amrex::Array4< const amrex::Real > &u_arr, const amrex::Array4< const amrex::Real > &v_arr, const amrex::Array4< const amrex::Real > &mf_u, const amrex::Array4< const amrex::Real > &mf_v, const amrex::Array4< const amrex::Real > &z_nd, const amrex::GpuArray< amrex::Real, AMREX_SPACEDIM > &dxInv)
Definition: ERF_TerrainMetrics.H:414
AMREX_GPU_DEVICE AMREX_FORCE_INLINE amrex::Real Compute_h_zeta_AtIface(const int &i, const int &j, const int &k, const amrex::GpuArray< amrex::Real, AMREX_SPACEDIM > &cellSizeInv, const amrex::Array4< const amrex::Real > &z_nd)
Definition: ERF_TerrainMetrics.H:104
AMREX_GPU_DEVICE AMREX_FORCE_INLINE amrex::Real Compute_h_zeta_AtJface(const int &i, const int &j, const int &k, const amrex::GpuArray< amrex::Real, AMREX_SPACEDIM > &cellSizeInv, const amrex::Array4< const amrex::Real > &z_nd)
Definition: ERF_TerrainMetrics.H:144
AMREX_FORCE_INLINE amrex::IntVect TileNoZ()
Definition: ERF_TileNoZ.H:11
const std::unique_ptr< amrex::EBFArrayBoxFactory > & get_const_factory() const noexcept
Definition: ERF_EB.H:46
@ yvel_bc
Definition: ERF_IndexDefines.H:103
@ xvel_bc
Definition: ERF_IndexDefines.H:102
@ ext_dir
Definition: ERF_IndexDefines.H:243
@ ext_dir_upwind
Definition: ERF_IndexDefines.H:251
@ gpz
Definition: ERF_IndexDefines.H:186
@ gpy
Definition: ERF_IndexDefines.H:185
@ gpx
Definition: ERF_IndexDefines.H:184
@ NumTypes
Definition: ERF_IndexDefines.H:196
@ ymom
Definition: ERF_IndexDefines.H:194
@ cons
Definition: ERF_IndexDefines.H:192
@ zmom
Definition: ERF_IndexDefines.H:195
@ xmom
Definition: ERF_IndexDefines.H:193
@ qt
Definition: ERF_Kessler.H:28
@ ng
Definition: ERF_Morrison.H:48
@ xvel
Definition: ERF_IndexDefines.H:175
@ zvel
Definition: ERF_IndexDefines.H:177
@ yvel
Definition: ERF_IndexDefines.H:176
@ q
Definition: ERF_WSM6.H:169
AdvType dycore_vert_adv_type
Definition: ERF_AdvStruct.H:420
amrex::Real dycore_vert_upw_frac
Definition: ERF_AdvStruct.H:430
AdvType dycore_horiz_adv_type
Definition: ERF_AdvStruct.H:419
amrex::Real dycore_horiz_upw_frac
Definition: ERF_AdvStruct.H:429
Definition: ERF_DiffStruct.H:19
MolecDiffType molec_diff_type
Definition: ERF_DiffStruct.H:84
Definition: ERF_EBStruct.H:27
EBBoundaryType eb_boundary_type
Definition: ERF_EBStruct.H:59
static MeshType mesh_type
Definition: ERF_DataStruct.H:1211
DiffChoice diffChoice
Definition: ERF_DataStruct.H:1220
amrex::Real gravity
Definition: ERF_DataStruct.H:1299
amrex::GpuArray< amrex::Real, AMREX_SPACEDIM > abl_pressure_grad
Definition: ERF_DataStruct.H:1396
bool implicit_thermal_diffusion
Definition: ERF_DataStruct.H:1249
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< int > fixed_density
Definition: ERF_DataStruct.H:1230
amrex::Vector< amrex::Vector< amrex::Real > > vert_implicit_fac
Definition: ERF_DataStruct.H:1246
bool use_rotate_surface_flux
Definition: ERF_DataStruct.H:1329
EBChoice ebChoice
Definition: ERF_DataStruct.H:1224
CouplingType coupling_type
Definition: ERF_DataStruct.H:1388
Definition: ERF_TurbStruct.H:82
PBLType pbl_type
Definition: ERF_TurbStruct.H:478
bool use_keqn
Definition: ERF_TurbStruct.H:514
RANSType rans_type
Definition: ERF_TurbStruct.H:473
bool uses_eamxx_shoc() const noexcept
Definition: ERF_TurbStruct.H:480
bool uses_native_shoc() const noexcept
Definition: ERF_TurbStruct.H:485
LESType les_type
Definition: ERF_TurbStruct.H:431
bool use_kturb
Definition: ERF_TurbStruct.H:513