179 BL_PROFILE_REGION(
"realbdy_compute_interior_ghost_RHS()");
188 Array4<Real> bdatxlo, bdatxhi, bdatylo, bdatyhi;
189 Array4<Real> btenxlo, btenxhi, btenylo, btenyhi;
192 Vector<std::unique_ptr<PlaneVector>>& bndry_data = m_r2d->interp_in_time(time);
193 bdatxlo = (*bndry_data[0])[0].array();
194 bdatylo = (*bndry_data[1])[0].array();
195 bdatxhi = (*bndry_data[3])[0].array();
196 bdatyhi = (*bndry_data[4])[0].array();
198 Vector<std::unique_ptr<PlaneVector>>& bndry_tend = m_r2d->get_tendency(time);
199 btenxlo = (*bndry_tend[0])[0].array();
200 btenylo = (*bndry_tend[1])[0].array();
201 btenxhi = (*bndry_tend[3])[0].array();
202 btenyhi = (*bndry_tend[4])[0].array();
206 Real F1 =
one/(nudge_factor*delta_t);
209 Real dT = bdy_time_interval;
211 int n_time =
static_cast<int>( (time-start_bdy_time) / dT);
212 int n_time_p1 = n_time + 1;
213 Real alpha = ((time-start_bdy_time) - n_time * dT) / dT;
216 if (time >= final_bdy_time) {
217 n_time =
static_cast<int>( (final_bdy_time - start_bdy_time)/ dT);
226 FArrayBox U_xlo, U_xhi, U_ylo, U_yhi;
227 FArrayBox V_xlo, V_xhi, V_ylo, V_yhi;
228 FArrayBox T_xlo, T_xhi, T_ylo, T_yhi;
249 for (
int ivar(ivarU); ivar < BdyEnd; ivar++) {
250 int ivar_idx = var_map[ivar];
251 Box domain = geom.Domain();
252 auto ixtype = S_cur_data[ivar_idx].boxArray().ixType();
253 domain.convert(ixtype);
258 Box gdom(domain); gdom.grow(ng_vect);
259 Box bx_xlo, bx_xhi, bx_ylo, bx_yhi;
267 U_xlo.resize(bx_xlo,1,The_Async_Arena()); U_xhi.resize(bx_xhi,1,The_Async_Arena());
268 U_ylo.resize(bx_ylo,1,The_Async_Arena()); U_yhi.resize(bx_yhi,1,The_Async_Arena());
269 }
else if (ivar == ivarV) {
270 V_xlo.resize(bx_xlo,1,The_Async_Arena()); V_xhi.resize(bx_xhi,1,The_Async_Arena());
271 V_ylo.resize(bx_ylo,1,The_Async_Arena()); V_yhi.resize(bx_yhi,1,The_Async_Arena());
272 }
else if (ivar == ivarT){
273 T_xlo.resize(bx_xlo,1,The_Async_Arena()); T_xhi.resize(bx_xhi,1,The_Async_Arena());
274 T_ylo.resize(bx_ylo,1,The_Async_Arena()); T_yhi.resize(bx_yhi,1,The_Async_Arena());
289 for (
int ivar(ivarU); ivar < BdyEnd; ivar++) {
290 int ivar_idx = var_map[ivar];
291 Box domain = geom.Domain();
292 auto ixtype = S_cur_data[ivar_idx].boxArray().ixType();
293 domain.convert(ixtype);
294 const auto&
dom_lo = lbound(domain);
295 const auto&
dom_hi = ubound(domain);
298 int bdy_comp = bnd_map[ivar];
299 const auto& dom_cc_lo = lbound(geom.Domain());
300 const auto& dom_cc_hi = ubound(geom.Domain());
303 #pragma omp parallel if (Gpu::notInLaunchRegion())
305 for (MFIter mfi(S_cur_data[ivar_idx],TilingIfNotGPU()); mfi.isValid(); ++mfi) {
309 Box gtbx = grow(mfi.tilebox(ixtype.toIntVect()),ng_vect);
310 Box tbx_xlo, tbx_xhi, tbx_ylo, tbx_yhi;
316 Array4<Real> arr_xlo; Array4<Real> arr_xhi;
317 Array4<Real> arr_ylo; Array4<Real> arr_yhi;
319 arr_xlo = U_xlo.array(); arr_xhi = U_xhi.array();
320 arr_ylo = U_ylo.array(); arr_yhi = U_yhi.array();
321 }
else if (ivar == ivarV) {
322 arr_xlo = V_xlo.array(); arr_xhi = V_xhi.array();
323 arr_ylo = V_ylo.array(); arr_yhi = V_yhi.array();
324 }
else if (ivar == ivarT){
325 arr_xlo = T_xlo.array(); arr_xhi = T_xhi.array();
326 arr_ylo = T_ylo.array(); arr_yhi = T_yhi.array();
332 const auto& bdatxlo_n = bdy_data_xlo[n_time ][ivar].const_array();
333 const auto& bdatxlo_np1 = bdy_data_xlo[n_time_p1][ivar].const_array();
334 const auto& bdatxhi_n = bdy_data_xhi[n_time ][ivar].const_array();
335 const auto& bdatxhi_np1 = bdy_data_xhi[n_time_p1][ivar].const_array();
336 const auto& bdatylo_n = bdy_data_ylo[n_time ][ivar].const_array();
337 const auto& bdatylo_np1 = bdy_data_ylo[n_time_p1][ivar].const_array();
338 const auto& bdatyhi_n = bdy_data_yhi[n_time ][ivar].const_array();
339 const auto& bdatyhi_np1 = bdy_data_yhi[n_time_p1][ivar].const_array();
349 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept
352 int jj = std::max(j ,
dom_lo.y); jj = std::min(jj,
dom_hi.y);
356 rho_interp =
myhalf * ( r_arr(i-1,j ,k) + r_arr(i,j,k) );
357 }
else if (ivar==ivarV) {
358 rho_interp =
myhalf * ( r_arr(i ,j-1,k) + r_arr(i,j,k) );
360 rho_interp = r_arr(i,j,k);
364 int ii2 = std::min(std::max(i , dom_cc_lo.x), dom_cc_hi.x);
365 int jj2 = std::min(std::max(j , dom_cc_lo.y), dom_cc_hi.y);
366 arr_xlo(i,j,k) = rho_interp * bdatxlo(ii2,jj2,k,bdy_comp);
368 arr_xlo(i,j,k) = rho_interp * ( oma * bdatxlo_n (ii,jj,k,0)
369 +
alpha * bdatxlo_np1(ii,jj,k,0) );
372 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept
375 int jj = std::max(j ,
dom_lo.y); jj = std::min(jj,
dom_hi.y);
379 rho_interp =
myhalf * ( r_arr(i-1,j ,k) + r_arr(i,j,k) );
380 }
else if (ivar==ivarV) {
381 rho_interp =
myhalf * ( r_arr(i ,j-1,k) + r_arr(i,j,k) );
383 rho_interp = r_arr(i,j,k);
387 int ii2 = std::min(std::max(i , dom_cc_lo.x), dom_cc_hi.x);
388 int jj2 = std::min(std::max(j , dom_cc_lo.y), dom_cc_hi.y);
389 arr_xhi(i,j,k) = rho_interp * bdatxhi(ii2,jj2,k,bdy_comp);
391 arr_xhi(i,j,k) = rho_interp * ( oma * bdatxhi_n (ii,jj,k,0)
392 +
alpha * bdatxhi_np1(ii,jj,k,0) );
397 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept
399 int ii = std::max(i ,
dom_lo.x); ii = std::min(ii,
dom_hi.x);
404 rho_interp =
myhalf * ( r_arr(i-1,j ,k) + r_arr(i,j,k) );
405 }
else if (ivar==ivarV) {
406 rho_interp =
myhalf * ( r_arr(i ,j-1,k) + r_arr(i,j,k) );
408 rho_interp = r_arr(i,j,k);
412 int ii2 = std::min(std::max(i , dom_cc_lo.x), dom_cc_hi.x);
413 int jj2 = std::min(std::max(j , dom_cc_lo.y), dom_cc_hi.y);
414 arr_ylo(i,j,k) = rho_interp * bdatylo(ii2,jj2,k,bdy_comp);
416 arr_ylo(i,j,k) = rho_interp * ( oma * bdatylo_n (ii,jj,k,0)
417 +
alpha * bdatylo_np1(ii,jj,k,0) );
420 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept
422 int ii = std::max(i ,
dom_lo.x); ii = std::min(ii,
dom_hi.x);
427 rho_interp =
myhalf * ( r_arr(i-1,j ,k) + r_arr(i,j,k) );
428 }
else if (ivar==ivarV) {
429 rho_interp =
myhalf * ( r_arr(i ,j-1,k) + r_arr(i,j,k) );
431 rho_interp = r_arr(i,j,k);
435 int ii2 = std::min(std::max(i , dom_cc_lo.x), dom_cc_hi.x);
436 int jj2 = std::min(std::max(j , dom_cc_lo.y), dom_cc_hi.y);
437 arr_yhi(i,j,k) = rho_interp * bdatyhi(ii2,jj2,k,bdy_comp);
439 arr_yhi(i,j,k) = rho_interp * ( oma * bdatyhi_n (ii,jj,k,0)
440 +
alpha * bdatyhi_np1(ii,jj,k,0) );
449 auto dx = geom.CellSizeArray();
450 auto ProbLo = geom.ProbLoArray();
451 auto ProbHi = geom.ProbHiArray();
453 for (
int ivar(ivarU); ivar < BdyEnd; ivar++) {
454 int ivar_idx = ivar_map[ivar];
455 int icomp = comp_map[ivar];
457 Box domain = geom.Domain();
458 domain.convert(S_cur_data[ivar_idx].boxArray().ixType());
462 #pragma omp parallel if (Gpu::notInLaunchRegion())
464 for (MFIter mfi(S_cur_data[ivar_idx],TilingIfNotGPU()); mfi.isValid(); ++mfi)
466 Box tbx = mfi.tilebox();
467 Box tbx_xlo, tbx_xhi, tbx_ylo, tbx_yhi;
473 Array4<Real> rhs_arr; Array4<Real> data_arr;
474 Array4<Real> arr_xlo; Array4<Real> arr_xhi;
475 Array4<Real> arr_ylo; Array4<Real> arr_yhi;
477 arr_xlo = U_xlo.array(); arr_xhi = U_xhi.array();
478 arr_ylo = U_ylo.array(); arr_yhi = U_yhi.array();
481 }
else if (ivar == ivarV) {
482 arr_xlo = V_xlo.array(); arr_xhi = V_xhi.array();
483 arr_ylo = V_ylo.array(); arr_yhi = V_yhi.array();
486 }
else if (ivar == ivarT){
487 arr_xlo = T_xlo.array(); arr_xhi = T_xhi.array();
488 arr_ylo = T_ylo.array(); arr_yhi = T_yhi.array();
496 width,
dx, ProbLo, ProbHi, F1,
497 tbx_xlo , tbx_xhi , tbx_ylo , tbx_yhi ,
498 arr_xlo , arr_xhi , arr_ylo , arr_yhi ,
499 data_arr, rhs_arr , c_p,
rdOcp);
505 Box domain = geom.Domain();
506 Box domainx = convert(domain, IntVect(1,0,0));
507 Box domainy = convert(domain, IntVect(0,1,0));
509 int ilo = domainx.smallEnd(0);
510 int ihi = domainx.bigEnd(0);
511 int jlo = domainy.smallEnd(1);
512 int jhi = domainy.bigEnd(1);
515 #pragma omp parallel if (Gpu::notInLaunchRegion())
517 for (MFIter mfi(S_cur_data[
IntVars::cons],TilingIfNotGPU()); mfi.isValid(); ++mfi)
519 Box tbx = mfi.nodaltilebox(0);
521 if (tbx.smallEnd(0) == ilo) {
522 tbx_lo = makeSlab(tbx,0,ilo);
524 if (tbx.bigEnd(0) == ihi) {
525 tbx_hi = makeSlab(tbx,0,ihi);
528 Box tby = mfi.nodaltilebox(1);
530 if (tby.smallEnd(1) == jlo) {
531 tby_lo = makeSlab(tby,1,jlo);
533 if (tby.bigEnd(1) == jhi) {
534 tby_hi = makeSlab(tby,1,jhi);
540 Array4<const Real> rhs_cons = S_rhs[
IntVars::cons].const_array(mfi);
541 Array4<const Real> cons_arr = S_cur_data[
IntVars::cons].const_array(mfi);
543 const auto& bdatxlo_n = bdy_data_xlo[n_time ][ivarU].const_array();
544 const auto& bdatxlo_np1 = bdy_data_xlo[n_time_p1][ivarU].const_array();
545 const auto& bdatxhi_n = bdy_data_xhi[n_time ][ivarU].const_array();
546 const auto& bdatxhi_np1 = bdy_data_xhi[n_time_p1][ivarU].const_array();
548 const auto& bdatylo_n = bdy_data_ylo[n_time ][ivarV].const_array();
549 const auto& bdatylo_np1 = bdy_data_ylo[n_time_p1][ivarV].const_array();
550 const auto& bdatyhi_n = bdy_data_yhi[n_time ][ivarV].const_array();
551 const auto& bdatyhi_np1 = bdy_data_yhi[n_time_p1][ivarV].const_array();
554 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept
556 Real rho_tend = rhs_cons(i,j,k);
557 Real rho_val =
Real(0.5) * (cons_arr(i,j,k) + cons_arr(i-1,j,k));
563 u_tend = (bdatxlo_np1(i,j,k) - bdatxlo_n(i,j,k)) / bdy_time_interval;
564 u_val = oma * bdatxlo_n(i,j,k) +
alpha * bdatxlo_np1(i,j,k);
566 rhs_xmom(i,j,k) = rho_val * u_tend + u_val * rho_tend;
568 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept
570 Real rho_tend = rhs_cons(i,j,k);
571 Real rho_val =
Real(0.5) * (cons_arr(i,j,k) + cons_arr(i-1,j,k));
577 u_tend = (bdatxhi_np1(i,j,k) - bdatxhi_n(i,j,k)) / bdy_time_interval;
578 u_val = oma * bdatxhi_n(i,j,k) +
alpha * bdatxhi_np1(i,j,k);
580 rhs_xmom(i,j,k) = rho_val * u_tend + u_val * rho_tend;
584 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept
586 Real rho_tend = rhs_cons(i,j,k);
587 Real rho_val =
Real(0.5) * (cons_arr(i,j,k) + cons_arr(i,j-1,k));
593 v_tend = (bdatylo_np1(i,j,k) - bdatylo_n(i,j,k)) / bdy_time_interval;
594 v_val = oma * bdatylo_n(i,j,k) +
alpha * bdatylo_np1(i,j,k);
596 rhs_ymom(i,j,k) = rho_val * v_tend + v_val * rho_tend;
598 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept
600 Real rho_tend = rhs_cons(i,j,k);
601 Real rho_val =
Real(0.5) * (cons_arr(i,j,k) + cons_arr(i,j-1,k));
607 v_tend = (bdatyhi_np1(i,j,k) - bdatyhi_n(i,j,k)) / bdy_time_interval;
608 v_val = oma * bdatyhi_n(i,j,k) +
alpha * bdatyhi_np1(i,j,k);
610 rhs_ymom(i,j,k) = rho_val * v_tend + v_val * rho_tend;
#define RhoTheta_comp
Definition: ERF_IndexDefines.H:37
const Real dx
Definition: ERF_InitCustomPert_ABL.H:23
const Real rdOcp
Definition: ERF_InitCustomPert_Bomex.H:16
void realbdy_interior_bxs_xy(const Box &bx, const Box &domain, const int &width, Box &bx_xlo, Box &bx_xhi, Box &bx_ylo, Box &bx_yhi, const IntVect &ng_vect, const bool get_int_ng)
Definition: ERF_InteriorGhostCells.cpp:23
AMREX_FORCE_INLINE IntVect offset(const int face_dir, const int normal)
Definition: ERF_ReadBndryPlanes.cpp:28
AMREX_GPU_HOST AMREX_FORCE_INLINE void realbdy_compute_relaxation(const int &icomp, const int &num_var, const int &width, const amrex::GpuArray< amrex::Real, AMREX_SPACEDIM > &dx, const amrex::GpuArray< amrex::Real, AMREX_SPACEDIM > &ProbLo, const amrex::GpuArray< amrex::Real, AMREX_SPACEDIM > &ProbHi, const amrex::Real &F1, const amrex::Box &bx_xlo, const amrex::Box &bx_xhi, const amrex::Box &bx_ylo, const amrex::Box &bx_yhi, const amrex::Array4< const amrex::Real > &arr_xlo, const amrex::Array4< const amrex::Real > &arr_xhi, const amrex::Array4< const amrex::Real > &arr_ylo, const amrex::Array4< const amrex::Real > &arr_yhi, const amrex::Array4< const amrex::Real > &data_arr, const amrex::Array4< amrex::Real > &rhs_arr, const amrex::Real &c_p, const amrex::Real &rdOcp, const int bdy_moist_nudge_type=0)
Definition: ERF_Utils.H:236
@ RhoTheta_bc_comp
Definition: ERF_IndexDefines.H:88
@ yvel_bc
Definition: ERF_IndexDefines.H:103
@ xvel_bc
Definition: ERF_IndexDefines.H:102
@ U
Definition: ERF_IndexDefines.H:123
@ NumTypes
Definition: ERF_IndexDefines.H:127
@ T
Definition: ERF_IndexDefines.H:125
@ V
Definition: ERF_IndexDefines.H:124
@ xvel
Definition: ERF_IndexDefines.H:175
@ cons
Definition: ERF_IndexDefines.H:174
@ yvel
Definition: ERF_IndexDefines.H:176
real(kind=kind_phys), parameter, public alpha
Definition: ERF_module_mp_wsm6.F90:44