GPU Implementation of a Cellular Genetic Algorithm for Scheduling Dependent Tasks of Physical System Simulation Programs

Yan Zhao,Liping Chen,Gang Xie,Jianjun Zhao,Jianwan Ding
DOI: https://doi.org/10.1007/s10878-016-0007-y
2018-01-01
Journal of Combinatorial Optimization
Abstract:This paper studies the problem of efficiently scheduling dependent computational tasks on heterogeneous computing systems. Computational tasks with precedence constraints are commonly represented by a directed acyclic graph (DAG). Four commonly used algorithms including a cellular genetic algorithm (CGA) are performed for scheduling a special type of DAGs derived from physical system simulation programs. Experimental results show that CGA outperforms the other three algorithms. However, when solving large instances of the dependent task scheduling problem, which are often the case for physical system simulation programs, a CPU implementation of the genetic algorithms can be extremely time consuming. The time complexity of producing a generation with a CPU is \(O(n_{cell} \; n^{2})\), where n is the size of DAG, and \(n_{cell}\) is the size of population. To improve runtimes, this paper presents a graphics processing unit (GPU) based implementation of the genetic algorithms. The time complexity of creating a new generation with a GPU is reduced to O(n). The experimental results show that significant speedups can be achieved by harnessing the power of a modern GPU.
What problem does this paper attempt to address?