205 for (
int lev = 0; lev <= finest_level; ++lev)
208 psi_mf[lev]->FillBoundary();
209 amrex::Box domain = this->geom[lev].Domain();
210 domain.convert(amrex::IntVect::TheNodeVector());
213 for (MFIter mfi(*
model_mf[lev],
false); mfi.isValid(); ++mfi)
215 amrex::Box bx = mfi.nodaltilebox();
218 amrex::Array4<Set::Vector>
const& rhs =
rhs_mf[lev]->array(mfi);
219 amrex::Array4<const Set::Scalar>
const& psi =
psi_mf[lev]->array(mfi);
220 amrex::Array4<const Set::Scalar>
const& trac_normal =
trac_normal_mf[lev]->array(mfi);
222 amrex::ParallelFor(bx, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k) {
224 rhs(i,j,k) = trac_normal(i,j,k) * grad;
231 if (a_step > 0)
return;
233 for (
int lev = 0; lev <= finest_level; ++lev)
235 eta_mf[lev]->FillBoundary();
237 amrex::Box domain = this->geom[lev].Domain();
238 domain.convert(amrex::IntVect::TheNodeVector());
242 for (MFIter mfi(*
model_mf[lev],
false); mfi.isValid(); ++mfi)
244 amrex::Box bx = mfi.grownnodaltilebox();
246 amrex::Array4<MODEL>
const& model =
model_mf[lev]->array(mfi);
247 amrex::Array4<const Set::Scalar>
const& eta =
eta_mf[lev]->array(mfi);
249 amrex::ParallelFor(bx, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k) {
250 model(i, j, k) = MODEL::Zero();
251 for (
unsigned int n = 0; n <
models.size(); n++)
252 model(i, j, k) += eta(i, j, k, n) *
models[n];
260 for (MFIter mfi(*
model_mf[lev],
false); mfi.isValid(); ++mfi)
262 amrex::Box bx = mfi.grownnodaltilebox() & domain;
263 amrex::Array4<MODEL>
const& model = this->
model_mf[lev]->array(mfi);
264 const Dim3 lo = amrex::lbound(domain), hi = amrex::ubound(domain);
266 amrex::ParallelFor(bx, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k)
268 if (i==lo.x && j==lo.y)
269 model(i,j,k) = 0.5*(model(i+1,j,k)+model(i,j+1,k));
270 else if (i==lo.x && j==hi.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==lo.y)
273 model(i,j,k) = 0.5*(model(i-1,j,k)+model(i,j+1,k));
274 else if (i==hi.x && j==hi.y)
275 model(i,j,k) = 0.5*(model(i-1,j,k)+model(i,j-1,k));
278 model(i,j,k) = model(i+1,j,k);
280 model(i,j,k) = model(i-1,j,k);
282 model(i,j,k) = model(i,j+1,k);
284 model(i,j,k) = model(i,j-1,k);
300 for (amrex::MFIter mfi(*
eta_mf[lev], TilingIfNotGPU()); mfi.isValid(); ++mfi)
302 amrex::Box bx = mfi.nodaltilebox();
303 amrex::Array4<char>
const& tags = a_tags.array(mfi);
304 amrex::Array4<Set::Scalar>
const& eta =
eta_mf[lev]->array(mfi);
305 amrex::ParallelFor(bx, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k)
308 for (
int n = 0; n <
eta_mf[lev]->nComp(); n++)
312 tags(i, j, k) = amrex::TagBox::SET;
317 amrex::Array4<Set::Scalar>
const& psi =
psi_mf[lev]->array(mfi);
318 amrex::ParallelFor(bx, [=] AMREX_GPU_DEVICE(
int i,
int j,
int k)
324 tags(i, j, k) = amrex::TagBox::SET;