Function for computing the slow RHS for the evolution equations for the scalars other than density or potential temperature
99 BL_PROFILE_REGION(
"erf_slow_rhs_post()");
101 const BCRec* bc_ptr_d = domain_bcs_type_d.data();
102 const BCRec* bc_ptr_h = domain_bcs_type_h.data();
108 const MultiFab* t_mean_mf =
nullptr;
109 if (SurfLayer) { t_mean_mf = SurfLayer->get_mac_avg(level,2); }
111 const bool l_use_terrain = (solverChoice.
mesh_type != MeshType::ConstantDz);
112 const bool l_moving_terrain = (solverChoice.
terrain_type == TerrainType::MovingFittedMesh);
113 const bool l_reflux = ( (solverChoice.
coupling_type == CouplingType::TwoWay) && (nrk == 2) && (finest_level > 0) );
114 if (l_moving_terrain) AMREX_ALWAYS_ASSERT(l_use_terrain);
116 const bool l_anelastic = solverChoice.
anelastic[level];
119 const bool l_use_KE = ( tc.
use_tke );
120 const bool l_need_SmnSmn = ( tc.
les_type == LESType::Deardorff ||
127 const bool l_use_turb = ( tc.
les_type == LESType::Smagorinsky ||
128 tc.
les_type == LESType::Deardorff ||
136 const Box& domain = geom.Domain();
138 const GpuArray<Real, AMREX_SPACEDIM> dxInv = geom.InvCellSizeArray();
139 const Real* dx = geom.CellSize();
144 const Array<Real,AMREX_SPACEDIM> grav{0.0, 0.0, -solverChoice.
gravity};
145 const GpuArray<Real,AMREX_SPACEDIM> grav_gpu{grav[0], grav[1], grav[2]};
152 const DistributionMapping& dm = S_data[
IntVars::cons].DistributionMap();
154 std::unique_ptr<MultiFab> dflux_x;
155 std::unique_ptr<MultiFab> dflux_y;
156 std::unique_ptr<MultiFab> dflux_z;
159 dflux_x = std::make_unique<MultiFab>(convert(ba,IntVect(1,0,0)), dm, 1, 0);
160 dflux_y = std::make_unique<MultiFab>(convert(ba,IntVect(0,1,0)), dm, 1, 0);
161 dflux_z = std::make_unique<MultiFab>(convert(ba,IntVect(0,0,1)), dm, 1, 0);
169 Vector<int> is_valid_slow_var; is_valid_slow_var.resize(
RhoQ1_comp+1,0);
170 if (l_use_KE) {is_valid_slow_var[
RhoKE_comp] = 1;}
180 Vector<Real> max_scal(nvar, 1.0e34); Gpu::DeviceVector<Real> max_scal_d(nvar);
181 Vector<Real> min_scal(nvar,-1.0e34); Gpu::DeviceVector<Real> min_scal_d(nvar);
182 if (l_use_mono_adv) {
184 for (
int ivar(
RhoKE_comp); ivar<nvar; ++ivar) {
185 GpuTuple<Real,Real> mm = ParReduce(TypeList<ReduceOpMax,ReduceOpMin>{},
186 TypeList<Real, Real>{},
188 [=] AMREX_GPU_DEVICE (
int box_no,
int i,
int j,
int k) noexcept
189 -> GpuTuple<Real,Real>
191 return { ma_s_arr[box_no](i,j,k,ivar), ma_s_arr[box_no](i,j,k,ivar) };
193 max_scal[ivar] = get<0>(mm);
194 min_scal[ivar] = get<1>(mm);
197 Gpu::copy(Gpu::hostToDevice, max_scal.begin(), max_scal.end(), max_scal_d.begin());
198 Gpu::copy(Gpu::hostToDevice, min_scal.begin(), min_scal.end(), min_scal_d.begin());
199 Real* max_s_ptr = max_scal_d.data();
200 Real* min_s_ptr = min_scal_d.data();
218 #pragma omp parallel if (Gpu::notInLaunchRegion())
221 std::array<FArrayBox,AMREX_SPACEDIM> flux;
222 std::array<FArrayBox,AMREX_SPACEDIM> flux_tmp;
228 iMultiFab physbnd_mask;
229 bool already_on_centroids =
false;
232 physbnd_mask.BuildMask(geom.Domain(), geom.periodicity(), 1, 1, 0, 1);
235 for (MFIter mfi(S_data[
IntVars::cons],TilingIfNotGPU()); mfi.isValid(); ++mfi) {
237 Box tbx = mfi.tilebox();
242 for (
int dir = 0; dir < AMREX_SPACEDIM; ++dir) {
244 flux[dir].resize(surroundingNodes(tbx,dir),
nvars);
246 flux[dir].resize(surroundingNodes(tbx,dir).grow(1),
nvars);
248 flux[dir].setVal<RunOn::Device>(0.);
249 if (l_use_mono_adv) {
250 flux_tmp[dir].resize(surroundingNodes(tbx,dir),1);
251 flux_tmp[dir].setVal<RunOn::Device>(0.);
254 const GpuArray<const Array4<Real>, AMREX_SPACEDIM>
255 flx_arr{{AMREX_D_DECL(flux[0].array(), flux[1].array(), flux[2].array())}};
256 Array4<Real> tmpx = (l_use_mono_adv) ? flux_tmp[0].array() : Array4<Real>{};
257 Array4<Real> tmpy = (l_use_mono_adv) ? flux_tmp[1].array() : Array4<Real>{};
258 Array4<Real> tmpz = (l_use_mono_adv) ? flux_tmp[2].array() : Array4<Real>{};
259 const GpuArray<Array4<Real>, AMREX_SPACEDIM> flx_tmp_arr{{AMREX_D_DECL(tmpx,tmpy,tmpz)}};
264 const Array4<const Real> & old_cons = S_old[
IntVars::cons].array(mfi);
265 const Array4< Real> & cell_rhs = S_rhs[
IntVars::cons].array(mfi);
267 const Array4< Real> & new_cons = S_new[
IntVars::cons].array(mfi);
268 const Array4< Real> & new_xmom = S_new[
IntVars::xmom].array(mfi);
269 const Array4< Real> & new_ymom = S_new[
IntVars::ymom].array(mfi);
270 const Array4< Real> & new_zmom = S_new[
IntVars::zmom].array(mfi);
272 const Array4< Real> & cur_cons = S_data[
IntVars::cons].array(mfi);
273 const Array4<const Real> & cur_prim = S_prim.array(mfi);
274 const Array4< Real> & cur_xmom = S_data[
IntVars::xmom].array(mfi);
275 const Array4< Real> & cur_ymom = S_data[
IntVars::ymom].array(mfi);
276 const Array4< Real> & cur_zmom = S_data[
IntVars::zmom].array(mfi);
282 const Array4<const Real> & u =
xvel.array(mfi);
283 const Array4<const Real> & v =
yvel.array(mfi);
285 const Array4<Real const>& mu_turb = l_use_turb ? eddyDiffs->const_array(mfi) : Array4<const Real>{};
287 const Array4<const Real>& z_nd = z_phys_nd->const_array(mfi);
288 const Array4<const Real>& z_cc = z_phys_cc->const_array(mfi);
289 const Array4<const Real>& detJ_new_arr = l_moving_terrain ? detJ_new->const_array(mfi) : Array4<const Real>{};
292 const Array4<const Real>& mf_mx = mapfac[
MapFacType::m_x]->const_array(mfi);
293 const Array4<const Real>& mf_ux = mapfac[
MapFacType::u_x]->const_array(mfi);
294 const Array4<const Real>& mf_vx = mapfac[
MapFacType::v_x]->const_array(mfi);
295 const Array4<const Real>& mf_my = mapfac[
MapFacType::m_y]->const_array(mfi);
296 const Array4<const Real>& mf_uy = mapfac[
MapFacType::u_y]->const_array(mfi);
297 const Array4<const Real>& mf_vy = mapfac[
MapFacType::v_y]->const_array(mfi);
300 const Array4<const Real>& SmnSmn_a = l_need_SmnSmn ? SmnSmn->const_array(mfi) : Array4<const Real>{};
306 const GpuArray<int, IntVars::NumTypes> scomp_slow = { 2,0,0,0};
307 const GpuArray<int, IntVars::NumTypes> ncomp_slow = {nsv,0,0,0};
313 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k,
int nn) {
315 cur_cons(i,j,k,n) = new_cons(i,j,k,n);
322 Box tbx_inc = mfi.nodaltilebox(0);
323 Box tby_inc = mfi.nodaltilebox(1);
324 Box tbz_inc = mfi.nodaltilebox(2);
326 ParallelFor(tbx_inc, tby_inc, tbz_inc,
327 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept {
328 avg_xmom(i,j,k) = cur_xmom(i,j,k);
330 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept {
331 avg_ymom(i,j,k) = cur_ymom(i,j,k);
333 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept {
334 avg_zmom(i,j,k) = cur_zmom(i,j,k);
341 Array4<const int> mask_arr{};
342 Array4<const EBCellFlag> cfg_arr{};
343 Array4<const Real> ax_arr{};
344 Array4<const Real> ay_arr{};
345 Array4<const Real> az_arr{};
346 Array4<const Real> fcx_arr{};
347 Array4<const Real> fcy_arr{};
348 Array4<const Real> fcz_arr{};
349 Array4<const Real> detJ_arr{};
351 EBCellFlagFab
const& cfg = ebfact.getMultiEBCellFlagFab()[mfi];
352 cfg_arr = cfg.const_array();
353 ax_arr = ebfact.getAreaFrac()[0]->const_array(mfi);
354 ay_arr = ebfact.getAreaFrac()[1]->const_array(mfi);
355 az_arr = ebfact.getAreaFrac()[2]->const_array(mfi);
356 fcx_arr = ebfact.getFaceCent()[0]->const_array(mfi);
357 fcy_arr = ebfact.getFaceCent()[1]->const_array(mfi);
358 fcz_arr = ebfact.getFaceCent()[2]->const_array(mfi);
359 detJ_arr = ebfact.getVolFrac().const_array(mfi);
361 mask_arr = physbnd_mask.const_array(mfi);
363 ax_arr = ax->const_array(mfi);
364 ay_arr = ay->const_array(mfi);
365 az_arr = az->const_array(mfi);
366 detJ_arr = detJ->const_array(mfi);
369 AdvType horiz_adv_type, vert_adv_type;
370 Real horiz_upw_frac, vert_upw_frac;
372 Array4<Real> diffflux_x, diffflux_y, diffflux_z;
373 Array4<Real> hfx_x, hfx_y, hfx_z, diss;
374 Array4<Real> q1fx_x, q1fx_y, q1fx_z, q2fx_z;
375 const bool use_SurfLayer = (SurfLayer !=
nullptr);
378 diffflux_x = dflux_x->array(mfi);
379 diffflux_y = dflux_y->array(mfi);
380 diffflux_z = dflux_z->array(mfi);
382 hfx_x = Hfx1->array(mfi);
383 hfx_y = Hfx2->array(mfi);
384 hfx_z = Hfx3->array(mfi);
385 diss = Diss->array(mfi);
387 if (Q1fx1) q1fx_x = Q1fx1->array(mfi);
388 if (Q1fx2) q1fx_y = Q1fx2->array(mfi);
389 if (Q1fx3) q1fx_z = Q1fx3->array(mfi);
390 if (Q2fx3) q2fx_z = Q2fx3->array(mfi);
398 if (is_valid_slow_var[ivar])
404 horiz_adv_type =
ac.moistscal_horiz_adv_type;
405 vert_adv_type =
ac.moistscal_vert_adv_type;
406 horiz_upw_frac =
ac.moistscal_horiz_upw_frac;
407 vert_upw_frac =
ac.moistscal_vert_upw_frac;
409 if (
ac.use_efficient_advection){
417 horiz_adv_type =
ac.dryscal_horiz_adv_type;
418 vert_adv_type =
ac.dryscal_vert_adv_type;
419 horiz_upw_frac =
ac.dryscal_horiz_upw_frac;
420 vert_upw_frac =
ac.dryscal_vert_upw_frac;
422 if (
ac.use_efficient_advection){
437 cur_cons, cur_prim, cell_rhs,
438 l_use_mono_adv, max_s_ptr, min_s_ptr,
439 detJ_arr, dxInv, mf_mx, mf_my,
440 horiz_adv_type, vert_adv_type,
441 horiz_upw_frac, vert_upw_frac,
442 flx_arr, flx_tmp_arr, domain, bc_ptr_h);
445 avg_xmom, avg_ymom, avg_zmom,
447 mask_arr, cfg_arr, ax_arr, ay_arr, az_arr,
448 fcx_arr, fcy_arr, fcz_arr,
449 detJ_arr, dxInv, mf_mx, mf_my,
450 horiz_adv_type, vert_adv_type,
451 horiz_upw_frac, vert_upw_frac,
452 flx_arr, domain, bc_ptr_h,
453 already_on_centroids);
458 const Array4<const Real> tm_arr = t_mean_mf ? t_mean_mf->const_array(mfi) : Array4<const Real>{};
459 if (solverChoice.
mesh_type == MeshType::StretchedDz && solverChoice.
terrain_type != TerrainType::EB) {
461 new_cons, cur_prim, cell_rhs,
462 diffflux_x, diffflux_y, diffflux_z,
463 stretched_dz_d, dxInv, SmnSmn_a,
466 hfx_x, hfx_y, hfx_z, q1fx_x, q1fx_y, q1fx_z,q2fx_z, diss,
467 mu_turb, solverChoice, level,
468 tm_arr, grav_gpu, bc_ptr_d, use_SurfLayer);
469 }
else if (l_use_terrain) {
471 new_cons, cur_prim, cell_rhs,
472 diffflux_x, diffflux_y, diffflux_z,
473 z_nd, z_cc, ax_arr, ay_arr, az_arr,
474 detJ_arr, dxInv, SmnSmn_a,
477 hfx_x, hfx_y, hfx_z, q1fx_x, q1fx_y, q1fx_z,q2fx_z, diss,
478 mu_turb, solverChoice, level,
479 tm_arr, grav_gpu, bc_ptr_d, use_SurfLayer);
482 new_cons, cur_prim, cell_rhs,
483 diffflux_x, diffflux_y, diffflux_z, dxInv, SmnSmn_a,
486 hfx_z, q1fx_z, q2fx_z, diss,
487 mu_turb, solverChoice, level,
488 tm_arr, grav_gpu, bc_ptr_d, use_SurfLayer);
494 #if defined(ERF_USE_NETCDF)
495 if (moist_set_rhs_bool)
497 const Array4<const Real> & old_cons_const = S_old[
IntVars::cons].const_array(mfi);
498 const Array4<const Real> & new_cons_const = S_new[
IntVars::cons].const_array(mfi);
499 moist_set_rhs(tbx, old_cons_const, new_cons_const, cell_rhs, bdy_time_interval,
500 start_bdy_time, new_stage_time, dt, width, set_width, domain,
501 bdy_data_xlo, bdy_data_xhi, bdy_data_ylo, bdy_data_yhi);
507 BL_PROFILE(
"rhs_post_8");
511 auto const& src_arr = source.const_array(mfi);
515 if (is_valid_slow_var[ivar])
525 if (l_moving_terrain)
527 ParallelFor(tbx, num_comp,
528 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k,
int nn) noexcept {
529 const int n = start_comp + nn;
530 cell_rhs(i,j,k,n) += src_arr(i,j,k,n);
531 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);
532 cur_cons(i,j,k,n) = temp_val / detJ_new_arr(i,j,k);
534 cur_cons(i,j,k,n) = amrex::max(cur_cons(i,j,k,n), eps);
538 }
else if (l_anelastic && (nrk == 1)) {
540 ParallelFor(tbx, num_comp,
541 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k,
int nn) noexcept {
542 const int n = start_comp + nn;
543 cell_rhs(i,j,k,n) += src_arr(i,j,k,n);
546 Real dt_times_old_cell_rhs = cur_cons(i,j,k,n) - old_cons(i,j,k,n);
549 cur_cons(i,j,k,n) = old_cons(i,j,k,n) + 0.5 * (dt_times_old_cell_rhs + dt * cell_rhs(i,j,k,n));
552 cur_cons(i,j,k,n) = amrex::max(cur_cons(i,j,k,n), eps);
554 cur_cons(i,j,k,n) = amrex::max(cur_cons(i,j,k,n), 0.0);
560 ParallelFor(tbx, num_comp,
561 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k,
int nn) noexcept {
562 const int n = start_comp + nn;
563 cell_rhs(i,j,k,n) += src_arr(i,j,k,n);
564 cur_cons(i,j,k,n) = old_cons(i,j,k,n) + dt * cell_rhs(i,j,k,n);
566 cur_cons(i,j,k,n) = amrex::max(cur_cons(i,j,k,n), eps);
568 cur_cons(i,j,k,n) = amrex::max(cur_cons(i,j,k,n), 0.0);
579 BL_PROFILE(
"rhs_post_9");
582 ParallelFor(tbx, num_comp_all,
583 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k,
int n) noexcept {
584 new_cons(i,j,k,n) = cur_cons(i,j,k,n);
588 Box xtbx = mfi.nodaltilebox(0);
589 Box ytbx = mfi.nodaltilebox(1);
590 Box ztbx = mfi.nodaltilebox(2);
593 BL_PROFILE(
"rhs_post_10()");
594 ParallelFor(xtbx, ytbx, ztbx,
595 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept {
596 new_xmom(i,j,k) = cur_xmom(i,j,k);
598 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept {
599 new_ymom(i,j,k) = cur_ymom(i,j,k);
601 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept {
602 new_zmom(i,j,k) = cur_zmom(i,j,k);
607 BL_PROFILE(
"rhs_post_10");
611 int num_comp_reflux =
nvars - strt_comp_reflux;
612 if (level < finest_level) {
613 fr_as_crse->CrseAdd(mfi,
614 {{AMREX_D_DECL(&(flux[0]), &(flux[1]), &(flux[2]))}},
615 dx, dt, strt_comp_reflux, strt_comp_reflux, num_comp_reflux, RunOn::Device);
618 fr_as_fine->FineAdd(mfi,
619 {{AMREX_D_DECL(&(flux[0]), &(flux[1]), &(flux[2]))}},
620 dx, dt, strt_comp_reflux, strt_comp_reflux, num_comp_reflux, RunOn::Device);
626 Gpu::streamSynchronize();
637 if (is_valid_slow_var[ivar])
651 MultiFab dUdt_tmp(ba, dm, num_comp_total, S_rhs[
IntVars::cons].nGrow(), MFInfo(), ebfact);
654 dUdt_tmp.FillBoundary(geom.periodicity());
655 dUdt_tmp.setDomainBndry(1.234e10, 0, num_comp_total, geom);
658 S_old[
IntVars::cons].setDomainBndry(1.234e10, 0, num_comp_total, geom);
667 for ( MFIter mfi(S_new[
IntVars::cons],TilingIfNotGPU()); mfi.isValid(); ++mfi)
669 Box tbx = mfi.tilebox();
673 Array4<const Real> detJ_arr = ebfact.getVolFrac().const_array(mfi);
675 ParallelFor(tbx, num_comp, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k,
int nn)
677 if (detJ_arr(i,j,k) > 0.0) {
678 const int n = start_comp + nn;
679 snew(i,j,k,n) = sold(i,j,k,n) + dt * srhs(i,j,k,n);
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)
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE AdvType EfficientAdvType(int nrk, AdvType adv_type)
Definition: ERF_Advection.H:287
@ 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 DiffusionSrcForState_S(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::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_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 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 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)
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 redistribute_term(int ncomp, const Geometry &geom, MultiFab &result, MultiFab &result_tmp, MultiFab const &state, EBFArrayBoxFactory const &ebfact, BCRec const *bc, Real const local_dt)
Definition: ERF_EBRedistribute.cpp:13
#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:221
#define RhoKE_comp
Definition: ERF_IndexDefines.H:38
@ ymom
Definition: ERF_IndexDefines.H:160
@ cons
Definition: ERF_IndexDefines.H:158
@ zmom
Definition: ERF_IndexDefines.H:161
@ xmom
Definition: ERF_IndexDefines.H:159
@ xvel
Definition: ERF_IndexDefines.H:141
@ yvel
Definition: ERF_IndexDefines.H:142
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:180
Definition: ERF_AdvStruct.H:19
Definition: ERF_DiffStruct.H:19
MolecDiffType molec_diff_type
Definition: ERF_DiffStruct.H:81
static MeshType mesh_type
Definition: ERF_DataStruct.H:708
bool use_mono_adv
Definition: ERF_DataStruct.H:798
DiffChoice diffChoice
Definition: ERF_DataStruct.H:717
amrex::Real gravity
Definition: ERF_DataStruct.H:757
amrex::Vector< TurbChoice > turbChoice
Definition: ERF_DataStruct.H:719
amrex::Vector< int > anelastic
Definition: ERF_DataStruct.H:724
AdvChoice advChoice
Definition: ERF_DataStruct.H:716
MoistureType moisture_type
Definition: ERF_DataStruct.H:804
static TerrainType terrain_type
Definition: ERF_DataStruct.H:702
bool use_rotate_surface_flux
Definition: ERF_DataStruct.H:785
CouplingType coupling_type
Definition: ERF_DataStruct.H:803
Definition: ERF_TurbStruct.H:39
PBLType pbl_type
Definition: ERF_TurbStruct.H:354
RANSType rans_type
Definition: ERF_TurbStruct.H:351
bool advect_tke
Definition: ERF_TurbStruct.H:394
bool use_tke
Definition: ERF_TurbStruct.H:366
LESType les_type
Definition: ERF_TurbStruct.H:314