Function for computing the slow RHS for the evolution equations for the density, potential temperature and momentum.
107 BL_PROFILE_REGION(
"erf_slow_rhs_pre()");
109 const BCRec* bc_ptr_d = domain_bcs_type_d.data();
110 const BCRec* bc_ptr_h = domain_bcs_type_h.data();
115 const MultiFab* t_mean_mf =
nullptr;
116 if (SurfLayer) { t_mean_mf = SurfLayer->get_mac_avg(level,2); }
118 const Box& domain = geom.Domain();
119 int klo = domain.smallEnd(2);
120 int khi = domain.bigEnd(2);
126 const bool l_use_terrain_fitted_coords = (solverChoice.
mesh_type != MeshType::ConstantDz);
127 const bool l_moving_terrain = (solverChoice.
terrain_type == TerrainType::MovingFittedMesh);
128 if (l_moving_terrain) AMREX_ALWAYS_ASSERT (l_use_terrain_fitted_coords);
131 const bool l_reflux = ( (solverChoice.
coupling_type == CouplingType::TwoWay) && (nrk == 2) && (finest_level > 0) );
138 const bool l_need_SmnSmn = tc.
use_keqn;
140 const bool l_use_moisture = (solverChoice.
moisture_type != MoistureType::None);
141 const bool l_use_SurfLayer = (SurfLayer !=
nullptr);
144 const bool l_anelastic = solverChoice.
anelastic[level];
147 const GpuArray<Real, AMREX_SPACEDIM> dxInv = geom.InvCellSizeArray();
148 const Real* dx = geom.CellSize();
153 const Array<Real,AMREX_SPACEDIM> grav{0.0, 0.0, -solverChoice.
gravity};
154 const GpuArray<Real,AMREX_SPACEDIM> grav_gpu{grav[0], grav[1], grav[2]};
161 const DistributionMapping& dm = S_data[
IntVars::cons].DistributionMap();
163 int nGhost = (solverChoice.
terrain_type == TerrainType::EB) ? 2 : 1;
164 MultiFab Omega(convert(ba,IntVect(0,0,1)), dm, 1, nGhost);
166 std::unique_ptr<MultiFab> expr;
167 std::unique_ptr<MultiFab> dflux_x;
168 std::unique_ptr<MultiFab> dflux_y;
169 std::unique_ptr<MultiFab> dflux_z;
174 SmnSmn,eddyDiffs,geom,solverChoice,SurfLayer,
177 dflux_x = std::make_unique<MultiFab>(convert(ba,IntVect(1,0,0)), dm,
nvars, 0);
178 dflux_y = std::make_unique<MultiFab>(convert(ba,IntVect(0,1,0)), dm,
nvars, 0);
179 dflux_z = std::make_unique<MultiFab>(convert(ba,IntVect(0,0,1)), dm,
nvars, 0);
181 if (l_use_SurfLayer) {
183 SurfLayer->impose_SurfaceLayer_bcs(level, mfs, Tau_lev,
194 Vector<Real> max_scal(nvar, 1.0e34); Gpu::DeviceVector<Real> max_scal_d(nvar);
195 Vector<Real> min_scal(nvar,-1.0e34); Gpu::DeviceVector<Real> min_scal_d(nvar);
196 if (l_use_mono_adv) {
199 GpuTuple<Real,Real> mm = ParReduce(TypeList<ReduceOpMax,ReduceOpMin>{},
200 TypeList<Real, Real>{},
202 [=] AMREX_GPU_DEVICE (
int box_no,
int i,
int j,
int k) noexcept
203 -> GpuTuple<Real,Real>
205 return { ma_s_arr[box_no](i,j,k,ivar), ma_s_arr[box_no](i,j,k,ivar) };
207 max_scal[ivar] = get<0>(mm);
208 min_scal[ivar] = get<1>(mm);
211 Gpu::copy(Gpu::hostToDevice, max_scal.begin(), max_scal.end(), max_scal_d.begin());
212 Gpu::copy(Gpu::hostToDevice, min_scal.begin(), min_scal.end(), min_scal_d.begin());
213 Real* max_s_ptr = max_scal_d.data();
214 Real* min_s_ptr = min_scal_d.data();
223 #pragma omp parallel if (Gpu::notInLaunchRegion())
226 std::array<FArrayBox,AMREX_SPACEDIM> flux;
227 std::array<FArrayBox,AMREX_SPACEDIM> flux_u;
228 std::array<FArrayBox,AMREX_SPACEDIM> flux_v;
229 std::array<FArrayBox,AMREX_SPACEDIM> flux_w;
230 std::array<FArrayBox,AMREX_SPACEDIM> flux_tmp;
233 bool already_on_centroids =
false;
234 Vector<iMultiFab> physbnd_mask;
238 physbnd_mask[
IntVars::cons].BuildMask(geom.Domain(), geom.periodicity(), 1, 1, 0, 1);
240 for (
int dir = 0; dir < AMREX_SPACEDIM; ++dir) {
241 physbnd_mask[1+dir].define(S_data[1+dir].boxArray(), S_data[1+dir].DistributionMap(), 1, 1);
242 physbnd_mask[1+dir].BuildMask(geom.Domain(), geom.periodicity(), 1, 1, 0, 1);
249 Box bx = mfi.tilebox();
250 Box tbx = mfi.nodaltilebox(0);
251 Box tby = mfi.nodaltilebox(1);
252 Box tbz = mfi.nodaltilebox(2);
255 Vector<Box> tbx_grown(AMREX_SPACEDIM);
256 Vector<Box> tby_grown(AMREX_SPACEDIM);
257 Vector<Box> tbz_grown(AMREX_SPACEDIM);
259 for (
int dir = 0; dir < AMREX_SPACEDIM; ++dir) {
260 tbx_grown[dir] = tbx;
261 tby_grown[dir] = tby;
262 tbz_grown[dir] = tbz;
265 tbx_grown[dir] = (tbx_grown[dir].growHi(dir,1)).grow(iv);
266 tby_grown[dir] = (tby_grown[dir].growHi(dir,1)).grow(iv);
267 tbz_grown[dir] = (tbz_grown[dir].growHi(dir,1)).grow(iv);
272 if (tbz.smallEnd(2) == domain.smallEnd(2)) {
275 if (tbz.bigEnd(2) == domain.bigEnd(2)+1) {
279 const Array4<const Real> & cell_data = S_data[
IntVars::cons].array(mfi);
280 const Array4<const Real> & cell_prim = S_prim.array(mfi);
281 const Array4<Real> & cell_rhs = S_rhs[
IntVars::cons].array(mfi);
283 const Array4<const Real> & cell_old = S_old[
IntVars::cons].array(mfi);
285 const Array4<Real const>& xmom_src_arr = xmom_src.const_array(mfi);
286 const Array4<Real const>& ymom_src_arr = ymom_src.const_array(mfi);
287 const Array4<Real const>& zmom_src_arr = zmom_src.const_array(mfi);
288 const Array4<Real const>& buoyancy_arr = buoyancy.const_array(mfi);
290 const Array4<Real const>& gpx_arr = gradp[
GpVars::gpx].const_array(mfi);
291 const Array4<Real const>& gpy_arr = gradp[
GpVars::gpy].const_array(mfi);
292 const Array4<Real const>& gpz_arr = gradp[
GpVars::gpz].const_array(mfi);
294 const Array4<Real const>& qt_arr =
qt.const_array(mfi);
296 const Array4<Real>& rho_u_old = S_old[
IntVars::xmom].array(mfi);
297 const Array4<Real>& rho_v_old = S_old[
IntVars::ymom].array(mfi);
301 S_scratch[
IntVars::xmom][mfi].template setVal<RunOn::Device>(0.0,tbx);
302 S_scratch[
IntVars::ymom][mfi].template setVal<RunOn::Device>(0.0,tby);
303 S_scratch[
IntVars::zmom][mfi].template setVal<RunOn::Device>(0.0,tbz);
310 const Array4<const Real> & u =
xvel.array(mfi);
311 const Array4<const Real> & v =
yvel.array(mfi);
312 const Array4<const Real> & w =
zvel.array(mfi);
314 const Array4<const Real>& rho_u = S_data[
IntVars::xmom].array(mfi);
315 const Array4<const Real>& rho_v = S_data[
IntVars::ymom].array(mfi);
316 const Array4<const Real>& rho_w = S_data[
IntVars::zmom].array(mfi);
319 const Array4<const Real>& mf_mx = mapfac[
MapFacType::m_x]->const_array(mfi);
320 const Array4<const Real>& mf_ux = mapfac[
MapFacType::u_x]->const_array(mfi);
321 const Array4<const Real>& mf_vx = mapfac[
MapFacType::v_x]->const_array(mfi);
322 const Array4<const Real>& mf_my = mapfac[
MapFacType::m_y]->const_array(mfi);
323 const Array4<const Real>& mf_uy = mapfac[
MapFacType::u_y]->const_array(mfi);
324 const Array4<const Real>& mf_vy = mapfac[
MapFacType::v_y]->const_array(mfi);
326 const Array4< Real>& omega_arr = Omega.array(mfi);
328 Array4<const Real> z_t;
330 z_t = z_t_mf->array(mfi);
332 z_t = Array4<const Real>{};
335 const Array4<Real>& rho_u_rhs = S_rhs[
IntVars::xmom].array(mfi);
336 const Array4<Real>& rho_v_rhs = S_rhs[
IntVars::ymom].array(mfi);
337 const Array4<Real>& rho_w_rhs = S_rhs[
IntVars::zmom].array(mfi);
339 const Array4<Real const>& mu_turb = l_use_turb ? eddyDiffs->const_array(mfi) : Array4<const Real>{};
342 const Array4<const Real>& z_nd = z_phys_nd.const_array(mfi);
347 for (
int dir = 0; dir < AMREX_SPACEDIM; ++dir) {
349 flux[dir].resize(surroundingNodes(bx,dir),2);
351 flux[dir].resize(surroundingNodes(bx,dir).grow(1),2);
353 flux[dir].setVal<RunOn::Device>(0.);
354 if (l_use_mono_adv) {
355 flux_tmp[dir].resize(surroundingNodes(bx,dir),2);
356 flux_tmp[dir].setVal<RunOn::Device>(0.);
359 const GpuArray<const Array4<Real>, AMREX_SPACEDIM>
360 flx_arr{{AMREX_D_DECL(flux[0].array(), flux[1].array(), flux[2].array())}};
363 GpuArray<Array4<Real>, AMREX_SPACEDIM> flx_u_arr{};
364 GpuArray<Array4<Real>, AMREX_SPACEDIM> flx_v_arr{};
365 GpuArray<Array4<Real>, AMREX_SPACEDIM> flx_w_arr{};
367 for (
int dir = 0; dir < AMREX_SPACEDIM; ++dir) {
368 flux_u[dir].resize(tbx_grown[dir],1);
369 flux_v[dir].resize(tby_grown[dir],1);
370 flux_w[dir].resize(tbz_grown[dir],1);
371 flux_u[dir].setVal<RunOn::Device>(0.);
372 flux_v[dir].setVal<RunOn::Device>(0.);
373 flux_w[dir].setVal<RunOn::Device>(0.);
374 flx_u_arr[dir] = flux_u[dir].array();
375 flx_v_arr[dir] = flux_v[dir].array();
376 flx_w_arr[dir] = flux_w[dir].array();
380 Array4<Real> tmpx = (l_use_mono_adv) ? flux_tmp[0].array() : Array4<Real>{};
381 Array4<Real> tmpy = (l_use_mono_adv) ? flux_tmp[1].array() : Array4<Real>{};
382 Array4<Real> tmpz = (l_use_mono_adv) ? flux_tmp[2].array() : Array4<Real>{};
383 const GpuArray<Array4<Real>, AMREX_SPACEDIM> flx_tmp_arr{{AMREX_D_DECL(tmpx,tmpy,tmpz)}};
389 BL_PROFILE(
"slow_rhs_making_omega");
390 IntVect nGrowVect = (solverChoice.
terrain_type == TerrainType::EB)
391 ? IntVect(AMREX_D_DECL(2, 2, 2)) : IntVect(AMREX_D_DECL(1, 1, 1));
392 Box gbxo = surroundingNodes(bx,2); gbxo.grow(nGrowVect);
398 if (!l_use_terrain_fitted_coords) {
399 ParallelFor(gbxo, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept {
400 omega_arr(i,j,k) = rho_w(i,j,k);
405 Box gbxo_lo = gbxo; gbxo_lo.setBig(2,domain.smallEnd(2));
406 int lo_z_face = domain.smallEnd(2);
407 if (gbxo_lo.smallEnd(2) <= lo_z_face) {
408 ParallelFor(gbxo_lo, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept {
409 omega_arr(i,j,k) = 0.;
412 Box gbxo_hi = gbxo; gbxo_hi.setSmall(2,gbxo.bigEnd(2));
413 int hi_z_face = domain.bigEnd(2)+1;
414 if (gbxo_hi.bigEnd(2) >= hi_z_face) {
415 ParallelFor(gbxo_hi, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept {
416 omega_arr(i,j,k) = rho_w(i,j,k);
421 Box gbxo_mid = gbxo; gbxo_mid.setSmall(2,1); gbxo_mid.setBig(2,gbxo.bigEnd(2)-1);
422 ParallelFor(gbxo_mid, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept {
424 Real rho_at_face = 0.5 * (cell_data(i,j,k,
Rho_comp) + cell_data(i,j,k-1,
Rho_comp));
425 omega_arr(i,j,k) =
OmegaFromW(i,j,k,rho_w(i,j,k),
426 rho_u,rho_v,mf_ux,mf_vy,z_nd,dxInv) -
427 rho_at_face * z_t(i,j,k);
431 if (gbxo_mid.smallEnd(2) <= domain.smallEnd(2)) {
432 gbxo_mid.setSmall(2,1);
434 if (gbxo_mid.bigEnd(2) >= domain.bigEnd(2)+1) {
435 gbxo_mid.setBig(2,gbxo.bigEnd(2)-1);
437 ParallelFor(gbxo_mid, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept {
438 omega_arr(i,j,k) =
OmegaFromW(i,j,k,rho_w(i,j,k),
439 rho_u,rho_v,mf_ux,mf_vy,z_nd,dxInv);
456 tau11 = Array4<Real>{};
tau22 = Array4<Real>{};
tau33 = Array4<Real>{};
457 tau12 = Array4<Real>{};
tau13 = Array4<Real>{};
tau23 = Array4<Real>{};
466 tau21 = Array4<Real>{};
tau31 = Array4<Real>{};
tau32 = Array4<Real>{};
470 Array4<Real> SmnSmn_a;
472 SmnSmn_a = SmnSmn->array(mfi);
474 SmnSmn_a = Array4<Real>{};
480 Array4<const int> mask_arr{};
481 Array4<const EBCellFlag> cfg_arr{};
482 Array4<const Real> ax_arr{};
483 Array4<const Real> ay_arr{};
484 Array4<const Real> az_arr{};
485 Array4<const Real> fcx_arr{};
486 Array4<const Real> fcy_arr{};
487 Array4<const Real> fcz_arr{};
488 Array4<const Real> detJ_arr{};
491 EBCellFlagFab
const& cfg = (ebfact.
get_const_factory())->getMultiEBCellFlagFab()[mfi];
492 cfg_arr = cfg.const_array();
503 ax_arr = ax.const_array(mfi);
504 ay_arr = ay.const_array(mfi);
505 az_arr = az.const_array(mfi);
506 detJ_arr = detJ.const_array(mfi);
511 rho_u, rho_v, omega_arr,
512 avg_xmom, avg_ymom, avg_zmom,
513 ax_arr, ay_arr, az_arr, detJ_arr,
514 dxInv, mf_mx, mf_my, mf_uy, mf_vx,
515 flx_arr, l_fixed_rho);
518 rho_u, rho_v, omega_arr,
519 avg_xmom, avg_ymom, avg_zmom,
521 ax_arr, ay_arr, az_arr,
522 fcx_arr, fcy_arr, fcz_arr, detJ_arr,
523 dxInv, mf_mx, mf_my, mf_uy, mf_vx,
524 flx_arr, l_fixed_rho,
525 already_on_centroids);
531 avg_xmom, avg_ymom, avg_zmom,
532 cell_data, cell_prim, cell_rhs,
533 l_use_mono_adv, max_s_ptr, min_s_ptr,
534 detJ_arr, dxInv, mf_mx, mf_my,
535 l_horiz_adv_type, l_vert_adv_type,
536 l_horiz_upw_frac, l_vert_upw_frac,
537 flx_arr, flx_tmp_arr, domain, bc_ptr_h);
540 avg_xmom, avg_ymom, avg_zmom,
542 mask_arr, cfg_arr, ax_arr, ay_arr, az_arr,
543 fcx_arr, fcy_arr, fcz_arr,
544 detJ_arr, dxInv, mf_mx, mf_my,
545 l_horiz_adv_type, l_vert_adv_type,
546 l_horiz_upw_frac, l_vert_upw_frac,
547 flx_arr, domain, bc_ptr_h,
548 already_on_centroids);
552 Array4<Real> diffflux_x = dflux_x->array(mfi);
553 Array4<Real> diffflux_y = dflux_y->array(mfi);
554 Array4<Real> diffflux_z = dflux_z->array(mfi);
556 Array4<Real> hfx_x = Hfx1->array(mfi);
557 Array4<Real> hfx_y = Hfx2->array(mfi);
558 Array4<Real> hfx_z = Hfx3->array(mfi);
560 Array4<Real> q1fx_x = (Q1fx1) ? Q1fx1->array(mfi) : Array4<Real>{};
561 Array4<Real> q1fx_y = (Q1fx2) ? Q1fx2->array(mfi) : Array4<Real>{};
562 Array4<Real> q1fx_z = (Q1fx3) ? Q1fx3->array(mfi) : Array4<Real>{};
564 Array4<Real> q2fx_z = (Q2fx3) ? Q2fx3->array(mfi) : Array4<Real>{};
565 Array4<Real> diss = Diss->array(mfi);
567 const Array4<const Real> tm_arr = t_mean_mf ? t_mean_mf->const_array(mfi) : Array4<const Real>{};
573 if (l_use_terrain_fitted_coords) {
575 cell_data, cell_prim, cell_rhs,
576 diffflux_x, diffflux_y, diffflux_z,
577 z_nd, ax_arr, ay_arr, az_arr, detJ_arr,
581 hfx_x, hfx_y, hfx_z, q1fx_x, q1fx_y, q1fx_z, q2fx_z, diss,
582 mu_turb, solverChoice, level,
583 tm_arr, grav_gpu, bc_ptr_d, l_use_SurfLayer);
586 cell_data, cell_prim, cell_rhs,
587 diffflux_x, diffflux_y, diffflux_z,
591 hfx_z, q1fx_z, q2fx_z, diss,
592 mu_turb, solverChoice, level,
593 tm_arr, grav_gpu, bc_ptr_d, l_use_SurfLayer);
597 const Array4<Real const>& source_arr = cc_src.const_array(mfi);
598 ParallelFor(bx, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept
605 if (l_use_terrain_fitted_coords && l_moving_terrain) {
606 ParallelFor(bx, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept
608 cell_rhs(i,j,k,
Rho_comp) *= detJ_arr(i,j,k);
614 if ( l_anelastic && (nrk == 1) )
616 ParallelFor(bx, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept
629 int lo_z_face = domain.smallEnd(2);
630 int hi_z_face = domain.bigEnd(2)+1;
633 rho_u_rhs, rho_v_rhs, rho_w_rhs,
635 rho_u, rho_v, omega_arr,
636 z_nd, ax_arr, ay_arr, az_arr, detJ_arr,
638 dxInv, mf_mx, mf_ux, mf_vx, mf_my, mf_uy, mf_vy,
639 l_horiz_adv_type, l_vert_adv_type,
640 l_horiz_upw_frac, l_vert_upw_frac,
642 ebfact, flx_u_arr, flx_v_arr, flx_w_arr,
643 physbnd_mask, already_on_centroids,
644 lo_z_face, hi_z_face, domain, bc_ptr_h);
652 if (l_use_terrain_fitted_coords) {
654 rho_u_rhs, rho_v_rhs, rho_w_rhs,
661 mf_my, mf_uy, mf_vy);
664 rho_u_rhs, rho_v_rhs, rho_w_rhs,
668 mf_my, mf_uy, mf_vy);
674 ParallelFor(tbx, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k)
677 Real
gpx = gpx_arr(i,j,k) * mf_ux(i,j,0);
679 Real q = (l_use_moisture) ? 0.5 * (qt_arr(i,j,k) + qt_arr(i-1,j,k)) : 0.0;
681 rho_u_rhs(i, j, k) += (-
gpx - abl_pressure_grad[0]) / (1.0 + q) + xmom_src_arr(i,j,k);
683 if (l_moving_terrain) {
685 rho_u_rhs(i, j, k) *= h_zeta;
688 if ( l_anelastic && (nrk == 1) ) {
689 rho_u_rhs(i,j,k) *= 0.5;
690 rho_u_rhs(i,j,k) += 0.5 / dt * (rho_u(i,j,k) - rho_u_old(i,j,k));
694 ParallelFor(tby, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k)
697 Real
gpy = gpy_arr(i,j,k) * mf_vy(i,j,0);
699 Real q = (l_use_moisture) ? 0.5 * (qt_arr(i,j,k) + qt_arr(i,j-1,k)) : 0.0;
701 rho_v_rhs(i, j, k) += (-
gpy - abl_pressure_grad[1]) / (1.0 + q) + ymom_src_arr(i,j,k);
703 if (l_moving_terrain) {
705 rho_v_rhs(i, j, k) *= h_zeta;
708 if ( l_anelastic && (nrk == 1) ) {
709 rho_v_rhs(i,j,k) *= 0.5;
710 rho_v_rhs(i,j,k) += 0.5 / dt * (rho_v(i,j,k) - rho_v_old(i,j,k));
719 if (bx.smallEnd(0) == domain.smallEnd(0)) {
720 Box lo_x_dom_face(bx); lo_x_dom_face.setBig(0,bx.smallEnd(0));
722 ParallelFor(lo_x_dom_face, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) {
723 rho_u_rhs(i,j,k) = 0.;
726 ParallelFor(lo_x_dom_face, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) {
727 if (u(i,j,k) >= 0.) {
728 rho_u_rhs(i,j,k) = 0.;
733 if (bx.bigEnd(0) == domain.bigEnd(0)) {
734 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);
736 ParallelFor(hi_x_dom_face, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) {
737 rho_u_rhs(i,j,k) = 0.;
740 ParallelFor(hi_x_dom_face, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) {
741 if (u(i,j,k) <= 0.) {
742 rho_u_rhs(i,j,k) = 0.;
747 if (bx.smallEnd(1) == domain.smallEnd(1)) {
748 Box lo_y_dom_face(bx); lo_y_dom_face.setBig(1,bx.smallEnd(1));
750 ParallelFor(lo_y_dom_face, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) {
751 rho_v_rhs(i,j,k) = 0.;
754 ParallelFor(lo_y_dom_face, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) {
755 if (v(i,j,k) >= 0.) {
756 rho_v_rhs(i,j,k) = 0.;
761 if (bx.bigEnd(1) == domain.bigEnd(1)) {
762 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);
764 ParallelFor(hi_y_dom_face, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) {
765 rho_v_rhs(i,j,k) = 0.;
768 ParallelFor(hi_y_dom_face, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) {
769 if (v(i,j,k) <= 0.) {
770 rho_v_rhs(i,j,k) = 0.;
776 ParallelFor(tbz, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k)
779 Real
gpz = gpz_arr(i,j,k);
781 Real q = (l_use_moisture) ? 0.5 * (qt_arr(i,j,k) + qt_arr(i,j,k-1)) : 0.0;
783 rho_w_rhs(i, j, k) += (-
gpz - abl_pressure_grad[2] + buoyancy_arr(i,j,k)) / (1.0 + q) + zmom_src_arr(i,j,k);
785 if (l_use_terrain_fitted_coords && l_moving_terrain) {
786 rho_w_rhs(i, j, k) *= 0.5 * (detJ_arr(i,j,k) + detJ_arr(i,j,k-1));
790 auto const lo = lbound(bx);
791 auto const hi = ubound(bx);
796 const Array4<const Real>& rho_w_rhs_crse = zmom_crse_rhs->const_array(mfi);
798 Box b2d = bx; b2d.setRange(2,0);
801 ParallelFor(b2d, [=] AMREX_GPU_DEVICE (
int i,
int j,
int )
803 rho_w_rhs(i,j,lo.z) = rho_w_rhs_crse(i,j,lo.z);
808 ParallelFor(b2d, [=] AMREX_GPU_DEVICE (
int i,
int j,
int )
810 rho_w_rhs(i,j,hi.z+1) = rho_w_rhs_crse(i,j,hi.z+1);
816 BL_PROFILE(
"slow_rhs_pre_fluxreg");
821 int strt_comp_reflux = (l_fixed_rho) ? 1 : 0;
822 int num_comp_reflux = 1;
823 if (level < finest_level) {
824 fr_as_crse->CrseAdd(mfi,
825 {{AMREX_D_DECL(&(flux[0]), &(flux[1]), &(flux[2]))}},
826 dx, dt, strt_comp_reflux, strt_comp_reflux, num_comp_reflux, RunOn::Device);
829 fr_as_fine->FineAdd(mfi,
830 {{AMREX_D_DECL(&(flux[0]), &(flux[1]), &(flux[2]))}},
831 dx, dt, strt_comp_reflux, strt_comp_reflux, num_comp_reflux, RunOn::Device);
837 Gpu::streamSynchronize();
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 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)
void AdvectionSrcForScalars(const amrex::Real &dt, 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 > &cur_cons, const amrex::Array4< const amrex::Real > &cell_prim, const amrex::Array4< amrex::Real > &src, const bool &use_mono_adv, amrex::Real *max_s_ptr, amrex::Real *min_s_ptr, 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::GpuArray< amrex::Array4< amrex::Real >, AMREX_SPACEDIM > &flx_tmp_arr, const amrex::Box &domain, const amrex::BCRec *bc_ptr_h)
@ tau12
Definition: ERF_DataStruct.H:30
@ tau23
Definition: ERF_DataStruct.H:30
@ tau33
Definition: ERF_DataStruct.H:30
@ tau22
Definition: ERF_DataStruct.H:30
@ tau11
Definition: ERF_DataStruct.H:30
@ tau32
Definition: ERF_DataStruct.H:30
@ tau31
Definition: ERF_DataStruct.H:30
@ tau21
Definition: ERF_DataStruct.H:30
@ tau13
Definition: ERF_DataStruct.H:30
@ nvars
Definition: ERF_DataStruct.H:87
@ v_x
Definition: ERF_DataStruct.H:22
@ u_y
Definition: ERF_DataStruct.H:23
@ v_y
Definition: ERF_DataStruct.H:23
@ m_y
Definition: ERF_DataStruct.H:23
@ u_x
Definition: ERF_DataStruct.H:22
@ m_x
Definition: ERF_DataStruct.H:22
void DiffusionSrcForMom_N(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 > &tau13, const amrex::Array4< const amrex::Real > &tau23, 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)
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)
void DiffusionSrcForMom_T(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, 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)
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 > &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)
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)
#define Rho_comp
Definition: ERF_IndexDefines.H:36
#define RhoTheta_comp
Definition: ERF_IndexDefines.H:37
AdvType
Definition: ERF_IndexDefines.H:221
#define RhoKE_comp
Definition: ERF_IndexDefines.H:38
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, MultiFab *SmnSmn, MultiFab *eddyDiffs, const Geometry geom, const SolverChoice &solverChoice, std::unique_ptr< SurfaceLayer > &, const MultiFab &detJ, Vector< std::unique_ptr< MultiFab >> &mapfac)
Definition: ERF_MakeTauTerms.cpp:12
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:415
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:96
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:139
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:40
@ yvel_bc
Definition: ERF_IndexDefines.H:88
@ xvel_bc
Definition: ERF_IndexDefines.H:87
@ ext_dir
Definition: ERF_IndexDefines.H:209
@ ext_dir_upwind
Definition: ERF_IndexDefines.H:217
@ gpz
Definition: ERF_IndexDefines.H:152
@ gpy
Definition: ERF_IndexDefines.H:151
@ gpx
Definition: ERF_IndexDefines.H:150
@ NumTypes
Definition: ERF_IndexDefines.H:162
@ ymom
Definition: ERF_IndexDefines.H:160
@ cons
Definition: ERF_IndexDefines.H:158
@ zmom
Definition: ERF_IndexDefines.H:161
@ xmom
Definition: ERF_IndexDefines.H:159
@ qt
Definition: ERF_Kessler.H:27
@ xvel
Definition: ERF_IndexDefines.H:141
@ zvel
Definition: ERF_IndexDefines.H:143
@ yvel
Definition: ERF_IndexDefines.H:142
AdvType dycore_vert_adv_type
Definition: ERF_AdvStruct.H:340
amrex::Real dycore_vert_upw_frac
Definition: ERF_AdvStruct.H:350
AdvType dycore_horiz_adv_type
Definition: ERF_AdvStruct.H:339
amrex::Real dycore_horiz_upw_frac
Definition: ERF_AdvStruct.H:349
Definition: ERF_DiffStruct.H:19
MolecDiffType molec_diff_type
Definition: ERF_DiffStruct.H:81
static MeshType mesh_type
Definition: ERF_DataStruct.H:691
bool use_mono_adv
Definition: ERF_DataStruct.H:781
DiffChoice diffChoice
Definition: ERF_DataStruct.H:700
amrex::Real gravity
Definition: ERF_DataStruct.H:740
amrex::GpuArray< amrex::Real, AMREX_SPACEDIM > abl_pressure_grad
Definition: ERF_DataStruct.H:794
bool fixed_density
Definition: ERF_DataStruct.H:709
amrex::Vector< TurbChoice > turbChoice
Definition: ERF_DataStruct.H:702
amrex::Vector< int > anelastic
Definition: ERF_DataStruct.H:707
AdvChoice advChoice
Definition: ERF_DataStruct.H:699
MoistureType moisture_type
Definition: ERF_DataStruct.H:787
static TerrainType terrain_type
Definition: ERF_DataStruct.H:685
bool use_rotate_surface_flux
Definition: ERF_DataStruct.H:768
CouplingType coupling_type
Definition: ERF_DataStruct.H:786
Definition: ERF_TurbStruct.H:31
PBLType pbl_type
Definition: ERF_TurbStruct.H:276
bool use_keqn
Definition: ERF_TurbStruct.H:283
RANSType rans_type
Definition: ERF_TurbStruct.H:273
LESType les_type
Definition: ERF_TurbStruct.H:236
bool use_kturb
Definition: ERF_TurbStruct.H:282