21 const auto& dom_lo = lbound(domain);
22 const auto& dom_hi = ubound(domain);
34 Vector<BCRec> bcrs(1);
37 Gpu::DeviceVector<BCRec> bcrs_d(1);
38 Gpu::copyAsync(Gpu::hostToDevice, bcrs.begin(), bcrs.end(), bcrs_d.begin());
39 const BCRec* bc_ptr = bcrs_d.data();
41 GpuArray<GpuArray<Real, AMREX_SPACEDIM*2>,1> l_bc_extdir_vals_d;
43 for (
int ori = 0; ori < 2*AMREX_SPACEDIM; ori++) {
47 GeometryData
const& geomdata =
m_geom.data();
48 bool is_periodic_in_x = geomdata.isPeriodic(0);
49 bool is_periodic_in_y = geomdata.isPeriodic(1);
52 if (!is_periodic_in_x)
55 Box bx_xlo(bx); bx_xlo.setBig (0,dom_lo.x-1);
56 Box bx_xhi(bx); bx_xhi.setSmall(0,dom_hi.x+2);
57 Box bx_xlo_face(bx); bx_xlo_face.setSmall(0,dom_lo.x ); bx_xlo_face.setBig(0,dom_lo.x );
58 Box bx_xhi_face(bx); bx_xhi_face.setSmall(0,dom_hi.x+1); bx_xhi_face.setBig(0,dom_hi.x+1);
59 ParallelFor(bx_xlo, bx_xlo_face,
60 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k)
62 int iflip = dom_lo.x - i;
64 dest_arr(i,j,k) = (xvel_bc_ptr) ? xvel_bc_ptr[k] : l_bc_extdir_vals_d[0][0];
66 dest_arr(i,j,k) = (xvel_bc_ptr) ? xvel_bc_ptr[k] : l_bc_extdir_vals_d[0][0];
68 dest_arr(i,j,k) = dest_arr(dom_lo.x,j,k);
70 dest_arr(i,j,k) = dest_arr(dom_lo.x,j,k);
72 dest_arr(i,j,k) = dest_arr(iflip,j,k);
74 dest_arr(i,j,k) = -dest_arr(iflip,j,k);
76 dest_arr(i,j,k) = (4.0*dest_arr(dom_lo.x+1,j,k) - dest_arr(dom_lo.x+2,j,k))/3.0;
78 Real delta_i = (dom_lo.x - i);
79 dest_arr(i,j,k) = (1.0 + delta_i)*dest_arr(dom_lo.x,j,k) - delta_i*dest_arr(dom_lo.x+1,j,k);
83 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k)
86 dest_arr(i,j,k) = (xvel_bc_ptr) ? xvel_bc_ptr[k] : l_bc_extdir_vals_d[0][0];
88 dest_arr(i,j,k) = (xvel_bc_ptr) ? xvel_bc_ptr[k] : l_bc_extdir_vals_d[0][0];
90 dest_arr(i,j,k) = (4.0*dest_arr(dom_lo.x+1,j,k) - dest_arr(dom_lo.x+2,j,k))/3.0;
94 ParallelFor(bx_xhi, bx_xhi_face,
95 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k)
97 int iflip = 2*(dom_hi.x + 1) - i;
99 dest_arr(i,j,k) = (xvel_bc_ptr) ? xvel_bc_ptr[k] : l_bc_extdir_vals_d[0][3];
101 dest_arr(i,j,k) = (xvel_bc_ptr) ? xvel_bc_ptr[k] : l_bc_extdir_vals_d[0][3];
103 dest_arr(i,j,k) = dest_arr(dom_hi.x+1,j,k);
105 dest_arr(i,j,k) = dest_arr(dom_hi.x+1,j,k);
107 dest_arr(i,j,k) = dest_arr(iflip,j,k);
109 dest_arr(i,j,k) = -dest_arr(iflip,j,k);
111 dest_arr(i,j,k) = (4.0*dest_arr(dom_hi.x,j,k) - dest_arr(dom_hi.x-1,j,k))/3.0;
113 Real delta_i = (i - dom_hi.x - 1);
114 dest_arr(i,j,k) = (1.0 + delta_i)*dest_arr(dom_hi.x+1,j,k) - delta_i*dest_arr(dom_hi.x,j,k);
118 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k)
121 dest_arr(i,j,k) = (xvel_bc_ptr) ? xvel_bc_ptr[k] : l_bc_extdir_vals_d[0][3];
123 dest_arr(i,j,k) = (xvel_bc_ptr) ? xvel_bc_ptr[k] : l_bc_extdir_vals_d[0][3];
125 dest_arr(i,j,k) = (4.0*dest_arr(dom_hi.x,j,k) - dest_arr(dom_hi.x-1,j,k))/3.0;
131 if (!is_periodic_in_y)
135 Box bx_ylo(bx); bx_ylo.setBig (1,dom_lo.y-1);
136 Box bx_yhi(bx); bx_yhi.setSmall(1,dom_hi.y+1);
137 ParallelFor(bx_ylo, bx_yhi,
138 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) {
139 int jflip = dom_lo.y - 1 - j;
141 dest_arr(i,j,k) = (xvel_bc_ptr) ? xvel_bc_ptr[k] : l_bc_extdir_vals_d[0][1];
143 dest_arr(i,j,k) = (xvel_bc_ptr) ? xvel_bc_ptr[k] : l_bc_extdir_vals_d[0][1];
145 dest_arr(i,j,k) = dest_arr(i,dom_lo.y,k);
147 dest_arr(i,j,k) = dest_arr(i,dom_lo.y,k);
149 dest_arr(i,j,k) = dest_arr(i,jflip,k);
151 dest_arr(i,j,k) = -dest_arr(i,jflip,k);
153 Real delta_j = (dom_lo.y - j);
154 dest_arr(i,j,k) = (1.0 + delta_j)*dest_arr(i,dom_lo.y,k) - delta_j*dest_arr(i,dom_lo.y+1,k);
157 [=] AMREX_GPU_DEVICE (
int i,
int j,
int k) {
158 int jflip = 2*dom_hi.y + 1 - j;
160 dest_arr(i,j,k) = (xvel_bc_ptr) ? xvel_bc_ptr[k] : l_bc_extdir_vals_d[0][4];
162 dest_arr(i,j,k) = (xvel_bc_ptr) ? xvel_bc_ptr[k] : l_bc_extdir_vals_d[0][4];
164 dest_arr(i,j,k) = dest_arr(i,dom_hi.y,k);
166 dest_arr(i,j,k) = dest_arr(i,dom_hi.y,k);
168 dest_arr(i,j,k) = dest_arr(i,jflip,k);
170 dest_arr(i,j,k) = -dest_arr(i,jflip,k);
172 Real delta_j = (j - dom_hi.y);
173 dest_arr(i,j,k) = (1.0 + delta_j)*dest_arr(i,dom_hi.y,k) - delta_j*dest_arr(i,dom_hi.y-1,k);
179 Gpu::streamSynchronize();
void impose_lateral_xvel_bcs(const amrex::Array4< amrex::Real > &dest_arr, const amrex::Array4< amrex::Real const > &xvel_arr, const amrex::Array4< amrex::Real const > &yvel_arr, const amrex::Box &bx, const amrex::Box &domain, int bccomp)
Definition: ERF_BoundaryConditionsXvel.cpp:15
@ open
Definition: ERF_IndexDefines.H:215
@ reflect_odd
Definition: ERF_IndexDefines.H:205
@ hoextrap
Definition: ERF_IndexDefines.H:216
@ foextrap
Definition: ERF_IndexDefines.H:208
@ ext_dir
Definition: ERF_IndexDefines.H:209
@ ext_dir_upwind
Definition: ERF_IndexDefines.H:217
@ neumann_int
Definition: ERF_IndexDefines.H:214
@ reflect_even
Definition: ERF_IndexDefines.H:207