Abstract
An increasing number of programming languages, such as Fortran 90 and APL, are providing a rich set of intrinsic array functions and array expressions. These constructs which constitute an important part of data parallel languages provide excellent opportunities for compiler optimizations. In this paper, we present a new approach to combine consecutive data access patterns of array constructs into a composite access function to the source arrays. Our scheme is based on the composition of access functions, which is similar to a composition of mathematic functions. Our new scheme can handle not only data movements of arrays of different numbers of dimensions and segmented array operations but also masked array expressions and multiple sources array operations. As a result, our proposed scheme is the first synthesis scheme which can synthesize Fortran 90 RESHAPE, EOSHIFT, MERGE, and WHERE constructs together. Experimental results show speedups from 1.21 to 2.95 for code fragments from real applications on a Sequent multiprocessor machine by incorporating the proposed optimizations.
Original language | English |
---|---|
Pages | 112-122 |
Number of pages | 11 |
DOIs | |
Publication status | Published - 1995 |
Externally published | Yes |
Event | Proceedings of the 5th ACM SIGPLAN Symposium on Principles and Practice of Parallel Programming - Santa Barbara, CA, USA Duration: 1995 Jul 19 → 1995 Jul 21 |
Other
Other | Proceedings of the 5th ACM SIGPLAN Symposium on Principles and Practice of Parallel Programming |
---|---|
City | Santa Barbara, CA, USA |
Period | 1995/07/19 → 1995/07/21 |
ASJC Scopus subject areas
- General Computer Science