6 BL_PROFILE(
"cons_to_prim()");
8 int ncomp_prim = S_prim.nComp();
11 #pragma omp parallel if (amrex::Gpu::notInLaunchRegion())
13 for (MFIter mfi(cons_state,TilingIfNotGPU()); mfi.isValid(); ++mfi)
15 const Box& gbx = mfi.growntilebox(
ng);
16 const Array4<const Real>& cons_arr = cons_state.array(mfi);
17 const Array4< Real>& prim_arr = S_prim.array(mfi);
22 amrex::ParallelFor(gbx, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept
27 for (
int n = 1; n < ncomp_prim; ++n) {
35 const Box& gbx1 = mfi.growntilebox(1);
37 const Array4< Real>& pi_stage_arr = pi_stage.array(mfi);
38 const Real rdOcp = solverChoice.rdOcp;
40 amrex::ParallelFor(gbx1, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept
50 auto make_qt = [&](
const MultiFab& cons_state, MultiFab&
qt)
52 BL_PROFILE(
"make_qt()");
54 int n_qstate_moist = micro->Get_Qstate_Moist_Size();
60 for (
int n(1); n<n_qstate_moist; ++n) {
65 MultiFab::Divide(
qt, cons_state,
Rho_comp, 0, 1, 1);
72 const Real time_for_fp,
int ng_cons,
int ng_vel,
73 bool fast_only,
bool vel_and_mom_synced)
75 BL_PROFILE(
"apply_bcs()");
88 if (!vel_and_mom_synced) {
101 AMREX_ALWAYS_ASSERT (ng_cons >= 1);
105 ng_cons_to_use = std::max(ng_cons, ng_vel+1);
113 FillIntermediatePatch(level, time_for_fp,
117 ng_cons_to_use, 0, cons_only, scomp_cons, ncomp_cons);
127 if (vel_and_mom_synced) {
137 ng_cons_to_use = std::max(ng_cons, ng_vel+1);
147 ng_cons_to_use = ng_cons;
155 FillIntermediatePatch(level, time_for_fp,
159 ng_cons_to_use, ng_vel, cons_only, scomp_cons, ncomp_cons);
162 auto update_terrain_stage = [&](
int lev, Real old_step_time, Real old_stage_time, Real new_stage_time, Real slow_dt)
171 if (verbose) Print() <<
"Re-making old geometry at old time : " << old_step_time << std::endl;
176 Box terrain_bx(surroundingNodes(Geom(0).Domain())); terrain_bx.grow(z_phys_nd[lev]->nGrow());
177 FArrayBox terrain_fab_old(makeSlab(terrain_bx,2,0),1);
178 FArrayBox terrain_fab_src(makeSlab(terrain_bx,2,0),1);
179 FArrayBox terrain_fab_new(makeSlab(terrain_bx,2,0),1);
181 prob->init_terrain_surface(fine_geom,terrain_fab_old,old_step_time);
182 prob->init_terrain_surface(fine_geom,terrain_fab_src,old_stage_time);
183 prob->init_terrain_surface(fine_geom,terrain_fab_new,new_stage_time);
186 for (MFIter mfi(*z_phys_nd[lev],
false); mfi.isValid(); ++mfi)
188 Box isect = terrain_fab_old.box() & (*z_phys_nd[lev])[mfi].box();
189 ( *z_phys_nd[lev])[mfi].
template copy<RunOn::Device>(terrain_fab_old,isect,0,isect,0,1);
190 (*z_phys_nd_src[lev])[mfi].
template copy<RunOn::Device>(terrain_fab_src,isect,0,isect,0,1);
191 (*z_phys_nd_new[lev])[mfi].
template copy<RunOn::Device>(terrain_fab_new,isect,0,isect,0,1);
195 make_J (fine_geom, *z_phys_nd[lev], *detJ_cc[lev]);
196 make_areas (fine_geom, *z_phys_nd[lev], *ax[lev], *ay[lev], *az[lev]);
198 if (verbose) Print() <<
"Making src geometry at old_stage_time: "
199 << std::setprecision(timeprecision) << old_stage_time << std::endl;
201 make_J (fine_geom, *z_phys_nd_src[lev], *detJ_cc_src[lev]);
202 make_areas (fine_geom, *z_phys_nd_src[lev], *ax_src[lev], *ay_src[lev], *az_src[lev]);
203 make_zcc (fine_geom, *z_phys_nd_src[lev], *z_phys_cc_src[lev]);
205 if (verbose) Print() <<
"Making new geometry at new_stage_time: "
206 << std::setprecision(timeprecision) << new_stage_time << std::endl;
208 make_J (fine_geom, *z_phys_nd_new[lev], *detJ_cc_new[lev]);
210 Real inv_dt = 1./slow_dt;
213 #pragma omp parallel if (amrex::Gpu::notInLaunchRegion())
215 for (MFIter mfi(*z_t_rk[lev],TilingIfNotGPU()); mfi.isValid(); ++mfi)
217 Box gbx = mfi.growntilebox(IntVect(1,1,0));
219 const Array4<Real >& z_t_arr = z_t_rk[lev]->array(mfi);
220 const Array4<Real const>& z_nd_new_arr = z_phys_nd_new[lev]->const_array(mfi);
221 const Array4<Real const>& z_nd_old_arr = z_phys_nd[lev]->const_array(mfi);
224 amrex::ParallelFor(gbx, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept
227 z_t_arr(i,j,k) = 0.25 * inv_dt * (z_nd_new_arr(i+1,j+1,k) - z_nd_old_arr(i+1,j+1,k)
228 +z_nd_new_arr(i ,j+1,k) - z_nd_old_arr( i,j+1,k)
229 +z_nd_new_arr(i+1,j ,k) - z_nd_old_arr(i+1,j ,k)
230 +z_nd_new_arr(i ,j ,k) - z_nd_old_arr(i ,j ,k));
237 Vector<MultiFab>& S_data, std::unique_ptr<MultiFab>& z_t_pert)
240 Box terrain_bx(surroundingNodes(Geom(0).Domain())); terrain_bx.grow(z_phys_nd[lev]->nGrow());
242 if (verbose) Print() <<
"Making geometry at start of substep time: "
243 << std::setprecision(timeprecision) << old_substep_time << std::endl;
244 FArrayBox terrain_fab_old(makeSlab(terrain_bx,2,0),1);
245 prob->init_terrain_surface(fine_geom,terrain_fab_old,old_substep_time);
248 if (verbose) Print() <<
"Making geometry for end of substep time :"
249 << std::setprecision(timeprecision) << new_substep_time << std::endl;
250 FArrayBox terrain_fab_new(makeSlab(terrain_bx,2,0),1);
251 prob->init_terrain_surface(fine_geom,terrain_fab_new,new_substep_time);
254 for (MFIter mfi(*z_phys_nd[lev],
false); mfi.isValid(); ++mfi)
256 Box isect = terrain_fab_old.box() & (*z_phys_nd[lev])[mfi].box();
257 ( *z_phys_nd[lev])[mfi].
template copy<RunOn::Device>(terrain_fab_old,isect,0,isect,0,1);
258 (*z_phys_nd_new[lev])[mfi].
template copy<RunOn::Device>(terrain_fab_new,isect,0,isect,0,1);
262 make_J (fine_geom,*z_phys_nd[lev], *detJ_cc[lev]);
265 make_J (fine_geom,*z_phys_nd_new[lev], *detJ_cc_new[lev]);
267 Real inv_dt = 1./dtau;
271 for (MFIter mfi(*z_t_rk[lev],TilingIfNotGPU()); mfi.isValid(); ++mfi)
273 Box gbx = mfi.growntilebox(IntVect(1,1,0));
275 const Array4<Real >& z_t_arr = z_t_rk[lev]->array(mfi);
276 const Array4<Real >& zp_t_arr = z_t_pert->array(mfi);
278 const Array4<Real const>& z_nd_new_arr = z_phys_nd_new[lev]->const_array(mfi);
279 const Array4<Real const>& z_nd_old_arr = z_phys_nd[lev]->const_array(mfi);
282 amrex::ParallelFor(gbx, [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept
285 zp_t_arr(i,j,k) = 0.25 * inv_dt * (z_nd_new_arr(i+1,j+1,k) - z_nd_old_arr(i+1,j+1,k)
286 +z_nd_new_arr(i ,j+1,k) - z_nd_old_arr( i,j+1,k)
287 +z_nd_new_arr(i+1,j ,k) - z_nd_old_arr(i+1,j ,k)
288 +z_nd_new_arr(i ,j ,k) - z_nd_old_arr(i ,j ,k));
290 zp_t_arr(i,j,k) -= z_t_arr(i,j,k);
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real getExnergivenRTh(const amrex::Real rhotheta, const amrex::Real rdOcp, const amrex::Real qv=0.0)
Definition: ERF_EOS.H:159
#define Rho_comp
Definition: ERF_IndexDefines.H:36
#define RhoTheta_comp
Definition: ERF_IndexDefines.H:37
#define PrimTheta_comp
Definition: ERF_IndexDefines.H:50
#define RhoQ1_comp
Definition: ERF_IndexDefines.H:42
auto apply_bcs
Definition: ERF_TI_utils.H:71
auto cons_to_prim
Definition: ERF_TI_utils.H:4
auto update_terrain_substep
Definition: ERF_TI_utils.H:236
auto make_qt
Definition: ERF_TI_utils.H:50
auto update_terrain_stage
Definition: ERF_TI_utils.H:162
void make_areas(const Geometry &geom, MultiFab &z_phys_nd, MultiFab &ax, MultiFab &ay, MultiFab &az)
Definition: ERF_TerrainMetrics.cpp:558
void make_terrain_fitted_coords(int lev, const Geometry &geom, MultiFab &z_phys_nd, Vector< Real > const &z_levels_h, GpuArray< ERF_BC, AMREX_SPACEDIM *2 > &phys_bc_type)
Definition: ERF_TerrainMetrics.cpp:46
void make_J(const Geometry &geom, MultiFab &z_phys_nd, MultiFab &detJ_cc)
Definition: ERF_TerrainMetrics.cpp:520
void make_zcc(const Geometry &geom, MultiFab &z_phys_nd, MultiFab &z_phys_cc)
Definition: ERF_TerrainMetrics.cpp:623
@ ymom
Definition: ERF_IndexDefines.H:160
@ cons
Definition: ERF_IndexDefines.H:158
@ zmom
Definition: ERF_IndexDefines.H:161
@ xmom
Definition: ERF_IndexDefines.H:159
@ rho
Definition: ERF_Kessler.H:22
@ qt
Definition: ERF_Kessler.H:27
@ ng
Definition: ERF_Morrison.H:48