An advanced environment supporting structured parallel programming in Java

  • Authors:
  • M. Aldinucci;M. Danelutto;P. Teti

  • Affiliations:
  • Department of Computer Science, University of Pisa, V. Buonarroti 2, 56127 Pisa, Italy;Department of Computer Science, University of Pisa, V. Buonarroti 2, 56127 Pisa, Italy;Department of Computer Science, University of Pisa, V. Buonarroti 2, 56127 Pisa, Italy

  • Venue:
  • Future Generation Computer Systems - Tools for program development and analysis
  • Year:
  • 2003

Quantified Score

Hi-index 0.00

Visualization

Abstract

In this work we present Lithium, a pure Java structured parallel programming environment based on skeletons (common, reusable and efficient parallelism exploitation patterns). Lithium is implemented as a Java package and represents both the first skeleton based programming environment in Java and the first complete skeleton based Java environment exploiting macro-data flow implementation techniques.Lithium supports a set of user code optimizations which are based on skeleton rewriting techniques. These optimizations improve both absolute performance and resource usage with respect to original user code. Parallel programs developed using the library run on any network of workstations provided the workstations support plain JRE. The paper describes the library implementation, outlines the optimization techniques used and eventually presents the performance results obtained on both synthetic and real applications.