Abstract
This paper presents compiler algorithms to optimize out-of-core programs. These algorithms consider loop and data layout transformations in a unified framework. The performance of an out-of-core loop nest containing many references can be improved by a combination of restructuring the loops and file layouts. This approach considers array references one-by-one and attempts to optimize each reference for parallelism and locality. When there are references for which parallelism optimizations do not work, communication is vectorized so that data transfer can be performed before the innermost tiling loop. Preliminary results from hand-compiles on IBM SP-2 and Intel Paragon show that this approach reduces the execution time, improves the bandwidth speedup and overall speedup. In addition, we extend the base algorithm to work with file layout constraints and show how it can be used for optimizing programs consisting of multiple loop nests.
Original language | English (US) |
---|---|
Pages | 79-92 |
Number of pages | 14 |
State | Published - 1997 |
Event | Proceedings of the 1997 5th Workshop on I/O in Parallel and Distributed Systems - San Jose, CA, USA Duration: Nov 17 1997 → Nov 17 1997 |
Other
Other | Proceedings of the 1997 5th Workshop on I/O in Parallel and Distributed Systems |
---|---|
City | San Jose, CA, USA |
Period | 11/17/97 → 11/17/97 |
All Science Journal Classification (ASJC) codes
- General Computer Science