Data Parallel Computers and the FORALL Statement

Abstract The array constructs of Fortran 90 (formerly called Fortran 8x) map naturally onto SIMD architectures, such as that of the Connection Machine computer system, that support a data parallel programming style. The Forall statement, an extension to Fortran 90 allowing for the expression of simultaneous execution of certain do loop bodies, enhances this natural fit. A Fortran 90 compiler for data parallel machines is naturally extended to handle the Forall statement. We describe the data structures and algorithms used to effect this extension and present some examples of source code fragments and the target operations generated for them.

[1]  Michael Metcalf,et al.  Fortran 8X Explained , 1987 .

[2]  Guy L. Steele,et al.  Data Optimization: Allocation of Arrays to Reduce Communication on SIMD Machines , 1990, J. Parallel Distributed Comput..

[3]  Guy L. Steele,et al.  Massively parallel data optimization , 1988, Proceedings., 2nd Symposium on the Frontiers of Massively Parallel Computation.

[4]  Robert E. Millstein,et al.  Control structures in Illiac IV Fortran , 1973, CACM.

[5]  W. Daniel Hillis,et al.  The connection machine , 1985 .

[6]  Guy L. Steele,et al.  Compiling Fortran 8x array features for the connection machine computer system , 1988, PPoPP 1988.