From 4a571bdd8854af66559989ae9b2ab788699d0183 Mon Sep 17 00:00:00 2001 From: "Aaron M. Lattanzi" <103702284+AMLattanzi@users.noreply.github.com> Date: Tue, 3 Sep 2024 14:44:49 -0700 Subject: [PATCH] Nscalar Bounds Fix (#1783) * Fix bounds on cons scalar loop. * propagate fix. * More index protections. * Fix typo. * Change mynn ctest to debug tolerance for MacOS. --- .../BoundaryConditions_cons.cpp | 49 +++++++++++++------ Tests/CTestList.cmake | 6 +-- 2 files changed, 36 insertions(+), 19 deletions(-) diff --git a/Source/BoundaryConditions/BoundaryConditions_cons.cpp b/Source/BoundaryConditions/BoundaryConditions_cons.cpp index acd86160d..e80703030 100644 --- a/Source/BoundaryConditions/BoundaryConditions_cons.cpp +++ b/Source/BoundaryConditions/BoundaryConditions_cons.cpp @@ -52,7 +52,7 @@ void ERFPhysBCFunct_cons::impose_lateral_cons_bcs (const Array4& dest_arr, } for (int ori = 0; ori < 2*AMREX_SPACEDIM; ori++) { - l_bc_extdir_vals_d[nc][ori] = m_bc_extdir_vals[bc_comp][ori]; + l_bc_extdir_vals_d[bc_comp][ori] = m_bc_extdir_vals[bc_comp][ori]; } } @@ -73,25 +73,31 @@ void ERFPhysBCFunct_cons::impose_lateral_cons_bcs (const Array4& dest_arr, bx_xlo, ncomp, [=] AMREX_GPU_DEVICE (int i, int j, int k, int n) { int dest_comp = icomp+n; + int bc_comp = (dest_comp >= RhoScalar_comp && dest_comp < RhoScalar_comp+NSCALARS) ? + BCVars::RhoScalar_bc_comp : dest_comp; + if (bc_comp > BCVars::RhoScalar_bc_comp) bc_comp -= (NSCALARS-1); int l_bc_type = bc_ptr[n].lo(0); if (l_bc_type == ERFBCType::ext_dir) { - dest_arr(i,j,k,dest_comp) = l_bc_extdir_vals_d[n][0]; + dest_arr(i,j,k,dest_comp) = l_bc_extdir_vals_d[bc_comp][0]; } else if (l_bc_type == ERFBCType::ext_dir_prim) { Real rho = dest_arr(dom_lo.x,j,k,Rho_comp); - dest_arr(i,j,k,dest_comp) = rho * l_bc_extdir_vals_d[n][0]; + dest_arr(i,j,k,dest_comp) = rho * l_bc_extdir_vals_d[bc_comp][0]; } }, bx_xhi, ncomp, [=] AMREX_GPU_DEVICE (int i, int j, int k, int n) { int dest_comp = icomp+n; + int bc_comp = (dest_comp >= RhoScalar_comp && dest_comp < RhoScalar_comp+NSCALARS) ? + BCVars::RhoScalar_bc_comp : dest_comp; + if (bc_comp > BCVars::RhoScalar_bc_comp) bc_comp -= (NSCALARS-1); int h_bc_type = bc_ptr[n].hi(0); if (h_bc_type == ERFBCType::ext_dir) { - dest_arr(i,j,k,dest_comp) = l_bc_extdir_vals_d[n][3]; + dest_arr(i,j,k,dest_comp) = l_bc_extdir_vals_d[bc_comp][3]; } else if (h_bc_type == ERFBCType::ext_dir_prim) { Real rho = dest_arr(dom_hi.x,j,k,Rho_comp); - dest_arr(i,j,k,dest_comp) = rho * l_bc_extdir_vals_d[n][3]; + dest_arr(i,j,k,dest_comp) = rho * l_bc_extdir_vals_d[bc_comp][3]; } } ); @@ -105,23 +111,29 @@ void ERFPhysBCFunct_cons::impose_lateral_cons_bcs (const Array4& dest_arr, bx_ylo, ncomp, [=] AMREX_GPU_DEVICE (int i, int j, int k, int n) { int dest_comp = icomp+n; + int bc_comp = (dest_comp >= RhoScalar_comp && dest_comp < RhoScalar_comp+NSCALARS) ? + BCVars::RhoScalar_bc_comp : dest_comp; + if (bc_comp > BCVars::RhoScalar_bc_comp) bc_comp -= (NSCALARS-1); int l_bc_type = bc_ptr[n].lo(1); if (l_bc_type == ERFBCType::ext_dir) { - dest_arr(i,j,k,dest_comp) = l_bc_extdir_vals_d[n][1]; + dest_arr(i,j,k,dest_comp) = l_bc_extdir_vals_d[bc_comp][1]; } else if (l_bc_type == ERFBCType::ext_dir_prim) { Real rho = dest_arr(i,dom_lo.y,k,Rho_comp); - dest_arr(i,j,k,dest_comp) = rho * l_bc_extdir_vals_d[n][1]; + dest_arr(i,j,k,dest_comp) = rho * l_bc_extdir_vals_d[bc_comp][1]; } }, bx_yhi, ncomp, [=] AMREX_GPU_DEVICE (int i, int j, int k, int n) { int dest_comp = icomp+n; + int bc_comp = (dest_comp >= RhoScalar_comp && dest_comp < RhoScalar_comp+NSCALARS) ? + BCVars::RhoScalar_bc_comp : dest_comp; + if (bc_comp > BCVars::RhoScalar_bc_comp) bc_comp -= (NSCALARS-1); int h_bc_type = bc_ptr[n].hi(1); if (h_bc_type == ERFBCType::ext_dir) { - dest_arr(i,j,k,dest_comp) = l_bc_extdir_vals_d[n][4]; + dest_arr(i,j,k,dest_comp) = l_bc_extdir_vals_d[bc_comp][4]; } else if (h_bc_type == ERFBCType::ext_dir_prim) { Real rho = dest_arr(i,dom_hi.y,k,Rho_comp); - dest_arr(i,j,k,dest_comp) = rho * l_bc_extdir_vals_d[n][4]; + dest_arr(i,j,k,dest_comp) = rho * l_bc_extdir_vals_d[bc_comp][4]; } } ); @@ -288,8 +300,8 @@ void ERFPhysBCFunct_cons::impose_vertical_cons_bcs (const Array4& dest_arr } for (int ori = 0; ori < 2*AMREX_SPACEDIM; ori++) { - l_bc_extdir_vals_d[nc][ori] = m_bc_extdir_vals[bc_comp][ori]; - l_bc_neumann_vals_d[nc][ori] = m_bc_neumann_vals[bc_comp][ori]; + l_bc_extdir_vals_d[bc_comp][ori] = m_bc_extdir_vals[bc_comp][ori]; + l_bc_neumann_vals_d[bc_comp][ori] = m_bc_neumann_vals[bc_comp][ori]; } } @@ -304,25 +316,30 @@ void ERFPhysBCFunct_cons::impose_vertical_cons_bcs (const Array4& dest_arr bx_zlo, ncomp, [=] AMREX_GPU_DEVICE (int i, int j, int k, int n) { int dest_comp = icomp+n; + int bc_comp = (dest_comp >= RhoScalar_comp && dest_comp < RhoScalar_comp+NSCALARS) ? + BCVars::RhoScalar_bc_comp : dest_comp; + if (bc_comp > BCVars::RhoScalar_bc_comp) bc_comp -= (NSCALARS-1); int l_bc_type = bc_ptr[n].lo(2); - if (l_bc_type == ERFBCType::ext_dir) { - dest_arr(i,j,k,dest_comp) = l_bc_extdir_vals_d[n][2]; + dest_arr(i,j,k,dest_comp) = l_bc_extdir_vals_d[bc_comp][2]; } else if (l_bc_type == ERFBCType::ext_dir_prim) { Real rho = dest_arr(i,j,dom_lo.z,Rho_comp); - dest_arr(i,j,k,dest_comp) = rho * l_bc_extdir_vals_d[n][2]; + dest_arr(i,j,k,dest_comp) = rho * l_bc_extdir_vals_d[bc_comp][2]; } }, bx_zhi, ncomp, [=] AMREX_GPU_DEVICE (int i, int j, int k, int n) { int dest_comp = icomp+n; + int bc_comp = (dest_comp >= RhoScalar_comp && dest_comp < RhoScalar_comp+NSCALARS) ? + BCVars::RhoScalar_bc_comp : dest_comp; + if (bc_comp > BCVars::RhoScalar_bc_comp) bc_comp -= (NSCALARS-1); int h_bc_type = bc_ptr[n].hi(2); if (h_bc_type == ERFBCType::ext_dir) { - dest_arr(i,j,k,dest_comp) = l_bc_extdir_vals_d[n][5]; + dest_arr(i,j,k,dest_comp) = l_bc_extdir_vals_d[bc_comp][5]; } else if (h_bc_type == ERFBCType::ext_dir_prim) { Real rho = dest_arr(i,j,dom_hi.z,Rho_comp); - dest_arr(i,j,k,dest_comp) = rho * l_bc_extdir_vals_d[n][5]; + dest_arr(i,j,k,dest_comp) = rho * l_bc_extdir_vals_d[bc_comp][5]; } } diff --git a/Tests/CTestList.cmake b/Tests/CTestList.cmake index 99b6e36e5..32202c6c3 100644 --- a/Tests/CTestList.cmake +++ b/Tests/CTestList.cmake @@ -63,7 +63,7 @@ function(add_test_d TEST_NAME TEST_EXE PLTFILE) setup_test() set(TEST_EXE ${CMAKE_BINARY_DIR}/Exec/${TEST_EXE}) - set(FCOMPARE_TOLERANCE "-r 2.0e-9 --abs_tol 2.0e-9") + set(FCOMPARE_TOLERANCE "-r 3.0e-9 --abs_tol 3.0e-9") set(FCOMPARE_FLAGS "--abort_if_not_all_found -a ${FCOMPARE_TOLERANCE}") set(test_command sh -c "${MPI_COMMANDS} ${TEST_EXE} ${CURRENT_TEST_BINARY_DIR}/${TEST_NAME}.i > ${TEST_NAME}.log && ${MPI_FCOMP_COMMANDS} ${FCOMPARE_EXE} ${FCOMPARE_FLAGS} ${PLOT_GOLD} ${CURRENT_TEST_BINARY_DIR}/${PLTFILE}") @@ -135,7 +135,7 @@ add_test_r(TaylorGreenAdvectingDiffusing "RegTests/TaylorGreenVortex/*/erf_t add_test_r(MSF_NoSub_IsentropicVortexAdv "RegTests/IsentropicVortex/*/erf_isentropic_vortex.exe" "plt00010") add_test_r(MSF_Sub_IsentropicVortexAdv "RegTests/IsentropicVortex/*/erf_isentropic_vortex.exe" "plt00010") add_test_r(ABL_MOST "ABL/*/erf_abl.exe" "plt00010") -add_test_r(ABL_MYNN_PBL "ABL/*/erf_abl.exe" "plt00100" INPUT_SOUNDING "input_sounding_GABLS1") +add_test_d(ABL_MYNN_PBL "ABL/*/erf_abl.exe" "plt00100" INPUT_SOUNDING "input_sounding_GABLS1") add_test_r(ABL_InflowFile "ABL/*/erf_abl.exe" "plt00010") add_test_r(MoistBubble "RegTests/Bubble/*/erf_bubble.exe" "plt00010") @@ -175,7 +175,7 @@ add_test_r(TaylorGreenAdvectingDiffusing "RegTests/TaylorGreenVortex/erf_tay add_test_r(MSF_NoSub_IsentropicVortexAdv "RegTests/IsentropicVortex/erf_isentropic_vortex" "plt00010") add_test_r(MSF_Sub_IsentropicVortexAdv "RegTests/IsentropicVortex/erf_isentropic_vortex" "plt00010") add_test_r(ABL_MOST "ABL/erf_abl" "plt00010") -add_test_r(ABL_MYNN_PBL "ABL/erf_abl" "plt00100" INPUT_SOUNDING "input_sounding_GABLS1") +add_test_d(ABL_MYNN_PBL "ABL/erf_abl" "plt00100" INPUT_SOUNDING "input_sounding_GABLS1") add_test_r(ABL_InflowFile "ABL/erf_abl" "plt00010") add_test_r(MoistBubble "RegTests/Bubble/erf_bubble" "plt00010")