177 BL_PROFILE_REGION(
"realbdy_compute_interior_ghost_RHS()");
186 Array4<Real> bdatxlo, bdatxhi, bdatylo, bdatyhi;
187 Array4<Real> btenxlo, btenxhi, btenylo, btenyhi;
190 Vector<std::unique_ptr<PlaneVector>>& bndry_data = m_r2d->interp_in_time(time);
191 bdatxlo = (*bndry_data[0])[0].array();
192 bdatylo = (*bndry_data[1])[0].array();
193 bdatxhi = (*bndry_data[3])[0].array();
194 bdatyhi = (*bndry_data[4])[0].array();
196 Vector<std::unique_ptr<PlaneVector>>& bndry_tend = m_r2d->get_tendency(time);
197 btenxlo = (*bndry_tend[0])[0].array();
198 btenylo = (*bndry_tend[1])[0].array();
199 btenxhi = (*bndry_tend[3])[0].array();
200 btenyhi = (*bndry_tend[4])[0].array();
204 Real F1 =
one/(nudge_factor*delta_t);
207 Real dT = bdy_time_interval;
209 int n_time =
static_cast<int>( (time-start_bdy_time) / dT);
210 int n_time_p1 = n_time + 1;
211 Real alpha = ((time-start_bdy_time) - n_time * dT) / dT;
214 if (time >= final_bdy_time) {
215 n_time =
static_cast<int>( (final_bdy_time - start_bdy_time)/ dT);
224 FArrayBox U_xlo, U_xhi, U_ylo, U_yhi;
225 FArrayBox V_xlo, V_xhi, V_ylo, V_yhi;
226 FArrayBox T_xlo, T_xhi, T_ylo, T_yhi;
247 for (
int ivar(ivarU); ivar < BdyEnd; ivar++) {
248 int ivar_idx = var_map[ivar];
249 Box domain = geom.Domain();
250 auto ixtype = S_cur_data[ivar_idx].boxArray().ixType();
251 domain.convert(ixtype);
256 Box gdom(domain); gdom.grow(ng_vect);
257 Box bx_xlo, bx_xhi, bx_ylo, bx_yhi;
265 U_xlo.resize(bx_xlo,1,The_Async_Arena()); U_xhi.resize(bx_xhi,1,The_Async_Arena());
266 U_ylo.resize(bx_ylo,1,The_Async_Arena()); U_yhi.resize(bx_yhi,1,The_Async_Arena());
267 }
else if (ivar == ivarV) {
268 V_xlo.resize(bx_xlo,1,The_Async_Arena()); V_xhi.resize(bx_xhi,1,The_Async_Arena());
269 V_ylo.resize(bx_ylo,1,The_Async_Arena()); V_yhi.resize(bx_yhi,1,The_Async_Arena());
270 }
else if (ivar == ivarT){
271 T_xlo.resize(bx_xlo,1,The_Async_Arena()); T_xhi.resize(bx_xhi,1,The_Async_Arena());
272 T_ylo.resize(bx_ylo,1,The_Async_Arena()); T_yhi.resize(bx_yhi,1,The_Async_Arena());
287 for (
int ivar(ivarU); ivar < BdyEnd; ivar++) {
288 int ivar_idx = var_map[ivar];
289 Box domain = geom.Domain();
290 auto ixtype = S_cur_data[ivar_idx].boxArray().ixType();
291 domain.convert(ixtype);
292 const auto&
dom_lo = lbound(domain);
293 const auto&
dom_hi = ubound(domain);
296 int bdy_comp = bnd_map[ivar];
297 const auto& dom_cc_lo = lbound(geom.Domain());
298 const auto& dom_cc_hi = ubound(geom.Domain());
301 #pragma omp parallel if (Gpu::notInLaunchRegion())
303 for (MFIter mfi(S_cur_data[ivar_idx],TilingIfNotGPU()); mfi.isValid(); ++mfi) {
307 Box gtbx = grow(mfi.tilebox(ixtype.toIntVect()),ng_vect);
308 Box tbx_xlo, tbx_xhi, tbx_ylo, tbx_yhi;
314 Array4<Real> arr_xlo; Array4<Real> arr_xhi;
315 Array4<Real> arr_ylo; Array4<Real> arr_yhi;
317 arr_xlo = U_xlo.array(); arr_xhi = U_xhi.array();
318 arr_ylo = U_ylo.array(); arr_yhi = U_yhi.array();
319 }
else if (ivar == ivarV) {
320 arr_xlo = V_xlo.array(); arr_xhi = V_xhi.array();
321 arr_ylo = V_ylo.array(); arr_yhi = V_yhi.array();
322 }
else if (ivar == ivarT){
323 arr_xlo = T_xlo.array(); arr_xhi = T_xhi.array();
324 arr_ylo = T_ylo.array(); arr_yhi = T_yhi.array();
330 const auto& bdatxlo_n = bdy_data_xlo[n_time ][ivar].const_array();
331 const auto& bdatxlo_np1 = bdy_data_xlo[n_time_p1][ivar].const_array();
332 const auto& bdatxhi_n = bdy_data_xhi[n_time ][ivar].const_array();
333 const auto& bdatxhi_np1 = bdy_data_xhi[n_time_p1][ivar].const_array();
334 const auto& bdatylo_n = bdy_data_ylo[n_time ][ivar].const_array();
335 const auto& bdatylo_np1 = bdy_data_ylo[n_time_p1][ivar].const_array();
336 const auto& bdatyhi_n = bdy_data_yhi[n_time ][ivar].const_array();
337 const auto& bdatyhi_np1 = bdy_data_yhi[n_time_p1][ivar].const_array();
347 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept
350 int jj = std::max(j ,
dom_lo.y); jj = std::min(jj,
dom_hi.y);
354 rho_interp =
myhalf * ( r_arr(i-1,j ,k) + r_arr(i,j,k) );
355 }
else if (ivar==ivarV) {
356 rho_interp =
myhalf * ( r_arr(i ,j-1,k) + r_arr(i,j,k) );
358 rho_interp = r_arr(i,j,k);
362 int ii2 = std::min(std::max(i , dom_cc_lo.x), dom_cc_hi.x);
363 int jj2 = std::min(std::max(j , dom_cc_lo.y), dom_cc_hi.y);
364 arr_xlo(i,j,k) = rho_interp * bdatxlo(ii2,jj2,k,bdy_comp);
366 arr_xlo(i,j,k) = rho_interp * ( oma * bdatxlo_n (ii,jj,k,0)
367 +
alpha * bdatxlo_np1(ii,jj,k,0) );
370 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept
373 int jj = std::max(j ,
dom_lo.y); jj = std::min(jj,
dom_hi.y);
377 rho_interp =
myhalf * ( r_arr(i-1,j ,k) + r_arr(i,j,k) );
378 }
else if (ivar==ivarV) {
379 rho_interp =
myhalf * ( r_arr(i ,j-1,k) + r_arr(i,j,k) );
381 rho_interp = r_arr(i,j,k);
385 int ii2 = std::min(std::max(i , dom_cc_lo.x), dom_cc_hi.x);
386 int jj2 = std::min(std::max(j , dom_cc_lo.y), dom_cc_hi.y);
387 arr_xhi(i,j,k) = rho_interp * bdatxhi(ii2,jj2,k,bdy_comp);
389 arr_xhi(i,j,k) = rho_interp * ( oma * bdatxhi_n (ii,jj,k,0)
390 +
alpha * bdatxhi_np1(ii,jj,k,0) );
395 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept
397 int ii = std::max(i ,
dom_lo.x); ii = std::min(ii,
dom_hi.x);
402 rho_interp =
myhalf * ( r_arr(i-1,j ,k) + r_arr(i,j,k) );
403 }
else if (ivar==ivarV) {
404 rho_interp =
myhalf * ( r_arr(i ,j-1,k) + r_arr(i,j,k) );
406 rho_interp = r_arr(i,j,k);
410 int ii2 = std::min(std::max(i , dom_cc_lo.x), dom_cc_hi.x);
411 int jj2 = std::min(std::max(j , dom_cc_lo.y), dom_cc_hi.y);
412 arr_ylo(i,j,k) = rho_interp * bdatylo(ii2,jj2,k,bdy_comp);
414 arr_ylo(i,j,k) = rho_interp * ( oma * bdatylo_n (ii,jj,k,0)
415 +
alpha * bdatylo_np1(ii,jj,k,0) );
418 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept
420 int ii = std::max(i ,
dom_lo.x); ii = std::min(ii,
dom_hi.x);
425 rho_interp =
myhalf * ( r_arr(i-1,j ,k) + r_arr(i,j,k) );
426 }
else if (ivar==ivarV) {
427 rho_interp =
myhalf * ( r_arr(i ,j-1,k) + r_arr(i,j,k) );
429 rho_interp = r_arr(i,j,k);
433 int ii2 = std::min(std::max(i , dom_cc_lo.x), dom_cc_hi.x);
434 int jj2 = std::min(std::max(j , dom_cc_lo.y), dom_cc_hi.y);
435 arr_yhi(i,j,k) = rho_interp * bdatyhi(ii2,jj2,k,bdy_comp);
437 arr_yhi(i,j,k) = rho_interp * ( oma * bdatyhi_n (ii,jj,k,0)
438 +
alpha * bdatyhi_np1(ii,jj,k,0) );
447 auto dx = geom.CellSizeArray();
448 auto ProbLo = geom.ProbLoArray();
449 auto ProbHi = geom.ProbHiArray();
451 for (
int ivar(ivarU); ivar < BdyEnd; ivar++) {
452 int ivar_idx = ivar_map[ivar];
453 int icomp = comp_map[ivar];
455 Box domain = geom.Domain();
456 domain.convert(S_cur_data[ivar_idx].boxArray().ixType());
460 #pragma omp parallel if (Gpu::notInLaunchRegion())
462 for (MFIter mfi(S_cur_data[ivar_idx],TilingIfNotGPU()); mfi.isValid(); ++mfi)
464 Box tbx = mfi.tilebox();
465 Box tbx_xlo, tbx_xhi, tbx_ylo, tbx_yhi;
471 Array4<Real> rhs_arr; Array4<Real> data_arr;
472 Array4<Real> arr_xlo; Array4<Real> arr_xhi;
473 Array4<Real> arr_ylo; Array4<Real> arr_yhi;
475 arr_xlo = U_xlo.array(); arr_xhi = U_xhi.array();
476 arr_ylo = U_ylo.array(); arr_yhi = U_yhi.array();
479 }
else if (ivar == ivarV) {
480 arr_xlo = V_xlo.array(); arr_xhi = V_xhi.array();
481 arr_ylo = V_ylo.array(); arr_yhi = V_yhi.array();
484 }
else if (ivar == ivarT){
485 arr_xlo = T_xlo.array(); arr_xhi = T_xhi.array();
486 arr_ylo = T_ylo.array(); arr_yhi = T_yhi.array();
494 width,
dx, ProbLo, ProbHi, F1,
495 tbx_xlo , tbx_xhi , tbx_ylo , tbx_yhi ,
496 arr_xlo , arr_xhi , arr_ylo , arr_yhi ,
503 Box domain = geom.Domain();
504 Box domainx = convert(domain, IntVect(1,0,0));
505 Box domainy = convert(domain, IntVect(0,1,0));
507 int ilo = domainx.smallEnd(0);
508 int ihi = domainx.bigEnd(0);
509 int jlo = domainy.smallEnd(1);
510 int jhi = domainy.bigEnd(1);
513 #pragma omp parallel if (Gpu::notInLaunchRegion())
515 for (MFIter mfi(S_cur_data[
IntVars::cons],TilingIfNotGPU()); mfi.isValid(); ++mfi)
517 Box tbx = mfi.nodaltilebox(0);
519 if (tbx.smallEnd(0) == ilo) {
520 tbx_lo = makeSlab(tbx,0,ilo);
522 if (tbx.bigEnd(0) == ihi) {
523 tbx_hi = makeSlab(tbx,0,ihi);
526 Box tby = mfi.nodaltilebox(1);
528 if (tby.smallEnd(1) == jlo) {
529 tby_lo = makeSlab(tby,1,jlo);
531 if (tby.bigEnd(1) == jhi) {
532 tby_hi = makeSlab(tby,1,jhi);
538 Array4<const Real> rhs_cons = S_rhs[
IntVars::cons].const_array(mfi);
539 Array4<const Real> cons_arr = S_cur_data[
IntVars::cons].const_array(mfi);
541 const auto& bdatxlo_n = bdy_data_xlo[n_time ][ivarU].const_array();
542 const auto& bdatxlo_np1 = bdy_data_xlo[n_time_p1][ivarU].const_array();
543 const auto& bdatxhi_n = bdy_data_xhi[n_time ][ivarU].const_array();
544 const auto& bdatxhi_np1 = bdy_data_xhi[n_time_p1][ivarU].const_array();
546 const auto& bdatylo_n = bdy_data_ylo[n_time ][ivarV].const_array();
547 const auto& bdatylo_np1 = bdy_data_ylo[n_time_p1][ivarV].const_array();
548 const auto& bdatyhi_n = bdy_data_yhi[n_time ][ivarV].const_array();
549 const auto& bdatyhi_np1 = bdy_data_yhi[n_time_p1][ivarV].const_array();
552 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept
554 Real rho_tend = rhs_cons(i,j,k);
555 Real rho_val =
Real(0.5) * (cons_arr(i,j,k) + cons_arr(i-1,j,k));
561 u_tend = (bdatxlo_np1(i,j,k) - bdatxlo_n(i,j,k)) / bdy_time_interval;
562 u_val = oma * bdatxlo_n(i,j,k) +
alpha * bdatxlo_np1(i,j,k);
564 rhs_xmom(i,j,k) = rho_val * u_tend + u_val * rho_tend;
566 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept
568 Real rho_tend = rhs_cons(i,j,k);
569 Real rho_val =
Real(0.5) * (cons_arr(i,j,k) + cons_arr(i-1,j,k));
575 u_tend = (bdatxhi_np1(i,j,k) - bdatxhi_n(i,j,k)) / bdy_time_interval;
576 u_val = oma * bdatxhi_n(i,j,k) +
alpha * bdatxhi_np1(i,j,k);
578 rhs_xmom(i,j,k) = rho_val * u_tend + u_val * rho_tend;
582 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept
584 Real rho_tend = rhs_cons(i,j,k);
585 Real rho_val =
Real(0.5) * (cons_arr(i,j,k) + cons_arr(i,j-1,k));
591 v_tend = (bdatylo_np1(i,j,k) - bdatylo_n(i,j,k)) / bdy_time_interval;
592 v_val = oma * bdatylo_n(i,j,k) +
alpha * bdatylo_np1(i,j,k);
594 rhs_ymom(i,j,k) = rho_val * v_tend + v_val * rho_tend;
596 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) noexcept
598 Real rho_tend = rhs_cons(i,j,k);
599 Real rho_val =
Real(0.5) * (cons_arr(i,j,k) + cons_arr(i,j-1,k));
605 v_tend = (bdatyhi_np1(i,j,k) - bdatyhi_n(i,j,k)) / bdy_time_interval;
606 v_val = oma * bdatyhi_n(i,j,k) +
alpha * bdatyhi_np1(i,j,k);
608 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
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)
Definition: ERF_Utils.H:225
@ 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