4 Vector<MultiFab>& S_old,
5 Vector<MultiFab>& S_new,
6 Vector<MultiFab>& S_data,
7 const Real old_step_time,
8 const Real old_stage_time,
9 const Real new_stage_time,
15 Real slow_dt = new_stage_time - old_step_time;
17 if (verbose) amrex::Print() <<
"Time integration of scalars at level " << level
18 << std::setprecision(timeprecision)
19 <<
" from " << old_step_time <<
" to " << new_stage_time
20 <<
" with dt = " << slow_dt
21 <<
" using RHS created at " << old_stage_time << std::endl;
23 const GpuArray<Real, AMREX_SPACEDIM>
dxInv = fine_geom.InvCellSizeArray();
28 YAFluxRegister* fr_as_crse =
nullptr;
29 YAFluxRegister* fr_as_fine =
nullptr;
30 if (solverChoice.coupling_type == CouplingType::TwoWay && finest_level > 0)
32 if (level < finest_level) {
33 fr_as_crse = getAdvFluxReg(level+1);
36 fr_as_fine = getAdvFluxReg(level);
41 (solverChoice.terrain_type == TerrainType::MovingFittedMesh) ? (detJ_cc_new[level].
get()) : (detJ_cc[level].
get());
43 erf_slow_rhs_post(level, finest_level, nrk, slow_dt, micro->Get_Qstate_Moist_Size(),
44 S_rhs, S_old, S_new, S_data, S_prim, avg_xmom[level], avg_ymom[level], avg_zmom[level],
45 xvel_new, yvel_new, zvel_new, cc_src, SmnSmn, eddyDiffs,
46 Hfx1, Hfx2, Hfx3, Q1fx1, Q1fx2, Q1fx3, Q2fx3, Diss,
47 fine_geom, solverChoice, m_SurfaceLayer, domain_bcs_type_d, domain_bcs_type,
48 z_phys_nd[level], z_phys_cc[level], ax[level], ay[level], az[level],
49 detJ_cc[level], new_detJ, stretched_dz_d[level], mapfac[level], EBFactory(level),
50 #ifdef ERF_USE_EAMXX_SHOC
51 eamxx_shoc_interface[level].
get(),
53 #ifdef ERF_USE_NATIVE_SHOC
54 native_shoc_driver[level].
get(),
56 fr_as_crse, fr_as_fine,
64 if (solverChoice.terrain_type == TerrainType::EB)
66 Vector<int> is_valid_slow_var; is_valid_slow_var.resize(
RhoQ1_comp+1,0);
67 if (solverChoice.turbChoice[level].use_tke) {is_valid_slow_var[
RhoKE_comp] = 1;}
69 if (solverChoice.moisture_type != MoistureType::None) {
76 MultiFab dUdt_tmp(ba, dm, num_comp_total, num_grow, MFInfo(), EBFactory(level));
77 dUdt_tmp.setVal(0, 0, num_comp_total, num_grow);
84 if (is_valid_slow_var[ivar])
93 MultiFab::Copy(dUdt_tmp, S_rhs[
IntVars::cons], start_comp, start_comp, num_comp, 0);
96 dUdt_tmp.FillBoundary(fine_geom.periodicity());
99 const BCRec* bc_ptr_d = domain_bcs_type_d.data();
108 for ( MFIter mfi(S_new[
IntVars::cons],TilingIfNotGPU()); mfi.isValid(); ++mfi)
110 Box tbx = mfi.tilebox();
114 Array4<const Real> detJ_arr = EBFactory(level).getVolFrac().const_array(mfi);
118 if (is_valid_slow_var[ivar])
127 ParallelFor(tbx, num_comp, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k,
int nn)
129 if (detJ_arr(i,j,k) >
zero) {
130 const int n = start_comp + nn;
131 snew(i,j,k,n) = sold(i,j,k,n) + slow_dt * srhs(i,j,k,n);
142 fast_only=
false, vel_and_mom_synced=
false);
144 if (solverChoice.moisture_tight_coupling) {
148 advance_microphysics(level, S_new[0], slow_dt, 123456789, old_step_time);
constexpr amrex::Real bogus_large_value
Definition: ERF_Constants.H:26
constexpr amrex::Real zero
Definition: ERF_Constants.H:8
@ nvars
Definition: ERF_DataStruct.H:98
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 NSCALARS
Definition: ERF_IndexDefines.H:16
#define RhoQ1_comp
Definition: ERF_IndexDefines.H:42
#define RhoKE_comp
Definition: ERF_IndexDefines.H:38
amrex::GpuArray< Real, AMREX_SPACEDIM > dxInv
Definition: ERF_InitCustomPertVels_ParticleTests.H:17
pp get("wavelength", wavelength)
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
void erf_slow_rhs_post(int level, int finest_level, int nrk, Real dt, int n_qstate, Vector< MultiFab > &S_rhs, Vector< MultiFab > &S_old, Vector< MultiFab > &S_new, Vector< MultiFab > &S_data, const MultiFab &S_prim, MultiFab &avg_xmom, MultiFab &avg_ymom, MultiFab &avg_zmom, const MultiFab &xvel, const MultiFab &yvel, const MultiFab &, const MultiFab &source, const MultiFab *SmnSmn, const MultiFab *eddyDiffs, MultiFab *Hfx1, MultiFab *Hfx2, MultiFab *Hfx3, MultiFab *Q1fx1, MultiFab *Q1fx2, MultiFab *Q1fx3, MultiFab *Q2fx3, MultiFab *Diss, const Geometry geom, const SolverChoice &solverChoice, std::unique_ptr< SurfaceLayer > &SurfLayer, const Gpu::DeviceVector< BCRec > &domain_bcs_type_d, const Vector< BCRec > &domain_bcs_type_h, std::unique_ptr< MultiFab > &z_phys_nd, std::unique_ptr< MultiFab > &z_phys_cc, std::unique_ptr< MultiFab > &ax, std::unique_ptr< MultiFab > &ay, std::unique_ptr< MultiFab > &az, std::unique_ptr< MultiFab > &detJ, MultiFab *detJ_new, Gpu::DeviceVector< Real > &stretched_dz_d, Vector< std::unique_ptr< MultiFab >> &mapfac, amrex::EBFArrayBoxFactory const &ebfact, YAFluxRegister *fr_as_crse, YAFluxRegister *fr_as_fine, std::unique_ptr< ReadBndryPlanes > &m_r2d)
Definition: ERF_SlowRhsPost.cpp:47
auto slow_rhs_fun_post
Definition: ERF_TI_slow_rhs_post.H:3
auto apply_bcs
Definition: ERF_TI_utils.H:34
@ cons
Definition: ERF_IndexDefines.H:192
@ xmom
Definition: ERF_IndexDefines.H:193