Algorithmic species : a classification of affine loop nests for parallel programming

C. Nugteren, P.J.M. Custers, H. Corporaal

Research output: Contribution to journalArticleAcademicpeer-review

8 Citations (Scopus)
9 Downloads (Pure)

Abstract

Code generation and programming have become ever more challenging over the last decade due to the shift towards parallel processing. Emerging processor architectures such as multi-cores and GPUs exploit increasingly parallelism, requiring programmers and compilers to deal with aspects such as threading, concurrency, synchronization, and complex memory partitioning. We advocate that programmers and compilers can greatly benefit from a structured classification of program code. Such a classification can help programmers to find opportunities for parallelization, reason about their code, and interact with other programmers. Similarly, parallelising compilers and source-to-source compilers can take threading and optimization decisions based on the same classification. In this work, we introduce algorithmic species, a classification of affine loop nests based on the polyhedral model and targeted for both automatic and manual use. Individual classes capture information such as the structure of parallelism and the data reuse. To make the classification applicable for manual use, a basic vocabulary forms the base for the creation of a set of intuitive classes. To demonstrate the use of algorithmic species, we identify 115 classes in a benchmark set. Additionally, we demonstrate the suitability of algorithmic species for automated uses by showing a tool to automatically extract species from program code, a species-based source-to-source compiler, and a species-based performance prediction model.
Original languageEnglish
Article number40
Pages (from-to)1-25
JournalACM Transactions on Architecture and Code Optimization
Volume9
Issue number4
DOIs
Publication statusPublished - 2013

Fingerprint

Dive into the research topics of 'Algorithmic species : a classification of affine loop nests for parallel programming'. Together they form a unique fingerprint.

Cite this