Affiliation:
1. Oregon State Univ., Corvallis
2. Univ. of Rochester, Rochester, NY
Abstract
Parallel programming involves finding the potential parallelism in an application and mapping it to the architecture at hand. Since a typical application has more potential parallelism than any single architecture can exploit effectively, programmers usually limit their focus to the parallelism that the available control constructs express easily and that the given architecture exploits efficiently. This approach produces programs that exhibit much less parallelism that exists in the application, and whose performance depends critically on the underlying hardware and software.
We argue for an alternative approach based on
control abstraction
. Control abstraction is the process by which programmers define new control constructs, specifying constraints on statement ordering separately from an implementation of that ordering. With control abstraction programmers can define and use a rich variety of control constructs to represent an algorithm's potential parallelism.
Since control abstraction separates the definition of a construct from its implementation, a construct may have several different implementations, each exploiting a different subset of the parallelism admitted by the construct. By selecting an implementation for each control construct using annotations, a programmer can vary the parallelism in a program to best exploit the underlying hardware without otherwise changing the source code. This approach produces programs that exhibit most of the potential parallelism in an algorithm, and whose performance can be tuned simply by choosing among the various implementations for the control constructs in use.
Publisher
Association for Computing Machinery (ACM)
Reference40 articles.
1. ALVERSON G.A. 1990. Abstraction for effectively portable shared memory parallel programs. Ph.D dissertation Tech Rep 90-10-09 Dept. of Computer Science and Engineering Univ. of Washington Seattle Wash.]] ALVERSON G.A. 1990. Abstraction for effectively portable shared memory parallel programs. Ph.D dissertation Tech Rep 90-10-09 Dept. of Computer Science and Engineering Univ. of Washington Seattle Wash.]]
2. Program structuring for effective parallel portability
3. An overview of the SR language and implementation
4. AMERICAN NATIONAL STANDARDS INSTITUTE. 1990. American National Standard Programming Language: Fortran 90 X3J3/s8.115. ANSI Washington D.C.]] AMERICAN NATIONAL STANDARDS INSTITUTE. 1990. American National Standard Programming Language: Fortran 90 X3J3/s8.115. ANSI Washington D.C.]]