Presentation
SIGN IN TO VIEW THIS PRESENTATION Sign In
Advanced MPI Programming
DescriptionThe vast majority of production parallel scientific applications today use MPI and run successfully on the largest systems in the world. Parallel system architectures are evolving to include complex, heterogeneous nodes comprising general-purpose CPUs as well as accelerators such as GPUs. At the same time, the MPI standard itself is evolving to address the needs and challenges of future extreme-scale platforms as well as applications. This tutorial will cover several advanced features of MPI that can help users program modern systems effectively. Using code examples based on scenarios found in real applications, we will cover several topics including one-sided communication, hybrid programming (MPI + threads, shared memory, GPUs), neighborhood and nonblocking collectives, some of the new performance-oriented features in MPI-4, and the new ABI (application binary interface) in MPI-5. Attendees will leave the tutorial with an understanding of how to use these advanced features of MPI and guidelines on how they might perform on different platforms and architectures.




