Computing Reviews
Today's Issue Hot Topics Search Browse Recommended My Account Log In
Review Help
Search
Parallel programming
Coffin M., Silicon Press, Summit, NJ, 1992. Type: Book (9780929306131)
Date Reviewed: Apr 1 1993

Rather than being an introduction to parallel programming, this book is an introduction to a new programming language called Par. It is also an introduction to a new style of programming with annotations. Coffin assumes his readers have a basic understanding of parallel computing and compiler construction. Although quite a few programming examples are given, the book has no proofs or formulas, so it can be read easily.

Par is a language that Coffin designed as a doctoral student at the University of Arizona. Combined with generalized directives, called annotations, Par is intended for the development of portable applications for shared-memory, multiple instruction, multiple data (MIMD) architectures. Portability is accomplished by segregating the algorithm from the mapping and scheduling annotations. Annotations carry two powerful notions. First, they cannot affect program correctness. This property would be a welcome addition to most parallel programming models used today. Second, they are encoded using the Par language itself. Programmable compiler directives have the potential of being reused and standardized. Par does have some serious drawbacks. For  example,  Par has been designed for a shared-memory, fork-join model of computation. It is therefore not well suited to work sharing or strictly message-passing systems. Also, Par has never been implemented. So, although the concepts introduced in this book are important and quite interesting, do not expect to order a Par compiler anytime soon.

On the brighter side, Coffin includes a good chapter on related work at the end of this book. He describes some recent developments in the area of parallel compilers. This summary includes a discussion of the efforts to parallelize currently popular programming languages. It also covers work on less popular programming languages for parallel computation.

Overall, this book is interesting, but I question its usefulness as a trade book. It should have been focused into a transaction or generalized into a survey and submitted to a journal. Also, since Par has not been implemented, the title is misleading. Only one chapter covers the Par programming language itself, so this book is far from a language tutorial. Finally, the author should have stated in the preface that Par has not been implemented. Saving this critical bit of information until chapter 5 is not fair to the reader.

Reviewer:  J. W. Kyle Review #: CR116417
Bookmark and Share
 
Concurrent, Distributed, And Parallel Languages (D.3.2 ... )
 
 
Methodologies (D.2.10 ... )
 
 
Parallel Programming (D.1.3 ... )
 
 
Portability (D.2.7 ... )
 
Would you recommend this review?
yes
no
Other reviews under "Concurrent, Distributed, And Parallel Languages": Date
Tutorial: compiling concurrent languages for sequential processors
Edwards S. ACM Transactions on Design Automation of Electronic Systems 8(2): 141-187, 2003. Type: Article
Jul 18 2003
Compositional parallel programming languages
Foster I. ACM Transactions on Programming Languages and Systems 18(4): 454-476, 1996. Type: Article
Jan 1 1997
Coordination languages and their significance
Gelernter D., Carriero N. Communications of the ACM 35(2): 97-107, 1992. Type: Article
Mar 1 1993
more...

E-Mail This Printer-Friendly
Send Your Comments
Contact Us
Reproduction in whole or in part without permission is prohibited.   Copyright 1999-2024 ThinkLoud®
Terms of Use
| Privacy Policy