58 AMREX_D_TERM(size(0) =
geom[0].ProbHi()[0] -
geom[0].ProbLo()[0];,
59 size(1) =
geom[0].ProbHi()[1] -
geom[0].ProbLo()[1];,
60 size(2) =
geom[0].ProbHi()[2] -
geom[0].ProbLo()[2];)
62 for (amrex::MFIter mfi(*a_field[lev],amrex::TilingIfNotGPU()); mfi.isValid(); ++mfi)
64 amrex::Box bx = mfi.tilebox();
65 bx.grow(a_field[lev]->nGrow());
66 int ncomp = a_field[lev]->nComp();
67 amrex::Array4<Set::Scalar>
const& field = a_field[lev]->array(mfi);
68 amrex::ParallelFor (bx,[=] AMREX_GPU_DEVICE(
int i,
int j,
int k) {
71 AMREX_D_TERM(x(0) =
geom[lev].ProbLo()[0] + ((amrex::Real)(i) + 0.5) *
geom[lev].CellSize()[0];,
72 x(1) =
geom[lev].ProbLo()[1] + ((amrex::Real)(j) + 0.5) *
geom[lev].CellSize()[1];,
73 x(2) =
geom[lev].ProbLo()[2] + ((amrex::Real)(k) + 0.5) *
geom[lev].CellSize()[2];);
75 amrex::Real min_distance = std::numeric_limits<amrex::Real>::infinity();
76 int min_grain_id = -1;
82 if (
geom[0].isPeriodic(0))
85 std::min( (x-
voronoi[n] + size(0)*Set::Vector::Unit(0)).lpNorm<2>(),
86 (x-
voronoi[n] - size(0)*Set::Vector::Unit(0)).lpNorm<2>()));
89 if (
geom[0].isPeriodic(1))
92 std::min( (x-
voronoi[n] + size(0)*Set::Vector::Unit(1)).lpNorm<2>(),
93 (x-
voronoi[n] - size(0)*Set::Vector::Unit(1)).lpNorm<2>()));
97 if (
geom[0].isPeriodic(2))
100 std::min( (x-
voronoi[n] + size(0)*Set::Vector::Unit(2)).lpNorm<2>(),
101 (x-
voronoi[n] - size(0)*Set::Vector::Unit(2)).lpNorm<2>()));