Title | Dynamic task scheduling using online optimization |
Publication Type | Journal Article |
Year of Publication | 2000 |
Authors | Hamidzadeh, B., L. Y. Kit, and D. J. Lilja |
Journal | Parallel and Distributed Systems, IEEE Transactions on |
Volume | 11 |
Pagination | 1151 - 1163 |
Date Published | nov. |
ISSN | 1045-9219 |
Keywords | computational complexity, database application, distributed memory systems, dynamic task scheduling, Intel Paragon distributed memory multiprocessor, memory locality, multiprocessor system, online optimization, partial schedules, performance evaluation, processor load balance, processor scheduling, resource allocation, scheduling overhead, self-adjusting dynamic scheduling, task-to-processor assignments |
Abstract | Algorithms for scheduling independent tasks on to the processors of a multiprocessor system must trade-off processor load balance, memory locality, and scheduling overhead. Most existing algorithms, however, do not adequately balance these conflicting factors. This paper introduces the self-adjusting dynamic scheduling (SADS) class of algorithms that use a unified cost model to explicitly account for these factors at runtime. A dedicated processor performs scheduling in phases by maintaining a tree of partial schedules and incrementally assigning tasks to the least-cost schedule. A scheduling phase terminates whenever any processor becomes idle, at which time partial schedules are distributed to the processors. An extension of the basic SADS algorithm, called DBSADS, controls the scheduling overhead by giving higher priority to partial schedules with more task-to-processor assignments. These algorithms are compared to two distributed scheduling algorithms within a database application on an Intel Paragon distributed memory multiprocessor system. |
URL | http://dx.doi.org/10.1109/71.888636 |
DOI | 10.1109/71.888636 |