An important recent idea in software technology for distr ibuted-memory multicomputers is the use of annotations to control data partitioning and placement, relying on a compiler to infer the necessary process placement and communications. We have been developing a declarative language for controlling data partitioning and placement in functional programs, called Caliban. It is interesting because the annotat ion language builds on the power of the functional language, allowing the user to reuse code developed for the computational part of the problem when expressing how it should be distributed across a parallel computer. The key to doing this is partial evaluation, that is symbolically executing the program until the annotat ion is in its primitive form, and the partit ioning is clear. While this work was developed primarily in the context of parallel functional programming, there is the interesting prospect of applying it to the problem of controlling the distr ibution of data in traditional languages.
[1]
Paul H. J. Kelly.
Functional programming for loosely-coupled multiprocessors
,
1989,
Research monographs in parallel and distributed computing.
[2]
Jwd Bakker,et al.
PARLE, Parallel Architectures and Languages Europe, Volume I: Parallel Architectures, Eindhoven, The Netherlands, June 15-19, 1987, Proceedings
,
1987
.
[3]
Jan Willem Klop,et al.
Term Graph Rewriting
,
1995,
HOA.
[4]
Marko C. J. D. van Eekelen,et al.
Term Graph Rewriting
,
1987,
PARLE.
[5]
Junxian Liu,et al.
An Implementation of Static Functional Process Networks
,
1992,
PARLE.
[6]
Simon L. Peyton Jones,et al.
Report on the programming language Haskell: a non-strict, purely functional language version 1.2
,
1992,
SIGP.
[7]
Murray Cole,et al.
Algorithmic Skeletons: Structured Management of Parallel Computation
,
1989
.