Abstract
Fortran's prominence in scientific computing requires strategies to ensure both that legacy codes are efficient on high-performance computing systems, and that the language remains attractive for the development of new high-performance codes. Coarray Fortran (CAF), part of the Fortran 2008 standard introduced for parallel programming, facilitates distributed memory parallelism with a syntax familiar to Fortran programmers, simplifying the transition from single-processor to multi-processor coding. This research focuses on innovating and refining a parallel programming methodology that fuses the strengths of Intel Coarray Fortran, Nvidia CUDA Fortran, and OpenMP for distributed memory parallelism, high-speed GPU acceleration and shared memory parallelism respectively. We consider the management of pageable and pinned memory, CPU-GPU affinity in NUMA multiprocessors, and robust compiler interfacing with speed optimisation. We demonstrate our method through its application to a parallelised Poisson solver and compare the methodology, implementation, and scaling performance to that of the Message Passing Interface (MPI), finding CAF offers similar speeds with easier implementation. For new codes, this approach offers a faster route to optimised parallel computing. For legacy codes, it eases the transition to parallel computing, allowing their transformation into scalable, high-performance computing applications without the need for extensive re-design or additional syntax.
| Original language | English |
|---|---|
| Article number | 104977 |
| Journal | Journal of Parallel and Distributed Computing |
| Volume | 195 |
| DOIs | |
| Publication status | Published - Jan 2025 |
Funding
We are thankful to the referee for the comments and suggestions that helped to improve the manuscript. This work was supported by the FWF project I4311-N27 (J.M., E.I.V.) and RFBR project 19-51-14002 (I.K.). Benchmarks were performed on the Vienna Scientific Cluster (VSC) 4 4 and on the Narval Cluster provided by Calcul Qu\u00E9bec 5 5 and the Digital Research Alliance of Canada 6 6 .
Austrian Fields of Science 2012
- 103003 Astronomy
- 103004 Astrophysics
Keywords
- Coarray Fortran (CAF)
- CUDA Fortran
- MPI
- OpenMP