60 const amrex::Box &a_box,
61 int ngrow,
int ,
int , amrex::Real time,
64 const amrex::Real* DX =
m_geom.CellSize();
68 amrex::Box box = a_box;
70 const amrex::Dim3 lo= amrex::lbound(
m_geom.Domain()), hi = amrex::ubound(
m_geom.Domain());
72 amrex::Array4<amrex::Real>
const& in = a_in.array();
74 for (
int n = 0; n < a_in.nComp(); n++)
76 amrex::ParallelFor (box,[=] AMREX_GPU_DEVICE(
int i,
int j,
int k)
78 amrex::IntVect glevel;
79 AMREX_D_TERM( glevel[0] = std::max(std::min(0,i-lo.x),i-hi.x); ,
80 glevel[1] = std::max(std::min(0,j-lo.y),j-hi.y); ,
81 glevel[2] = std::max(std::min(0,k-lo.z),k-hi.z); );
86 in(i,j,k,n) =
m_bc_val[Face::XLO][n](time);
88 in(i,j,k,n) = in(i-glevel[0],j,k,n) - (
m_bc_val[Face::XLO].size() > 0 ?
m_bc_val[Face::XLO][n](time)*DX[0] : 0);
90 in(i,j,k,n) = in(1-glevel[0],j,k,n);
92 in(i,j,k,n) = -in(1-glevel[0],j,k,n);
97 else if (glevel[0]>0 && (face == Orientation::xhi || face ==
Orientation::All))
100 in(i,j,k,n) =
m_bc_val[Face::XHI][n](time);
102 in(i,j,k,n) = in(i-glevel[0],j,k,n) - (
m_bc_val[Face::XHI].size() > 0 ?
m_bc_val[Face::XHI][n](time)*DX[0] : 0);
104 in(i,j,k,n) = in(hi.x-glevel[0],j,k,n);
106 in(i,j,k,n) = -in(hi.x-glevel[0],j,k,n);
112 else if (glevel[1]<0 && (face == Orientation::ylo || face ==
Orientation::All))
115 in(i,j,k,n) =
m_bc_val[Face::YLO][n](time);
117 in(i,j,k,n) = in(i,j-glevel[1],k,n) - (
m_bc_val[Face::YLO].size() > 0 ?
m_bc_val[Face::YLO][n](time)*DX[1] : 0);
119 in(i,j,k,n) = in(i,j-glevel[1],k,n);
121 in(i,j,k,n) = -in(i,j-glevel[1],k,n);
126 else if (glevel[1]>0 && (face == Orientation::yhi || face ==
Orientation::All))
129 in(i,j,k,n) =
m_bc_val[Face::YHI][n](time);
131 in(i,j,k,n) = in(i,j-glevel[1],k,n) - (
m_bc_val[Face::YHI].size() > 0 ?
m_bc_val[Face::YHI][n](time)*DX[1] : 0);
133 in(i,j,k,n) = in(i,hi.y-glevel[1],k,n);
135 in(i,j,k,n) = -in(i,hi.y-glevel[1],k,n);
142 else if (glevel[2]<0 && (face == Orientation::zlo || face ==
Orientation::All))
145 in(i,j,k,n) =
m_bc_val[Face::ZLO][n](time);
147 in(i,j,k,n) = in(i,j,k-glevel[2],n) - (
m_bc_val[Face::ZLO].size() > 0 ?
m_bc_val[Face::ZLO][n](time)*DX[2] : 0);
149 in(i,j,k,n) = in(i,j,1-glevel[2],n);
151 in(i,j,k,n) = -in(i,j,1-glevel[2],n);
155 else if (glevel[2]>0 && (face == Orientation::zhi || face ==
Orientation::All))
158 in(i,j,k,n) =
m_bc_val[Face::ZHI][n](time);
160 in(i,j,k,n) = in(i,j,k-glevel[2],n) - (
m_bc_val[Face::ZHI].size() > 0 ?
m_bc_val[Face::ZHI][n](time)*DX[2] : 0);
162 in(i,j,k,n) = in(i,j,hi.z-glevel[2],n);
164 in(i,j,k,n) = -in(i,j,hi.z-glevel[2],n);
176 amrex::ParallelFor (box,[=] AMREX_GPU_DEVICE(
int i,
int j,
int k)
178 if (i < lo.x && j < lo.y) in(i,j,k,n) = 0.5*( in(i+1,j,k,n) + in(i,j+1,k,n) );
179 if (i < lo.x && j > hi.y) in(i,j,k,n) = 0.5*( in(i+1,j,k,n) + in(i,j-1,k,n) );
180 if (i > hi.x && j < lo.y) in(i,j,k,n) = 0.5*( in(i-1,j,k,n) + in(i,j+1,k,n) );
181 if (i > hi.x && j > hi.y) in(i,j,k,n) = 0.5*( in(i-1,j,k,n) + in(i,j-1,k,n) );