Back to Search Start Over

Engineering Algorithms for Scalability through Continuous Validation of Performance Expectations.

Authors :
Shudler, Sergei
Berens, Yannick
Calotoiu, Alexandru
Hoefler, Torsten
Strube, Alexandre
Wolf, Felix
Source :
IEEE Transactions on Parallel & Distributed Systems. Aug2019, Vol. 30 Issue 8, p1768-1785. 18p.
Publication Year :
2019

Abstract

Many libraries in the HPC field use sophisticated algorithms with clear theoretical scalability expectations. However, hardware constraints or programming bugs may sometimes render these expectations inaccurate or even plainly wrong. While algorithm and performance engineers have already been advocating the systematic combination of analytical performance models with practical measurements for a very long time, we go one step further and show how this comparison can become part of automated testing procedures. The most important applications of our method include initial validation, regression testing, and benchmarking to compare implementation and platform alternatives. Advancing the concept of performance assertions, we verify asymptotic scaling trends rather than precise analytical expressions, relieving the developer from the burden of having to specify and maintain very fine-grained and potentially non-portable expectations. In this way, scalability validation can be continuously applied throughout the whole development cycle with very little effort. Using MPI and parallel sorting algorithms as examples, we show how our method can help uncover non-obvious limitations of both libraries and underlying platforms. [ABSTRACT FROM AUTHOR]

Details

Language :
English
ISSN :
10459219
Volume :
30
Issue :
8
Database :
Academic Search Index
Journal :
IEEE Transactions on Parallel & Distributed Systems
Publication Type :
Academic Journal
Accession number :
137646027
Full Text :
https://doi.org/10.1109/TPDS.2019.2896993