A comparison of task pools for dynamic load balancing of irregular algorithms: Research Articles

  • Authors:
  • Matthias Korch;Thomas Rauber

  • Affiliations:
  • Faculty of Mathematics, Physics and Computer Science, University of Bayreuth, Bayreuth, Germany;Faculty of Mathematics, Physics and Computer Science, University of Bayreuth, Bayreuth, Germany

  • Venue:
  • Concurrency and Computation: Practice & Experience
  • Year:
  • 2003

Quantified Score

Hi-index 0.00

Visualization

Abstract

Since a static work distribution does not allow for satisfactory speed-ups of parallel irregular algorithms, there is a need for a dynamic distribution of work and data that can be adapted to the runtime behavior of the algorithm. Task pools are data structures which can distribute tasks dynamically to different processors where each task specifies computations to be performed and provides the data for these computations. This paper discusses the characteristics of task-based algorithms and describes the implementation of selected types of task pools for shared-memory multiprocessors. Several task pools have been implemented in C with POSIX threads and in Java. The task pools differ in the data structures to store the tasks, the mechanism to achieve load balance, and the memory manager used to store the tasks. Runtime experiments have been performed on three different shared-memory systems using a synthetic algorithm, the hierarchical radiosity method, and a volume rendering algorithm. Copyright © 2004 John Wiley & Sons, Ltd.