202 for (
int lev = 0; lev <= finest_level; ++lev)
205 psi_mf[lev]->FillBoundary();
206 amrex::Box domain = this->geom[lev].Domain();
207 domain.convert(amrex::IntVect::TheNodeVector());
210 for (MFIter mfi(*
model_mf[lev],
false); mfi.isValid(); ++mfi)
212 amrex::Box bx = mfi.nodaltilebox();
215 amrex::Array4<Set::Vector>
const& rhs =
rhs_mf[lev]->array(mfi);
216 amrex::Array4<const Set::Scalar>
const& psi =
psi_mf[lev]->array(mfi);
217 amrex::Array4<const Set::Scalar>
const& trac_normal =
trac_normal_mf[lev]->array(mfi);
219 amrex::ParallelFor(bx, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k) {
221 rhs(i,j,k) = trac_normal(i,j,k) * grad;
228 if (a_step > 0)
return;
230 for (
int lev = 0; lev <= finest_level; ++lev)
232 eta_mf[lev]->FillBoundary();
234 amrex::Box domain = this->geom[lev].Domain();
235 domain.convert(amrex::IntVect::TheNodeVector());
239 for (MFIter mfi(*
model_mf[lev],
false); mfi.isValid(); ++mfi)
241 amrex::Box bx = mfi.grownnodaltilebox();
244 amrex::Array4<MODEL>
const& model =
model_mf[lev]->array(mfi);
245 amrex::Array4<const Set::Scalar>
const& eta =
eta_mf[lev]->array(mfi);
247 amrex::ParallelFor(bx, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k) {
248 model(i, j, k) = MODEL::Zero();
249 for (
unsigned int n = 0; n <
models.size(); n++)
250 model(i, j, k) += eta(i, j, k, n) *
models[n];
258 for (MFIter mfi(*
model_mf[lev],
false); mfi.isValid(); ++mfi)
260 amrex::Box bx = mfi.grownnodaltilebox() & domain;
261 amrex::Array4<MODEL>
const& model = this->
model_mf[lev]->array(mfi);
262 const Dim3 lo = amrex::lbound(domain), hi = amrex::ubound(domain);
264 amrex::ParallelFor(bx, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k)
266 if (i==lo.x && j==lo.y)
267 model(i,j,k) = 0.5*(model(i+1,j,k)+model(i,j+1,k));
268 else if (i==lo.x && j==hi.y)
269 model(i,j,k) = 0.5*(model(i+1,j,k)+model(i,j-1,k));
270 else if (i==hi.x && j==lo.y)
271 model(i,j,k) = 0.5*(model(i-1,j,k)+model(i,j+1,k));
272 else if (i==hi.x && j==hi.y)
273 model(i,j,k) = 0.5*(model(i-1,j,k)+model(i,j-1,k));
276 model(i,j,k) = model(i+1,j,k);
278 model(i,j,k) = model(i-1,j,k);
280 model(i,j,k) = model(i,j+1,k);
282 model(i,j,k) = model(i,j-1,k);
298 for (amrex::MFIter mfi(*
eta_mf[lev], TilingIfNotGPU()); mfi.isValid(); ++mfi)
300 amrex::Box bx = mfi.nodaltilebox();
301 amrex::Array4<char>
const& tags = a_tags.array(mfi);
302 amrex::Array4<Set::Scalar>
const& eta =
eta_mf[lev]->array(mfi);
303 amrex::ParallelFor(bx, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k)
306 for (
int n = 0; n <
eta_mf[lev]->nComp(); n++)
310 tags(i, j, k) = amrex::TagBox::SET;
315 amrex::Array4<Set::Scalar>
const& psi =
psi_mf[lev]->array(mfi);
316 amrex::ParallelFor(bx, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k)
322 tags(i, j, k) = amrex::TagBox::SET;