From ddf15b965da63bbd160d62a7b16d5bef2467c584 Mon Sep 17 00:00:00 2001 From: "Jean M. Sexton" Date: Mon, 29 Apr 2024 20:02:24 -0700 Subject: [PATCH] 3d anisotropic eb (#3907) ## Summary ## Additional background Creating draft PR to run tests ## Checklist The proposed changes: - [ ] fix a bug or incorrect behavior in AMReX - [x] add new capabilities to AMReX - [ ] changes answers in the test suite to more than roundoff level - [ ] are likely to significantly affect the results of downstream AMReX users - [ ] include documentation in the code and/or rst files, if appropriate --- Src/EB/AMReX_EB2_3D_C.cpp | 35 ++++++++++++++++++++--------------- Src/EB/AMReX_EB2_C.H | 1 + Src/EB/AMReX_EB2_Level.H | 2 +- 3 files changed, 22 insertions(+), 16 deletions(-) diff --git a/Src/EB/AMReX_EB2_3D_C.cpp b/Src/EB/AMReX_EB2_3D_C.cpp index 4127919a56..c2de520e7a 100644 --- a/Src/EB/AMReX_EB2_3D_C.cpp +++ b/Src/EB/AMReX_EB2_3D_C.cpp @@ -32,18 +32,18 @@ void set_eb_data (const int i, const int j, const int k, Array4 const& fcx, Array4 const& fcy, Array4 const& fcz, Array4 const& m2x, Array4 const& m2y, Array4 const& m2z, + GpuArray const& dx, Array4 const& vfrac, Array4 const& vcent, Array4 const& barea, Array4 const& bcent, Array4 const& bnorm, Real small_volfrac, bool& is_small_cell, bool& is_multicut) noexcept { - Real axm = apx(i,j,k); - Real axp = apx(i+1,j,k); - Real aym = apy(i,j,k); - Real ayp = apy(i,j+1,k); - Real azm = apz(i,j,k); - Real azp = apz(i,j,k+1); - + const Real axm = apx(i,j,k); + const Real axp = apx(i+1,j,k); + const Real aym = apy(i,j,k); + const Real ayp = apy(i,j+1,k); + const Real azm = apz(i,j,k); + const Real azp = apz(i,j,k+1); // Check for small cell first if (((axm == 0.0_rt && axp == 0.0_rt) && (aym == 0.0_rt && ayp == 0.0_rt) && @@ -76,10 +76,10 @@ void set_eb_data (const int i, const int j, const int k, return; } - Real dapx = axm - axp; - Real dapy = aym - ayp; - Real dapz = azm - azp; - Real apnorm = std::sqrt(dapx*dapx+dapy*dapy+dapz*dapz); + Real dapx = (axm - axp)*(dx[1]*dx[2]); + Real dapy = (aym - ayp)*(dx[0]*dx[2]); + Real dapz = (azm - azp)*(dx[0]*dx[1]); + const Real apnorm = std::sqrt(dapx*dapx+dapy*dapy+dapz*dapz) + 1.e-30_rt*std::sqrt(dx[0]*dx[1]*dx[2]); if (apnorm == 0.0_rt) { bool maybe_multi_cuts = (axm == 0.0_rt && axp == 0.0_rt) || (aym == 0.0_rt && ayp == 0.0_rt) || @@ -96,10 +96,13 @@ void set_eb_data (const int i, const int j, const int k, Real nx = dapx * apnorminv; Real ny = dapy * apnorminv; Real nz = dapz * apnorminv; + const Real bareascaling = std::sqrt( (nx*dx[0])*(nx*dx[0]) + + (ny*dx[1])*(ny*dx[1]) + + (nz*dx[2])*(nz*dx[2]) ); bnorm(i,j,k,0) = nx; bnorm(i,j,k,1) = ny; bnorm(i,j,k,2) = nz; - barea(i,j,k) = nx*dapx + ny*dapy + nz*dapz; + barea(i,j,k) = (nx*dapx/(dx[1]*dx[2]) + ny*dapy/(dx[0]*dx[2]) + nz*dapz/(dx[0]*dx[1])); Real aax = 0.5_rt*(axm+axp); Real aay = 0.5_rt*(aym+ayp); @@ -121,7 +124,7 @@ void set_eb_data (const int i, const int j, const int k, return; } - Real bainv = 1.0_rt/barea(i,j,k); + Real bainv = bareascaling*bareascaling/apnorm; bcent(i,j,k,0) = bainv * (Bx + nx*vfrac(i,j,k)); bcent(i,j,k,1) = bainv * (By + ny*vfrac(i,j,k)); bcent(i,j,k,2) = bainv * (Bz + nz*vfrac(i,j,k)); @@ -310,6 +313,7 @@ void set_eb_cell (int i, int j, int k, Array4 const& fcx, Array4 const& fcy, Array4 const& fcz, Array4 const& m2x, Array4 const& m2y, Array4 const& m2z, + GpuArray const& dx, Array4 const& vfrac, Array4 const& vcent, Array4 const& barea, Array4 const& bcent, Array4 const& bnorm, Real small_volfrac, @@ -341,7 +345,7 @@ void set_eb_cell (int i, int j, int k, barea(i,j,k) = 0.0_rt; } else { set_eb_data(i, j , k, cell, apx, apy, apz, fcx, fcy, fcz, m2x, m2y, m2z, - vfrac, vcent, barea, bcent, bnorm, small_volfrac, + dx, vfrac, vcent, barea, bcent, bnorm, small_volfrac, is_small_cell, is_multicut); } } @@ -773,6 +777,7 @@ void build_cells (Box const& bx, Array4 const& cell, Array4 const& fcx, Array4 const& fcy, Array4 const& fcz, Array4 const& m2x, Array4 const& m2y, Array4 const& m2z, + GpuArray const& dx, Array4 const& vfrac, Array4 const& vcent, Array4 const& barea, Array4 const& bcent, Array4 const& bnorm, Array4 const& ctmp, @@ -790,7 +795,7 @@ void build_cells (Box const& bx, Array4 const& cell, bool is_small_cell = false; bool is_multicut = false; set_eb_cell(i, j, k, cell, apx, apy, apz, fcx, fcy, fcz, m2x, m2y, m2z, - vfrac, vcent, barea, bcent, bnorm, small_volfrac, + dx, vfrac, vcent, barea, bcent, bnorm, small_volfrac, is_small_cell, is_multicut); if (is_small_cell) { Gpu::Atomic::Add(dp, 1); diff --git a/Src/EB/AMReX_EB2_C.H b/Src/EB/AMReX_EB2_C.H index e176c87b29..49db3a270b 100644 --- a/Src/EB/AMReX_EB2_C.H +++ b/Src/EB/AMReX_EB2_C.H @@ -64,6 +64,7 @@ void build_cells (Box const& bx, Array4 const& cell, Array4 const& fcx, Array4 const& fcy, Array4 const& fcz, Array4 const& m2x, Array4 const& m2y, Array4 const& m2z, + GpuArray const& dx, Array4 const& vfrac, Array4 const& vcent, Array4 const& barea, Array4 const& bcent, Array4 const& bnorm, Array4 const& ctmp, diff --git a/Src/EB/AMReX_EB2_Level.H b/Src/EB/AMReX_EB2_Level.H index 9243318b99..7e30e51a6b 100644 --- a/Src/EB/AMReX_EB2_Level.H +++ b/Src/EB/AMReX_EB2_Level.H @@ -422,7 +422,7 @@ GShopLevel::define_fine (G const& gshop, const Geometry& geom, Array4 const& cfgtmp = cellflagtmp.array(); build_cells(vbx, cfg, ftx, fty, ftz, apx, apy, apz, - fcx, fcy, fcz, xm2, ym2, zm2, vfr, ctr, + fcx, fcy, fcz, xm2, ym2, zm2, dx, vfr, ctr, bar, bct, bnm, cfgtmp, lst, small_volfrac, geom, extend_domain_face, cover_multiple_cuts, nsm, nmc);