Parallel Particle Swarm Optimization Algorithm Based On Graphic Processing Units

Ying Tan,You Zhou
DOI: https://doi.org/10.1007/978-3-642-17390-5_6
2011-01-01
Abstract:A novel parallel approach to implement particle swarm optimization(PSO) algorithm on graphic processing units(GPU) in a personal computer is proposed in this chapter. By using the general-purpose computing ability of CPU and under the software platform of compute unified device architecture(CUDA) which is developed by NVIDIA, the PSO algorithm can be executed in parallel on the CPU. The process of fitness evaluation, as well as the updating of the velocity and the position of all the particles in the swarm are parallelized and described in details in the context of this chapter. Experiments are conducted by running the PSO both on the CPU and the CPU, respectively, to optimize several benchmark test functions. The running time of the PSO based on GPU(GPU-PSO, for short) is greatly shortened compared to that of the PSO based on CPU(CPU-PSO, for short). A 40x speedup can be obtained by our implemented GPU-PSO on a display card of NVIDIA Geforce 9800GT, with the same optimizing performance. Compared to the CPU-PSO, the GPU-PSO has special speed advantages on large-scale population and high-dimensional problems which are often happened and widely used in a lot of real-world optimization applications.
What problem does this paper attempt to address?