6 BL_PROFILE(
"make_pi_stage()");
9 #pragma omp parallel if (amrex::Gpu::notInLaunchRegion())
11 for (MFIter mfi(cons_state,TilingIfNotGPU()); mfi.isValid(); ++mfi)
16 const Box& gbx1 = mfi.growntilebox(1);
18 const Array4<const Real>& cons_arr = cons_state.const_array(mfi);
19 const Array4< Real>& pi_stage_arr = pi_stage.array(mfi);
21 const bool l_use_moisture = (solverChoice.moisture_type != MoistureType::None);
35 const Real time_for_fp,
int ng_cons,
int ng_vel,
36 bool fast_only,
bool vel_and_mom_synced)
38 BL_PROFILE(
"apply_bcs()");
51 if (!vel_and_mom_synced) {
68 ng_cons_to_use = std::max(ng_cons, ng_vel+1);
76 FillIntermediatePatch(level, time_for_fp,
80 ng_cons_to_use, 0, cons_only, scomp_cons, ncomp_cons);
90 if (vel_and_mom_synced) {
100 ng_cons_to_use = std::max(ng_cons, ng_vel+1);
110 ng_cons_to_use = ng_cons;
118 FillIntermediatePatch(level, time_for_fp,
122 ng_cons_to_use, ng_vel, cons_only, scomp_cons, ncomp_cons);
134 if (verbose) Print() <<
"Re-making old geometry at old time : " << old_step_time << std::endl;
139 Box terrain_bx(surroundingNodes(Geom(0).Domain())); terrain_bx.grow(z_phys_nd[lev]->nGrow());
140 FArrayBox terrain_fab_old(makeSlab(terrain_bx,2,0),1);
141 FArrayBox terrain_fab_src(makeSlab(terrain_bx,2,0),1);
142 FArrayBox terrain_fab_new(makeSlab(terrain_bx,2,0),1);
144 prob->init_terrain_surface(fine_geom,terrain_fab_old,old_step_time);
145 prob->init_terrain_surface(fine_geom,terrain_fab_src,old_stage_time);
146 prob->init_terrain_surface(fine_geom,terrain_fab_new,new_stage_time);
149 for (MFIter mfi(*z_phys_nd[lev],
false); mfi.isValid(); ++mfi)
151 Box isect = terrain_fab_old.box() & (*z_phys_nd[lev])[mfi].box();
152 ( *z_phys_nd[lev])[mfi].
template copy<RunOn::Device>(terrain_fab_old,isect,0,isect,0,1);
153 (*z_phys_nd_src[lev])[mfi].
template copy<RunOn::Device>(terrain_fab_src,isect,0,isect,0,1);
154 (*z_phys_nd_new[lev])[mfi].
template copy<RunOn::Device>(terrain_fab_new,isect,0,isect,0,1);
158 make_J (fine_geom, *z_phys_nd[lev], *detJ_cc[lev]);
159 make_areas (fine_geom, *z_phys_nd[lev], *ax[lev], *ay[lev], *az[lev]);
161 if (verbose) Print() <<
"Making src geometry at old_stage_time: "
162 << std::setprecision(timeprecision) << old_stage_time << std::endl;
164 make_J (fine_geom, *z_phys_nd_src[lev], *detJ_cc_src[lev]);
165 make_areas (fine_geom, *z_phys_nd_src[lev], *ax_src[lev], *ay_src[lev], *az_src[lev]);
166 make_zcc (fine_geom, *z_phys_nd_src[lev], *z_phys_cc_src[lev]);
168 if (verbose) Print() <<
"Making new geometry at new_stage_time: "
169 << std::setprecision(timeprecision) << new_stage_time << std::endl;
171 make_J (fine_geom, *z_phys_nd_new[lev], *detJ_cc_new[lev]);
176 #pragma omp parallel if (amrex::Gpu::notInLaunchRegion())
178 for (MFIter mfi(*z_t_rk[lev],TilingIfNotGPU()); mfi.isValid(); ++mfi)
180 Box gbx = mfi.growntilebox(IntVect(1,1,0));
182 const Array4<Real >& z_t_arr = z_t_rk[lev]->array(mfi);
183 const Array4<Real const>& z_nd_new_arr = z_phys_nd_new[lev]->const_array(mfi);
184 const Array4<Real const>& z_nd_old_arr = z_phys_nd[lev]->const_array(mfi);
190 z_t_arr(i,j,k) =
fourth * inv_dt * (z_nd_new_arr(i+1,j+1,k) - z_nd_old_arr(i+1,j+1,k)
191 +z_nd_new_arr(i ,j+1,k) - z_nd_old_arr( i,j+1,k)
192 +z_nd_new_arr(i+1,j ,k) - z_nd_old_arr(i+1,j ,k)
193 +z_nd_new_arr(i ,j ,k) - z_nd_old_arr(i ,j ,k));
200 Vector<MultiFab>& S_data, std::unique_ptr<MultiFab>& z_t_pert)
203 Box terrain_bx(surroundingNodes(Geom(0).Domain())); terrain_bx.grow(z_phys_nd[lev]->nGrow());
205 if (verbose) Print() <<
"Making geometry at start of substep time: "
206 << std::setprecision(timeprecision) << old_substep_time << std::endl;
207 FArrayBox terrain_fab_old(makeSlab(terrain_bx,2,0),1);
208 prob->init_terrain_surface(fine_geom,terrain_fab_old,old_substep_time);
211 if (verbose) Print() <<
"Making geometry for end of substep time :"
212 << std::setprecision(timeprecision) << new_substep_time << std::endl;
213 FArrayBox terrain_fab_new(makeSlab(terrain_bx,2,0),1);
214 prob->init_terrain_surface(fine_geom,terrain_fab_new,new_substep_time);
217 for (MFIter mfi(*z_phys_nd[lev],
false); mfi.isValid(); ++mfi)
219 Box isect = terrain_fab_old.box() & (*z_phys_nd[lev])[mfi].box();
220 ( *z_phys_nd[lev])[mfi].
template copy<RunOn::Device>(terrain_fab_old,isect,0,isect,0,1);
221 (*z_phys_nd_new[lev])[mfi].
template copy<RunOn::Device>(terrain_fab_new,isect,0,isect,0,1);
225 make_J (fine_geom,*z_phys_nd[lev], *detJ_cc[lev]);
228 make_J (fine_geom,*z_phys_nd_new[lev], *detJ_cc_new[lev]);
234 for (MFIter mfi(*z_t_rk[lev],TilingIfNotGPU()); mfi.isValid(); ++mfi)
236 Box gbx = mfi.growntilebox(IntVect(1,1,0));
238 const Array4<Real >& z_t_arr = z_t_rk[lev]->array(mfi);
239 const Array4<Real >& zp_t_arr = z_t_pert->array(mfi);
241 const Array4<Real const>& z_nd_new_arr = z_phys_nd_new[lev]->const_array(mfi);
242 const Array4<Real const>& z_nd_old_arr = z_phys_nd[lev]->const_array(mfi);
248 zp_t_arr(i,j,k) =
fourth * inv_dt * (z_nd_new_arr(i+1,j+1,k) - z_nd_old_arr(i+1,j+1,k)
249 +z_nd_new_arr(i ,j+1,k) - z_nd_old_arr( i,j+1,k)
250 +z_nd_new_arr(i+1,j ,k) - z_nd_old_arr(i+1,j ,k)
251 +z_nd_new_arr(i ,j ,k) - z_nd_old_arr(i ,j ,k));
253 zp_t_arr(i,j,k) -= z_t_arr(i,j,k);
constexpr amrex::Real one
Definition: ERF_Constants.H:7
constexpr amrex::Real fourth
Definition: ERF_Constants.H:12
constexpr amrex::Real zero
Definition: ERF_Constants.H:6
AMREX_GPU_HOST_DEVICE AMREX_FORCE_INLINE amrex::Real getExnergivenRTh(const amrex::Real rhotheta, const amrex::Real rdOcp, const amrex::Real qv=amrex::Real(0))
Definition: ERF_EOS.H:156
#define Rho_comp
Definition: ERF_IndexDefines.H:36
#define RhoTheta_comp
Definition: ERF_IndexDefines.H:37
#define RhoQ1_comp
Definition: ERF_IndexDefines.H:42
const Real rdOcp
Definition: ERF_InitCustomPert_Bomex.H:16
AMREX_ALWAYS_ASSERT(bx.length()[2]==khi+1)
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
auto make_pi_stage
Definition: ERF_TI_utils.H:4
auto apply_bcs
Definition: ERF_TI_utils.H:34
auto update_terrain_substep
Definition: ERF_TI_utils.H:199
auto update_terrain_stage
Definition: ERF_TI_utils.H:125
void make_areas(const Geometry &geom, MultiFab &z_phys_nd, MultiFab &ax, MultiFab &ay, MultiFab &az)
Definition: ERF_TerrainMetrics.cpp:561
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:47
void make_J(const Geometry &geom, MultiFab &z_phys_nd, MultiFab &detJ_cc)
Definition: ERF_TerrainMetrics.cpp:523
void make_zcc(const Geometry &geom, MultiFab &z_phys_nd, MultiFab &z_phys_cc)
Definition: ERF_TerrainMetrics.cpp:628
@ ymom
Definition: ERF_IndexDefines.H:194
@ cons
Definition: ERF_IndexDefines.H:192
@ zmom
Definition: ERF_IndexDefines.H:195
@ xmom
Definition: ERF_IndexDefines.H:193