An array operation synthesis scheme to optimize Fortran 90 programs
- 1 August 1995
- conference paper
- Published by Association for Computing Machinery (ACM)
- Vol. 30 (8) , 112-122
- https://doi.org/10.1145/209936.209949
Abstract
[[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.[[fileno]]2030216030010[[department]]資訊工程學This publication has 3 references indexed in Scilit:
- Object oriented parallel programmingPublished by Association for Computing Machinery (ACM) ,1991
- An APL Compiler for a Vector ProcessorACM Transactions on Programming Languages and Systems, 1984
- Compilation and delayed evaluation in APLPublished by Association for Computing Machinery (ACM) ,1978