Artigo Revisado por pares

A comparison of task pools for dynamic load balancing of irregular algorithms

2003; Wiley; Volume: 16; Issue: 1 Linguagem: Inglês

10.1002/cpe.745

ISSN

1532-0634

Autores

Matthias Korch, Thomas Rauber,

Tópico(s)

Advanced Data Storage Technologies

Resumo

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.

Referência(s)