A novel sorting algorithm for many-core architectures based on adaptive bitonic sort
Department of Computer Science, CAU Kiel, Kiel, Germany
IEEE International Parallel & Distributed Processing Symposium (IPDPS 2012), 2012
@article{peters2012novel,
title={A novel sorting algorithm for many-core architectures based on adaptive bitonic sort},
author={Peters, H. and Schulz-Hildebrandt, O. and Luttenberger, N. and Kiel, CAU},
year={2012}
}
Adaptive bitonic sort is a well known merge-based parallel sorting algorithm. It achieves optimal complexity using a complex tree-like data structure called a bitonic tree. Due to this, using adaptive bitonic sort together with other algorithms usually implies converting bitonic trees to arrays and vice versa. This makes adaptive bitonic sort inappropriate in the context of hybrid sorting algorithms where frequent switches between algorithms are performed. In this article we present a novel optimal sorting algorithm that is based on an approach similar to adaptive bitonic sort. Our approach does not use bitonic trees but uses the input array together with some additional information. Using this approach it is trivial to switch between adaptive bitonic sort and other algorithms. We present an implementation of a hybrid algorithm for GPUs based on bitonic sort and our novel algorithm. This implementation turns out to be the fastest comparison-based sorting algorithm for GPUs found in literature.
February 24, 2012 by hgpu