A Deterministic Notation for Cooperating Processes
- Creators
- Chandy, K. Mani
- Foster, Ian
Abstract
This paper proposes extensions of sequential programming languages for parallel programming that have the following features: 1. Dynamic Structures The process structure is dynamic: Processes and variables can be created and deleted. 2.Paradigm Integration The programming notation allows shared memory and message passing. 3.Determinism Demonstrating that a program is deterministic -- all executions with the same input produce the same output -- is straightforward. A program can be written so that the compiler can verify that the program is deterministic. Nondeterministic constructs can be introduced in a sequence of refinement steps to obtain greater efficiency if required. The ideas have been incorporated in an extension of Fortran, but the underlying sequential imperative language is not central to the ideas described here.
Additional Information
© 1993 California Institute of Technology. August 12, 1993. Supported by NSF Center for Research in Parallel Computation Contract CCR-8809615 and DOE Contract W-31-109-Eng-38.Attached Files
Submitted - CS-TR-93-31.pdf
Submitted - CS-TR-93-31.ps
Files
Name | Size | Download all |
---|---|---|
md5:45d76651fb9ad3df03ff5845d3c1b96e
|
1.4 MB | Download |
md5:da9c66361a039dadc274b1dd347585cc
|
1.2 MB | Preview Download |
Additional details
- Eprint ID
- 26897
- Resolver ID
- CaltechCSTR:1993.cs-tr-93-31
- NSF
- CCR-8809615
- Department of Energy (DOE)
- W-31-109-ENG-38
- Created
-
2001-07-19Created from EPrint's datestamp field
- Updated
-
2019-10-03Created from EPrint's last_modified field
- Caltech groups
- Computer Science Technical Reports
- Series Name
- Computer Science Technical Reports