Compiler Optimizations for Irregular Memory Access Patterns in the PGAS Programming Model
Files
Publication or External Link
Date
Authors
Advisor
Citation
Abstract
Applications that operate on large, sparse graphs and matrices exhibit fine-grain irregular memory accesses patterns, leading to both performance and productivity challenges on today's distributed-memory systems. The Partitioned Global Address Space (PGAS) model attempts to address these challenges by combining the memory of physically distributed nodes into a logical global address space, simplifying how programmers perform communication in their applications. However, while the PGAS model can provide high developer productivity, the performance issues that arise from irregular memory accesses are still present. This dissertation aims to bridge the gap between high productivity and high performance for irregular applications in the PGAS programming model.
To achieve that goal, I designed and implemented COPPER, a framework that performs Compiler Optimizations for Productivity and PERformance. COPPER automatically performs static analysis to identify irregular memory access patterns to distributed data within parallel loops, and then applies code transformations to perform optimizations at runtime. These optimizations perform small message aggregation, adaptive prefetching and selective data replication. Furthermore, they are applied without requiring user intervention, thereby improving performance and developer productivity. I demonstrate the capabilities of COPPER by implementing it within the Chapel parallel programming language and conducting performance evaluations across a variety of irregular workloads and hardware platforms. These evaluations show that COPPER can achieve runtime speed-ups of 1.08 -- 87x for small message aggregation, 0.78 -- 3.2x for adaptive prefetching and 1.2 -- 444x for selective data replication.