diff --git a/Docs/source/reactions.rst b/Docs/source/reactions.rst index 21d6c64091..cbef46f81d 100644 --- a/Docs/source/reactions.rst +++ b/Docs/source/reactions.rst @@ -57,8 +57,32 @@ in the inputs file. Reactions are enabled by setting:: the efficiency). It is possible to set the maximum and minimum temperature and density for allowing -reactions to occur in a zone using the parameters ``castro.react_T_min``, -``castro.react_T_max``, ``castro.react_rho_min`` and ``castro.react_rho_max``. +reactions to occur in a zone using the parameters: + +* ``castro.react_T_min`` and ``castro.react_T_max`` for temperature + +* ``castro.react_rho_min`` and ``castro.react_rho_max`` for density + +.. index:: castro.disable_shock_burning, USE_SHOCK_VAR + +Burning can also be disabled inside shocks. This requires that the code be +compiled with:: + + USE_SHOCK_VAR = TRUE + +in the ``GNUmakefile``. This will allocate storage for a shock flag in the conserved +state array. This flag is computed via a multidimensional shock detection algorithm +that looks for compression (:math:`\nabla \cdot \ub < 0`) along with a pressure jump +in the direction of compression. The runtime parameter:: + + castro.disable_shock_burning = 1 + +will skip reactions in a zone where we've detected a shock. + +.. note:: + + Both the compilation with ``USE_SHOCK_VAR = TRUE`` and the runtime parameter + ``castro.disable_shock_burning = 1`` are needed to turn off burning in shocks. Reactions Flowchart =================== diff --git a/Source/radiation/CastroRad_1d.f90 b/Source/radiation/CastroRad_1d.f90 deleted file mode 100644 index 94732d9c25..0000000000 --- a/Source/radiation/CastroRad_1d.f90 +++ /dev/null @@ -1,18 +0,0 @@ -! no tiling -subroutine ca_correct_dterm(dfx, dfx_l1, dfx_h1, & - re, rc) bind(C, name="ca_correct_dterm") - - use amrex_fort_module, only : rt => amrex_real - implicit none - - integer, intent(in) :: dfx_l1, dfx_h1 - real(rt) , intent(inout) :: dfx(dfx_l1:dfx_h1) - real(rt) , intent(in) :: re(dfx_l1:dfx_h1), rc(1) - - integer :: i - - do i=dfx_l1, dfx_h1 - dfx(i) = dfx(i) / (re(i) + 1.e-50_rt) - end do - -end subroutine ca_correct_dterm diff --git a/Source/radiation/CastroRad_2d.f90 b/Source/radiation/CastroRad_2d.f90 deleted file mode 100644 index 892aadac3b..0000000000 --- a/Source/radiation/CastroRad_2d.f90 +++ /dev/null @@ -1,30 +0,0 @@ -! no tiling -subroutine ca_correct_dterm( & - dfx, dfx_l1, dfx_l2, dfx_h1, dfx_h2, & - dfy, dfy_l1, dfy_l2, dfy_h1, dfy_h2, & - re, rc) bind(C, name="ca_correct_dterm") - - use amrex_fort_module, only : rt => amrex_real - implicit none - - integer, intent(in) :: dfx_l1, dfx_l2, dfx_h1, dfx_h2 - integer, intent(in) :: dfy_l1, dfy_l2, dfy_h1, dfy_h2 - real(rt) , intent(inout) :: dfx(dfx_l1:dfx_h1,dfx_l2:dfx_h2) - real(rt) , intent(inout) :: dfy(dfy_l1:dfy_h1,dfy_l2:dfy_h2) - real(rt) , intent(in) :: re(dfx_l1:dfx_h1), rc(dfy_l1:dfy_h1) - - integer :: i, j - - do j=dfx_l2, dfx_h2 - do i=dfx_l1, dfx_h1 - dfx(i,j) = dfx(i,j) / (re(i) + 1.e-50_rt) - end do - end do - - do j=dfy_l2, dfy_h2 - do i=dfy_l1, dfy_h1 - dfy(i,j) = dfy(i,j) / rc(i) - end do - end do - -end subroutine ca_correct_dterm diff --git a/Source/radiation/CastroRad_3d.f90 b/Source/radiation/CastroRad_3d.f90 deleted file mode 100644 index c21d2945ac..0000000000 --- a/Source/radiation/CastroRad_3d.f90 +++ /dev/null @@ -1,18 +0,0 @@ -subroutine ca_correct_dterm( & - dfx, dfx_l1, dfx_l2, dfx_l3, dfx_h1, dfx_h2, dfx_h3, & - dfy, dfy_l1, dfy_l2, dfy_l3, dfy_h1, dfy_h2, dfy_h3, & - dfz, dfz_l1, dfz_l2, dfz_l3, dfz_h1, dfz_h2, dfz_h3, & - re, rc) bind(C, name="ca_correct_dterm") - - use amrex_fort_module, only : rt => amrex_real - implicit none - - integer, intent(in) :: dfx_l1, dfx_l2, dfx_l3, dfx_h1, dfx_h2, dfx_h3 - integer, intent(in) :: dfy_l1, dfy_l2, dfy_l3, dfy_h1, dfy_h2, dfy_h3 - integer, intent(in) :: dfz_l1, dfz_l2, dfz_l3, dfz_h1, dfz_h2, dfz_h3 - real(rt) , intent(inout) :: dfx(dfx_l1:dfx_h1,dfx_l2:dfx_h2,dfx_l3:dfx_h3) - real(rt) , intent(inout) :: dfy(dfy_l1:dfy_h1,dfy_l2:dfy_h2,dfy_l3:dfy_h3) - real(rt) , intent(inout) :: dfz(dfz_l1:dfz_h1,dfz_l2:dfz_h2,dfz_l3:dfz_h3) - real(rt) , intent(in) :: re(1), rc(1) - -end subroutine ca_correct_dterm diff --git a/Source/radiation/HABEC.H b/Source/radiation/HABEC.H index 2c9df6b2e3..3039e759d3 100644 --- a/Source/radiation/HABEC.H +++ b/Source/radiation/HABEC.H @@ -367,6 +367,222 @@ namespace HABEC } }); } + + AMREX_INLINE + void hdterm (Array4 const dterm, + Array4 const er, + const Box& reg, + int cdir, int bct, Real bcl, + Array4 const bcval, + Array4 const mask, + Array4 const d, + const Real* dx) + { + Real h; + + // Index shift for whichever edge we're checking. + // Negative means we're looking at the lo edge, + // positive means we're looking at the hi edge. + // The first group is for cell centers, the second + // group is for cell edges. + + int icp = 0; + int jcp = 0; + int kcp = 0; + + int iep = 0; + int jep = 0; + int kep = 0; + +#if AMREX_SPACEDIM == 1 + if (cdir == 0) { + h = dx[0]; + icp = -1; + } + else if (cdir == 1) { + h = dx[0]; + icp = 1; + iep = 1; + } +#elif AMREX_SPACEDIM == 2 + if (cdir == 0) { + h = dx[0]; + icp = -1; + } + else if (cdir == 2) { + h = dx[0]; + icp = 1; + iep = 1; + } + else if (cdir == 1) { + h = dx[1]; + jcp = -1; + } + else if (cdir == 3) { + h = dx[1]; + jcp = 1; + jep = 1; + } +#else + if (cdir == 0) { + h = dx[0]; + icp = -1; + } + else if (cdir == 3) { + h = dx[0]; + icp = 1; + iep = 1; + } + else if (cdir == 1) { + h = dx[1]; + jcp = -1; + } + else if (cdir == 4) { + h = dx[1]; + jcp = 1; + jep = 1; + } + else if (cdir == 2) { + h = dx[2]; + kcp = -1; + } + else if (cdir == 5) { + h = dx[2]; + kcp = 1; + kep = 1; + } +#endif + + amrex::LoopOnCpu(reg, [=] (int i, int j, int k) noexcept + { + if (mask.contains(i+icp,j+jcp,k+kcp)) { + if (mask(i+icp,j+jcp,k+kcp) > 0) { + if (bct == LO_DIRICHLET) { + Real d_sign = 1.0_rt; + if (iep != 0 || jep != 0 || kep != 0) { + // right edge + d_sign = -1.0_rt; + } + dterm(i+iep,j+jep,k+kep) = d(i+iep,j+jep,k+kep) * d_sign * (er(i,j,k) - bcval(i+icp,j+jcp,k+kcp)) / (0.5_rt * h + bcl); + } + } + } + }); + } + + AMREX_INLINE + void hdterm3 (Array4 const dterm, + Array4 const er, + const Box& reg, + int cdir, int bctype, + Array4 const tf, + Real bcl, + Array4 const bcval, + Array4 const mask, + Array4 const d, + const Real* const dx) + { + Real h; + + // Index shift for whichever edge we're checking. + // Negative means we're looking at the lo edge, + // positive means we're looking at the hi edge. + // The first group is for cell centers, the second + // group is for cell edges. + + int icp = 0; + int jcp = 0; + int kcp = 0; + + int iep = 0; + int jep = 0; + int kep = 0; + +#if AMREX_SPACEDIM == 1 + if (cdir == 0) { + h = dx[0]; + icp = -1; + } + else if (cdir == 1) { + h = dx[0]; + icp = 1; + iep = 1; + } +#elif AMREX_SPACEDIM == 2 + if (cdir == 0) { + h = dx[0]; + icp = -1; + } + else if (cdir == 2) { + h = dx[0]; + icp = 1; + iep = 1; + } + else if (cdir == 1) { + h = dx[1]; + jcp = -1; + } + else if (cdir == 3) { + h = dx[1]; + jcp = 1; + jep = 1; + } +#else + if (cdir == 0) { + h = dx[0]; + icp = -1; + } + else if (cdir == 3) { + h = dx[0]; + icp = 1; + iep = 1; + } + else if (cdir == 1) { + h = dx[1]; + jcp = -1; + } + else if (cdir == 4) { + h = dx[1]; + jcp = 1; + jep = 1; + } + else if (cdir == 2) { + h = dx[2]; + kcp = -1; + } + else if (cdir == 5) { + h = dx[2]; + kcp = 1; + kep = 1; + } +#endif + + amrex::LoopOnCpu(reg, [=] (int i, int j, int k) noexcept + { + if (mask.contains(i+icp,j+jcp,k+kcp)) { + if (mask(i+icp,j+jcp,k+kcp) > 0) { + int bct; + if (bctype == -1) { + bct = tf(i+icp,j+jcp,k+kcp); + } + else { + bct = bctype; + } + if (bct == LO_DIRICHLET) { + Real d_sign = 1.0_rt; + if (iep != 0 || jep != 0 || kep != 0) { + // right edge + d_sign = -1.0_rt; + } + dterm(i+iep,j+jep,k+kep) = d(i+iep,j+jep,k+kep) * d_sign * (er(i,j,k) - bcval(i+icp,j+jcp,k+kcp)) / (0.5_rt * h + bcl); + } + else if (bct == LO_NEUMANN && bcval(i+icp,j+jcp,k+kcp) == 0.0_rt) { + dterm(i+iep,j+jep,k+kep) = 0.0_rt; + } + } + } + }); + } } // namespace HABEC #endif diff --git a/Source/radiation/HABEC_1D.F90 b/Source/radiation/HABEC_1D.F90 deleted file mode 100644 index 544297195e..0000000000 --- a/Source/radiation/HABEC_1D.F90 +++ /dev/null @@ -1,133 +0,0 @@ -#include -#include - -module habec_module - - ! habec is Hypre abec, where abec is the form of the linear equation - ! we are solving: - ! - ! alpha*phi - div(beta*grad phi) + div(\vec{c}*phi) - - use amrex_fort_module, only : rt => amrex_real - implicit none - -contains - -subroutine hdterm(dterm, & - DIMS(dtbox), & - er, DIMS(ebox), & - DIMS(reg), & - cdir, bct, bcl, & - bcval, DIMS(bcv), & - mask, DIMS(msk), & - d, DIMS(dbox), & - dx) bind(C, name="hdterm") - - use amrex_fort_module, only : rt => amrex_real - integer :: DIMDEC(dtbox) - integer :: DIMDEC(ebox) - integer :: DIMDEC(reg) - integer :: DIMDEC(bcv) - integer :: DIMDEC(msk) - integer :: DIMDEC(dbox) - integer :: cdir, bct - real(rt) :: bcl, dx(1) - real(rt) :: dterm(DIMV(dtbox)) - real(rt) :: er(DIMV(ebox)) - real(rt) :: bcval(DIMV(bcv)) - integer :: mask(DIMV(msk)) - real(rt) :: d(DIMV(dbox)) - real(rt) :: h - integer :: i - h = dx(1) - if (bct == LO_DIRICHLET) then - if (cdir == 0) then - ! Left face of grid - i = reg_l1 - if (mask(i-1) > 0) then - dterm(i) = d(i)*(er(i) - bcval(i-1))/(0.5e0_rt*h+bcl) - endif - else if (cdir == 1) then - ! Right face of grid - i = reg_h1 - if (mask(i+1) > 0) then - dterm(i+1) = d(i+1)*(bcval(i+1)-er(i))/(0.5e0_rt*h+bcl) - endif - else - print *, "hdterm: impossible face orientation" - endif - else - print *, "hdterm: unsupported boundary type" - stop - endif -end subroutine hdterm - -subroutine hdterm3(dterm, & - DIMS(dtbox), & - er, DIMS(ebox), & - DIMS(reg), & - cdir, bctype, tf, bcl, & - bcval, DIMS(bcv), & - mask, DIMS(msk), & - d, DIMS(dbox), & - dx) bind(C, name="hdterm3") - - use amrex_fort_module, only : rt => amrex_real - integer :: DIMDEC(dtbox) - integer :: DIMDEC(ebox) - integer :: DIMDEC(reg) - integer :: DIMDEC(bcv) - integer :: DIMDEC(msk) - integer :: DIMDEC(dbox) - integer :: cdir, bctype, tf(DIMV(bcv)) - real(rt) :: bcl, dx(1) - real(rt) :: dterm(DIMV(dtbox)) - real(rt) :: er(DIMV(ebox)) - real(rt) :: bcval(DIMV(bcv)) - integer :: mask(DIMV(msk)) - real(rt) :: d(DIMV(dbox)) - real(rt) :: h - integer :: i, bct - h = dx(1) - if (cdir == 0) then - ! Left face of grid - i = reg_l1 - if (mask(i-1) > 0) then - if (bctype == -1) then - bct = tf(i-1) - else - bct = bctype - endif - if (bct == LO_DIRICHLET) then - dterm(i) = d(i)*(er(i) - bcval(i-1))/(0.5e0_rt*h+bcl) - else if (bct == LO_NEUMANN .AND. bcval(i-1) == 0.e0_rt) then - dterm(i) = 0.e0_rt - else - print *, "hdterm3: unsupported boundary type" - stop - endif - endif - else if (cdir == 1) then - ! Right face of grid - i = reg_h1 - if (mask(i+1) > 0) then - if (bctype == -1) then - bct = tf(i+1) - else - bct = bctype - endif - if (bct == LO_DIRICHLET) then - dterm(i+1) = d(i+1)*(bcval(i+1)-er(i))/(0.5e0_rt*h+bcl) - else if (bct == LO_NEUMANN .AND. bcval(i+1) == 0.e0_rt) then - dterm(i+1) = 0.e0_rt - else - print *, "hbterm3: unsupported boundary type" - stop - endif - endif - else - print *, "hdterm3: impossible face orientation" - endif -end subroutine hdterm3 - -end module habec_module diff --git a/Source/radiation/HABEC_2D.F90 b/Source/radiation/HABEC_2D.F90 deleted file mode 100644 index 837e29d219..0000000000 --- a/Source/radiation/HABEC_2D.F90 +++ /dev/null @@ -1,206 +0,0 @@ -#include -#include - - -module habec_module - - ! habec is Hypre abec, where abec is the form of the linear equation - ! we are solving: - ! - ! alpha*phi - div(beta*grad phi) + div(\vec{c}*phi) - - use amrex_fort_module, only : rt => amrex_real - implicit none - -contains - -subroutine hdterm(dterm, & - DIMS(dtbox), & - er, DIMS(ebox), & - DIMS(reg), & - cdir, bct, bcl, & - bcval, DIMS(bcv), & - mask, DIMS(msk), & - d, DIMS(dbox), & - dx) bind(C, name="hdterm") - - use amrex_fort_module, only : rt => amrex_real - integer :: DIMDEC(dtbox) - integer :: DIMDEC(ebox) - integer :: DIMDEC(reg) - integer :: DIMDEC(bcv) - integer :: DIMDEC(msk) - integer :: DIMDEC(dbox) - integer :: cdir, bct - real(rt) :: bcl, dx(2) - real(rt) :: dterm(DIMV(dtbox)) - real(rt) :: er(DIMV(ebox)) - real(rt) :: bcval(DIMV(bcv)) - integer :: mask(DIMV(msk)) - real(rt) :: d(DIMV(dbox)) - real(rt) :: h - integer :: i, j - if (cdir == 0 .OR. cdir == 2) then - h = dx(1) - else - h = dx(2) - endif - if (bct == LO_DIRICHLET) then - if (cdir == 0) then - ! Left face of grid - i = reg_l1 - do j = reg_l2, reg_h2 - if (mask(i-1,j) > 0) then - dterm(i,j) = d(i,j)*(er(i,j)-bcval(i-1,j))/(0.5e0_rt*h+bcl) - endif - enddo - else if (cdir == 2) then - ! Right face of grid - i = reg_h1 - do j = reg_l2, reg_h2 - if (mask(i+1,j) > 0) then - dterm(i+1,j) = d(i+1,j)*(bcval(i+1,j)-er(i,j))/(0.5e0_rt*h+bcl) - endif - enddo - else if (cdir == 1) then - ! Bottom face of grid - j = reg_l2 - do i = reg_l1, reg_h1 - if (mask(i,j-1) > 0) then - dterm(i,j) = d(i,j)*(er(i,j)-bcval(i,j-1))/(0.5e0_rt*h+bcl) - endif - enddo - else if (cdir == 3) then - ! Top face of grid - j = reg_h2 - do i = reg_l1, reg_h1 - if (mask(i,j+1) > 0) then - dterm(i,j+1) = d(i,j+1)*(bcval(i,j+1)-er(i,j))/(0.5e0_rt*h+bcl) - endif - enddo - else - print *, "hdterm: impossible face orientation" - endif - else - print *, "hdterm: unsupported boundary type" - stop - endif -end subroutine hdterm - -subroutine hdterm3(dterm, & - DIMS(dtbox), & - er, DIMS(ebox), & - DIMS(reg), & - cdir, bctype, tf, bcl, & - bcval, DIMS(bcv), & - mask, DIMS(msk), & - d, DIMS(dbox), & - dx) bind(C, name="hdterm3") - - use amrex_fort_module, only : rt => amrex_real - integer :: DIMDEC(dtbox) - integer :: DIMDEC(ebox) - integer :: DIMDEC(reg) - integer :: DIMDEC(bcv) - integer :: DIMDEC(msk) - integer :: DIMDEC(dbox) - integer :: cdir, bctype, tf(DIMV(bcv)) - real(rt) :: bcl, dx(2) - real(rt) :: dterm(DIMV(dtbox)) - real(rt) :: er(DIMV(ebox)) - real(rt) :: bcval(DIMV(bcv)) - integer :: mask(DIMV(msk)) - real(rt) :: d(DIMV(dbox)) - real(rt) :: h - integer :: i, j, bct - if (cdir == 0 .OR. cdir == 2) then - h = dx(1) - else - h = dx(2) - endif - if (cdir == 0) then - ! Left face of grid - i = reg_l1 - do j = reg_l2, reg_h2 - if (mask(i-1,j) > 0) then - if (bctype == -1) then - bct = tf(i-1,j) - else - bct = bctype - endif - if (bct == LO_DIRICHLET) then - dterm(i,j) = d(i,j)*(er(i,j)-bcval(i-1,j))/(0.5e0_rt*h+bcl) - else if (bct == LO_NEUMANN .AND. bcval(i-1,j) == 0.e0_rt) then - dterm(i,j) = 0.e0_rt - else - print *, "hdterm3: unsupported boundary type" - stop - endif - endif - enddo - else if (cdir == 2) then - ! Right face of grid - i = reg_h1 - do j = reg_l2, reg_h2 - if (mask(i+1,j) > 0) then - if (bctype == -1) then - bct = tf(i+1,j) - else - bct = bctype - endif - if (bct == LO_DIRICHLET) then - dterm(i+1,j) = d(i+1,j)*(bcval(i+1,j)-er(i,j))/(0.5e0_rt*h+bcl) - else if (bct == LO_NEUMANN .AND. bcval(i+1,j) == 0.e0_rt) then - dterm(i+1,j) = 0.e0_rt - else - print *, "hdterm3: unsupported boundary type" - stop - endif - endif - enddo - else if (cdir == 1) then - ! Bottom face of grid - j = reg_l2 - do i = reg_l1, reg_h1 - if (mask(i,j-1) > 0) then - if (bctype == -1) then - bct = tf(i,j-1) - else - bct = bctype - endif - if (bct == LO_DIRICHLET) then - dterm(i,j) = d(i,j)*(er(i,j)-bcval(i,j-1))/(0.5e0_rt*h+bcl) - else if (bct == LO_NEUMANN .AND. bcval(i,j-1) == 0.e0_rt) then - dterm(i,j) = 0.e0_rt - else - print *, "hdterm3: unsupported boundary type" - stop - endif - endif - enddo - else if (cdir == 3) then - ! Top face of grid - j = reg_h2 - do i = reg_l1, reg_h1 - if (mask(i,j+1) > 0) then - if (bctype == -1) then - bct = tf(i,j+1) - else - bct = bctype - endif - if (bct == LO_DIRICHLET) then - dterm(i,j+1) = d(i,j+1)*(bcval(i,j+1)-er(i,j))/(0.5e0_rt*h+bcl) - else if (bct == LO_NEUMANN .AND. bcval(i,j+1) == 0.e0_rt) then - dterm(i,j+1) = 0.e0_rt - else - print *, "hdterm3: unsupported boundary type" - stop - endif - endif - enddo - else - print *, "hdterm3: impossible face orientation" - endif -end subroutine hdterm3 - -end module habec_module diff --git a/Source/radiation/HABEC_3D.F90 b/Source/radiation/HABEC_3D.F90 deleted file mode 100644 index d59edec61a..0000000000 --- a/Source/radiation/HABEC_3D.F90 +++ /dev/null @@ -1,308 +0,0 @@ -#include -#include - - -module habec_module - - ! habec is Hypre abec, where abec is the form of the linear equation - ! we are solving: - ! - ! alpha*phi - div(beta*grad phi) + div(\vec{c}*phi) - - use amrex_fort_module, only : rt => amrex_real - implicit none - -contains - -subroutine hdterm(dterm, & - DIMS(dtbox), & - er, DIMS(ebox), & - DIMS(reg), & - cdir, bct, bcl, & - bcval, DIMS(bcv), & - mask, DIMS(msk), & - d, DIMS(dbox), & - dx) bind(C, name="hdterm") - - use amrex_fort_module, only : rt => amrex_real - integer :: DIMDEC(dtbox) - integer :: DIMDEC(ebox) - integer :: DIMDEC(reg) - integer :: DIMDEC(bcv) - integer :: DIMDEC(msk) - integer :: DIMDEC(dbox) - integer :: cdir, bct - real(rt) :: bcl, dx(3) - real(rt) :: dterm(DIMV(dtbox)) - real(rt) :: er(DIMV(ebox)) - real(rt) :: bcval(DIMV(bcv)) - integer :: mask(DIMV(msk)) - real(rt) :: d(DIMV(dbox)) - real(rt) :: h, bfm, bfv - integer :: i, j, k - if (cdir == 0 .OR. cdir == 3) then - h = dx(1) - elseif (cdir == 1 .OR. cdir == 4) then - h = dx(2) - else - h = dx(3) - endif - if (bct == LO_DIRICHLET) then - if (cdir == 0) then - i = reg_l1 - do k = reg_l3, reg_h3 - do j = reg_l2, reg_h2 - if (mask(i-1,j,k) > 0) then - dterm(i,j,k) = d(i,j,k) * & - (er(i,j,k) - bcval(i-1,j,k)) & - / (0.5e0_rt*h + bcl) - endif - enddo - enddo - else if (cdir == 3) then - i = reg_h1 - do k = reg_l3, reg_h3 - do j = reg_l2, reg_h2 - if (mask(i+1,j,k) > 0) then - dterm(i+1,j,k) = d(i+1,j,k) * & - (bcval(i+1,j,k) - er(i,j,k)) & - / (0.5e0_rt*h + bcl) - endif - enddo - enddo - else if (cdir == 1) then - j = reg_l2 - do k = reg_l3, reg_h3 - do i = reg_l1, reg_h1 - if (mask(i,j-1,k) > 0) then - dterm(i,j,k) = d(i,j,k) * & - (er(i,j,k) - bcval(i,j-1,k)) & - / (0.5e0_rt*h + bcl) - endif - enddo - enddo - else if (cdir == 4) then - j = reg_h2 - do k = reg_l3, reg_h3 - do i = reg_l1, reg_h1 - if (mask(i,j+1,k) > 0) then - dterm(i,j+1,k) = d(i,j+1,k) * & - (bcval(i,j+1,k) - er(i,j,k)) & - / (0.5e0_rt*h + bcl) - endif - enddo - enddo - else if (cdir == 2) then - k = reg_l3 - do j = reg_l2, reg_h2 - do i = reg_l1, reg_h1 - if (mask(i,j,k-1) > 0) then - dterm(i,j,k) = d(i,j,k) * & - (er(i,j,k) - bcval(i,j,k-1)) & - / (0.5e0_rt*h + bcl) - endif - enddo - enddo - else if (cdir == 5) then - k = reg_h3 - do j = reg_l2, reg_h2 - do i = reg_l1, reg_h1 - if (mask(i,j,k+1) > 0) then - dterm(i,j,k+1) = d(i,j,k+1) * & - (bcval(i,j,k+1) - er(i,j,k)) & - / (0.5e0_rt*h + bcl) - endif - enddo - enddo - else - print *, "hdterm: impossible face orientation" - endif - else - print *, "hdterm: unsupported boundary type" - stop - endif -end subroutine hdterm - -subroutine hdterm3(dterm, & - DIMS(dtbox), & - er, DIMS(ebox), & - DIMS(reg), & - cdir, bctype, tf, bcl, & - bcval, DIMS(bcv), & - mask, DIMS(msk), & - d, DIMS(dbox), & - dx) bind(C, name="hdterm3") - - use amrex_fort_module, only : rt => amrex_real - integer :: DIMDEC(dtbox) - integer :: DIMDEC(ebox) - integer :: DIMDEC(reg) - integer :: DIMDEC(bcv) - integer :: DIMDEC(msk) - integer :: DIMDEC(dbox) - integer :: cdir, bctype, tf(DIMV(bcv)) - real(rt) :: bcl, dx(3) - real(rt) :: dterm(DIMV(dtbox)) - real(rt) :: er(DIMV(ebox)) - real(rt) :: bcval(DIMV(bcv)) - integer :: mask(DIMV(msk)) - real(rt) :: d(DIMV(dbox)) - real(rt) :: h, bfm, bfv - integer :: i, j, k, bct - if (cdir == 0 .OR. cdir == 3) then - h = dx(1) - elseif (cdir == 1 .OR. cdir == 4) then - h = dx(2) - else - h = dx(3) - endif - if (cdir == 0) then - i = reg_l1 - do k = reg_l3, reg_h3 - do j = reg_l2, reg_h2 - if (mask(i-1,j,k) > 0) then - if (bctype == -1) then - bct = tf(i-1,j,k) - else - bct = bctype - endif - if (bct == LO_DIRICHLET) then - dterm(i,j,k) = d(i,j,k) * & - (er(i,j,k) - bcval(i-1,j,k)) & - / (0.5e0_rt*h + bcl) - else if (bct == LO_NEUMANN & - .AND. bcval(i-1,j,k) == 0.e0_rt) then - dterm(i,j,k) = 0.e0_rt - else - print *, "hdterm3: unsupported boundary type" - stop - endif - endif - enddo - enddo - else if (cdir == 3) then - i = reg_h1 - do k = reg_l3, reg_h3 - do j = reg_l2, reg_h2 - if (mask(i+1,j,k) > 0) then - if (bctype == -1) then - bct = tf(i+1,j,k) - else - bct = bctype - endif - if (bct == LO_DIRICHLET) then - dterm(i+1,j,k) = d(i+1,j,k) * & - (bcval(i+1,j,k) - er(i,j,k)) & - / (0.5e0_rt*h + bcl) - else if (bct == LO_NEUMANN & - .AND. bcval(i+1,j,k) == 0.e0_rt) then - dterm(i+1,j,k) = 0.e0_rt - else - print *, "hdterm3: unsupported boundary type" - stop - endif - endif - enddo - enddo - else if (cdir == 1) then - j = reg_l2 - do k = reg_l3, reg_h3 - do i = reg_l1, reg_h1 - if (mask(i,j-1,k) > 0) then - if (bctype == -1) then - bct = tf(i,j-1,k) - else - bct = bctype - endif - if (bct == LO_DIRICHLET) then - dterm(i,j,k) = d(i,j,k) * & - (er(i,j,k) - bcval(i,j-1,k)) & - / (0.5e0_rt*h + bcl) - else if (bct == LO_NEUMANN & - .AND. bcval(i,j-1,k) == 0.e0_rt) then - dterm(i,j,k) = 0.e0_rt - else - print *, "hdterm3: unsupported boundary type" - stop - endif - endif - enddo - enddo - else if (cdir == 4) then - j = reg_h2 - do k = reg_l3, reg_h3 - do i = reg_l1, reg_h1 - if (mask(i,j+1,k) > 0) then - if (bctype == -1) then - bct = tf(i,j+1,k) - else - bct = bctype - endif - if (bct == LO_DIRICHLET) then - dterm(i,j+1,k) = d(i,j+1,k) * & - (bcval(i,j+1,k) - er(i,j,k)) & - / (0.5e0_rt*h + bcl) - else if (bct == LO_NEUMANN & - .AND. bcval(i,j+1,k) == 0.e0_rt) then - dterm(i,j+1,k) = 0.e0_rt - else - print *, "hdterm3: unsupported boundary type" - stop - endif - endif - enddo - enddo - else if (cdir == 2) then - k = reg_l3 - do j = reg_l2, reg_h2 - do i = reg_l1, reg_h1 - if (mask(i,j,k-1) > 0) then - if (bctype == -1) then - bct = tf(i,j,k-1) - else - bct = bctype - endif - if (bct == LO_DIRICHLET) then - dterm(i,j,k) = d(i,j,k) * & - (er(i,j,k) - bcval(i,j,k-1)) & - / (0.5e0_rt*h + bcl) - else if (bct == LO_NEUMANN & - .AND. bcval(i,j,k-1) == 0.e0_rt) then - dterm(i,j,k) = 0.e0_rt - else - print *, "hdterm3: unsupported boundary type" - stop - endif - endif - enddo - enddo - else if (cdir == 5) then - k = reg_h3 - do j = reg_l2, reg_h2 - do i = reg_l1, reg_h1 - if (mask(i,j,k+1) > 0) then - if (bctype == -1) then - bct = tf(i,j,k+1) - else - bct = bctype - endif - if (bct == LO_DIRICHLET) then - dterm(i,j,k+1) = d(i,j,k+1) * & - (bcval(i,j,k+1) - er(i,j,k)) & - / (0.5e0_rt*h + bcl) - else if (bct == LO_NEUMANN & - .AND. bcval(i,j,k+1) == 0.e0_rt) then - dterm(i,j,k+1) = 0.e0_rt - else - print *, "hdterm3: unsupported boundary type" - stop - endif - endif - enddo - enddo - else - print *, "hdterm3: impossible face orientation" - endif -end subroutine hdterm3 - -end module habec_module diff --git a/Source/radiation/HABEC_F.H b/Source/radiation/HABEC_F.H deleted file mode 100644 index 72a3f7be97..0000000000 --- a/Source/radiation/HABEC_F.H +++ /dev/null @@ -1,37 +0,0 @@ -#ifndef CASTRO_HABEC_F_H -#define CASTRO_HABEC_F_H - -#include -#include - -#ifdef __cplusplus -extern "C" { -#else -#define RadBoundCond int -#endif - - void hdterm(BL_FORT_FAB_ARG(dterm), - BL_FORT_FAB_ARG(soln), - ARLIM_P(reglo), ARLIM_P(reghi), - const int& cdir, const RadBoundCond& bct, - const amrex::Real& bcl, - const BL_FORT_FAB_ARG(bcval), - const BL_FORT_IFAB_ARG(mask), - BL_FORT_FAB_ARG(dcoefs), - const amrex::Real* dx); - - void hdterm3(BL_FORT_FAB_ARG(dterm), - BL_FORT_FAB_ARG(soln), - ARLIM_P(reglo), ARLIM_P(reghi), - const int& cdir, const int& bctype, const int* tf, - const amrex::Real& bcl, - const BL_FORT_FAB_ARG(bcval), - const BL_FORT_IFAB_ARG(mask), - BL_FORT_FAB_ARG(dcoefs), - const amrex::Real* dx); - -#ifdef __cplusplus -}; -#endif - -#endif diff --git a/Source/radiation/HypreABec.cpp b/Source/radiation/HypreABec.cpp index e3ac5a4931..638d4715bb 100644 --- a/Source/radiation/HypreABec.cpp +++ b/Source/radiation/HypreABec.cpp @@ -4,7 +4,6 @@ #include #include -#include #include #include diff --git a/Source/radiation/HypreExtMultiABec.cpp b/Source/radiation/HypreExtMultiABec.cpp index 9f958fae89..a65292751a 100644 --- a/Source/radiation/HypreExtMultiABec.cpp +++ b/Source/radiation/HypreExtMultiABec.cpp @@ -1,6 +1,6 @@ #include -#include +#include #include #include <_hypre_sstruct_mv.h> @@ -1040,31 +1040,31 @@ void HypreExtMultiABec::boundaryDterm(int level, const Mask &msk = bd[level]->bndryMasks(oitr(), i); if (reg[oitr()] == domain[oitr()]) { - const int *tfp = NULL; + Array4 tf_arr; int bctype = bct; if (bd[level]->mixedBndry(oitr())) { const BaseFab &tf = *(bd[level]->bndryTypes(oitr())[i]); - tfp = tf.dataPtr(); + tf_arr = tf.array(); bctype = -1; } - hdterm3(BL_TO_FORTRAN(Dterm[idim][mfi]), - BL_TO_FORTRAN_N(Soln[mfi], icomp), - ARLIM(reg.loVect()), ARLIM(reg.hiVect()), - cdir, bctype, tfp, bcl, - BL_TO_FORTRAN_N(bcv, bdcomp), - BL_TO_FORTRAN(msk), - BL_TO_FORTRAN((*d2coefs[level])[idim][mfi]), - geom[level].CellSize()); + HABEC::hdterm3(Dterm[idim][mfi].array(), + Soln[mfi].array(icomp), + reg, + cdir, bctype, tf_arr, bcl, + bcv.array(bdcomp), + msk.array(), + (*d2coefs[level])[idim][mfi].array(), + geom[level].CellSize()); } else { - hdterm(BL_TO_FORTRAN(Dterm[idim][mfi]), - BL_TO_FORTRAN_N(Soln[mfi], icomp), - ARLIM(reg.loVect()), ARLIM(reg.hiVect()), - cdir, bct, bcl, - BL_TO_FORTRAN_N(bcv, bdcomp), - BL_TO_FORTRAN(msk), - BL_TO_FORTRAN((*d2coefs[level])[idim][mfi]), - geom[level].CellSize()); + HABEC::hdterm(Dterm[idim][mfi].array(), + Soln[mfi].array(icomp), + reg, + cdir, bct, bcl, + bcv.array(bdcomp), + msk.array(), + (*d2coefs[level])[idim][mfi].array(), + geom[level].CellSize()); } } } diff --git a/Source/radiation/HypreMultiABec.cpp b/Source/radiation/HypreMultiABec.cpp index b548767211..311c78c0a4 100644 --- a/Source/radiation/HypreMultiABec.cpp +++ b/Source/radiation/HypreMultiABec.cpp @@ -4,7 +4,6 @@ #include #include -#include #include #include diff --git a/Source/radiation/Make.package b/Source/radiation/Make.package index 977a82fee5..eb9eb54a20 100644 --- a/Source/radiation/Make.package +++ b/Source/radiation/Make.package @@ -30,13 +30,10 @@ CEXE_headers += filter.H CEXE_headers += filt_prim.H FEXE_headers += RAD_F.H -FEXE_headers += HABEC_F.H ca_F90EXE_sources += RAD_$(DIM)D.F90 -ca_F90EXE_sources += HABEC_$(DIM)D.F90 CEXE_sources += trace_ppm_rad.cpp -ca_f90EXE_sources += CastroRad_$(DIM)d.f90 ca_F90EXE_sources += rad_params.F90 ca_F90EXE_sources += Rad_nd.F90 diff --git a/Source/radiation/RAD_F.H b/Source/radiation/RAD_F.H index 079dedba62..3b6e374ba0 100644 --- a/Source/radiation/RAD_F.H +++ b/Source/radiation/RAD_F.H @@ -53,17 +53,6 @@ BL_FORT_PROC_DECL(CA_INITGROUPS3,ca_initgroups3) BL_FORT_PROC_DECL(CA_COMPUTE_KAPKAP, ca_compute_kapkap) (BL_FORT_FAB_ARG(kapkap), const BL_FORT_FAB_ARG(kap_r)); -#ifdef __cplusplus -extern "C" { -#endif - void ca_correct_dterm - (D_DECL(BL_FORT_FAB_ARG(dfx), - BL_FORT_FAB_ARG(dfy), - BL_FORT_FAB_ARG(dfz)), - const amrex::Real* re, const amrex::Real* rc); -#ifdef __cplusplus -} -#endif #ifdef __cplusplus extern "C" { diff --git a/Source/radiation/RadSolve.cpp b/Source/radiation/RadSolve.cpp index e671cf66f1..ea8e78d0df 100644 --- a/Source/radiation/RadSolve.cpp +++ b/Source/radiation/RadSolve.cpp @@ -8,7 +8,6 @@ #include #include #include -#include // only for nonsymmetric flux; may be changed? #include @@ -813,6 +812,7 @@ void RadSolve::levelDterm(int level, MultiFab& Dterm, MultiFab& Er, int igroup) const BoxArray& grids = parent->boxArray(level); const DistributionMapping& dmap = parent->DistributionMap(level); const Geometry& geom = parent->Geom(level); + const GeometryData& geomdata = geom.data(); auto dx = parent->Geom(level).CellSizeArray(); const Castro *castro = dynamic_cast(&parent->getLevel(level)); @@ -863,75 +863,64 @@ void RadSolve::levelDterm(int level, MultiFab& Dterm, MultiFab& Er, int igroup) // Correct D terms at physical and coarse-fine boundaries. hem->boundaryDterm(level, &Dterm_face[0], Er, igroup); + // Correct for metric terms (only has an effect in non-Cartesian geometries). + for (int dir = 0; dir < AMREX_SPACEDIM; ++dir) { #ifdef _OPENMP #pragma omp parallel #endif - { - Vector rc, re, s; - - if (geom.IsSPHERICAL() || geom.IsRZ()) { - for (MFIter fi(Dterm_face[0]); fi.isValid(); ++fi) { // omp over boxes - int i = fi.index(); - const Box ® = grids[i]; + for (MFIter mfi(Dterm_face[dir], true); mfi.isValid(); ++mfi) { + const Box& box = mfi.tilebox(); + Array4 const d = Dterm_face[dir][mfi].array(); - parent->Geom(level).GetEdgeLoc(re, reg, 0); - parent->Geom(level).GetCellLoc(rc, reg, 0); - - if (geom.IsSPHERICAL()) { - parent->Geom(level).GetCellLoc(s, reg, 0); + amrex::ParallelFor(box, + [=] AMREX_GPU_DEVICE (int i, int j, int k) noexcept + { + if (dir == 0 && (geomdata.Coord() == CoordSys::SPHERICAL || geomdata.Coord() == CoordSys::RZ)) { + Real r, s; + edge_center_metric(i, j, k, dir, geomdata, r, s); - const Box &dbox = Dterm_face[0][fi].box(); + d(i,j,k) = d(i,j,k) / (r + 1.0e-50_rt); + } + else if (dir == 1 && geomdata.Coord() == CoordSys::RZ) { + Real r, s; + cell_center_metric(i, j, k, geomdata, r, s); - for (int i = dbox.loVect()[0]; i <= dbox.hiVect()[0]; ++i) { - re[i] *= re[i]; - } -#if AMREX_SPACEDIM >= 2 - Real h2 = 0.5e0_rt * dx[1]; - Real d2 = 1.e0_rt / dx[1]; - for (int j = dbox.loVect()[1]; j <= dbox.hiVect()[1]; ++j) { - s[j] = d2 * (std::cos(s[j] - h2) - std::cos(s[j] + h2)); - } -#endif + d(i,j,k) = d(i,j,k) / r; } + }); + } + } - ca_correct_dterm(D_DECL(BL_TO_FORTRAN(Dterm_face[0][fi]), - BL_TO_FORTRAN(Dterm_face[1][fi]), - BL_TO_FORTRAN(Dterm_face[2][fi])), - re.dataPtr(), rc.dataPtr()); - } #ifdef _OPENMP -#pragma omp barrier +#pragma omp parallel #endif - } - - for (MFIter fi(Dterm,true); fi.isValid(); ++fi) { - const Box& bx = fi.tilebox(); + for (MFIter fi(Dterm,true); fi.isValid(); ++fi) { + const Box& bx = fi.tilebox(); - auto Dx = Dterm_face[0][fi].array(); + auto Dx = Dterm_face[0][fi].array(); #if AMREX_SPACEDIM >= 2 - auto Dy = Dterm_face[1][fi].array(); + auto Dy = Dterm_face[1][fi].array(); #endif #if AMREX_SPACEDIM == 3 - auto Dz = Dterm_face[2][fi].array(); + auto Dz = Dterm_face[2][fi].array(); #endif - auto D = Dterm[fi].array(); + auto D = Dterm[fi].array(); - amrex::ParallelFor(bx, - [=] AMREX_GPU_HOST_DEVICE (int i, int j, int k) - { + amrex::ParallelFor(bx, + [=] AMREX_GPU_HOST_DEVICE (int i, int j, int k) + { #if AMREX_SPACEDIM == 1 - D(i,j,k) = (Dx(i,j,k) + Dx(i+1,j,k)) * 0.5_rt; + D(i,j,k) = (Dx(i,j,k) + Dx(i+1,j,k)) * 0.5_rt; #elif AMREX_SPACEDIM == 2 - D(i,j,k) = (Dx(i,j,k) + Dx(i+1,j,k) + - Dy(i,j,k) + Dy(i,j+1,k)) * 0.25_rt; + D(i,j,k) = (Dx(i,j,k) + Dx(i+1,j,k) + + Dy(i,j,k) + Dy(i,j+1,k)) * 0.25_rt; #else - D(i,j,k) = (Dx(i,j,k) + Dx(i+1,j,k) + - Dy(i,j,k) + Dy(i,j+1,k) + - Dz(i,j,k) + Dz(i,j,k+1)) * (1.0_rt / 6.0_rt); + D(i,j,k) = (Dx(i,j,k) + Dx(i+1,j,k) + + Dy(i,j,k) + Dy(i,j+1,k) + + Dz(i,j,k) + Dz(i,j,k+1)) * (1.0_rt / 6.0_rt); #endif - }); - } + }); } }