TY - JOUR
T1 - Parthenon—a performance portable block-structured adaptive mesh refinement framework
AU - Grete, Philipp
AU - Dolence, Joshua C.
AU - Miller, Jonah M.
AU - Brown, Joshua
AU - Ryan, Ben
AU - Gaspar, Andrew
AU - Glines, Forrest
AU - Swaminarayan, Sriram
AU - Lippuner, Jonas
AU - Solomon, Clell J.
AU - Shipman, Galen
AU - Junghans, Christoph
AU - Holladay, Daniel
AU - Stone, James M.
AU - Roberts, Luke F.
N1 - Publisher Copyright:
© The Author(s) 2022.
PY - 2023/9
Y1 - 2023/9
N2 - On the path to exascale the landscape of computer device architectures and corresponding programming models has become much more diverse. While various low-level performance portable programming models are available, support at the application level lacks behind. To address this issue, we present the performance portable block-structured adaptive mesh refinement (AMR) framework Parthenon, derived from the well-tested and widely used Athena++ astrophysical magnetohydrodynamics code, but generalized to serve as the foundation for a variety of downstream multi-physics codes. Parthenon adopts the Kokkos programming model, and provides various levels of abstractions from multidimensional variables, to packages defining and separating components, to launching of parallel compute kernels. Parthenon allocates all data in device memory to reduce data movement, supports the logical packing of variables and mesh blocks to reduce kernel launch overhead, and employs one-sided, asynchronous MPI calls to reduce communication overhead in multi-node simulations. Using a hydrodynamics miniapp, we demonstrate weak and strong scaling on various architectures including AMD and NVIDIA GPUs, Intel and AMD x86 CPUs, IBM Power9 CPUs, as well as Fujitsu A64FX CPUs. At the largest scale on Frontier (the first TOP500 exascale machine), the miniapp reaches a total of 1.7 × 1013 zone-cycles/s on 9216 nodes (73,728 logical GPUs) at (Formula presented.) weak scaling parallel efficiency (starting from a single node). In combination with being an open, collaborative project, this makes Parthenon an ideal framework to target exascale simulations in which the downstream developers can focus on their specific application rather than on the complexity of handling massively-parallel, device-accelerated AMR.
AB - On the path to exascale the landscape of computer device architectures and corresponding programming models has become much more diverse. While various low-level performance portable programming models are available, support at the application level lacks behind. To address this issue, we present the performance portable block-structured adaptive mesh refinement (AMR) framework Parthenon, derived from the well-tested and widely used Athena++ astrophysical magnetohydrodynamics code, but generalized to serve as the foundation for a variety of downstream multi-physics codes. Parthenon adopts the Kokkos programming model, and provides various levels of abstractions from multidimensional variables, to packages defining and separating components, to launching of parallel compute kernels. Parthenon allocates all data in device memory to reduce data movement, supports the logical packing of variables and mesh blocks to reduce kernel launch overhead, and employs one-sided, asynchronous MPI calls to reduce communication overhead in multi-node simulations. Using a hydrodynamics miniapp, we demonstrate weak and strong scaling on various architectures including AMD and NVIDIA GPUs, Intel and AMD x86 CPUs, IBM Power9 CPUs, as well as Fujitsu A64FX CPUs. At the largest scale on Frontier (the first TOP500 exascale machine), the miniapp reaches a total of 1.7 × 1013 zone-cycles/s on 9216 nodes (73,728 logical GPUs) at (Formula presented.) weak scaling parallel efficiency (starting from a single node). In combination with being an open, collaborative project, this makes Parthenon an ideal framework to target exascale simulations in which the downstream developers can focus on their specific application rather than on the complexity of handling massively-parallel, device-accelerated AMR.
KW - Adaptive mesh refinement
KW - high-performance computing
KW - parallel computing
KW - performance portability
UR - http://www.scopus.com/inward/record.url?scp=85144188348&partnerID=8YFLogxK
UR - http://www.scopus.com/inward/citedby.url?scp=85144188348&partnerID=8YFLogxK
U2 - 10.1177/10943420221143775
DO - 10.1177/10943420221143775
M3 - Article
AN - SCOPUS:85144188348
SN - 1094-3420
VL - 37
SP - 465
EP - 486
JO - International Journal of High Performance Computing Applications
JF - International Journal of High Performance Computing Applications
IS - 5
ER -