A VLSI sorter of sizeO(n) can sortn elements in linear time when the input and output time are taken into account. If the input contains more thann elements, some prepocessing has to be performed. A VLSI partition algorithm that provides a solution to this problem is presented. The algorithm partitions the input data into two smaller parts as the quicksort algorithm does. That is, the elements of the first part will be smaller than the elements of the second part. The partition is repeated until the parts are small enough to fit in the sorter. It is shown that the average number of times each element must go through the partitioner isO(logk) for a data file of sizekn wheren is the size of the sorter. In the worst case where the partitioner fails to divide the input evenly, the elements must goO(k) times through the partitioner like in the quicksort algorithm. The partitioner can also be used, with simple modifications, as a sorter, a stack, a queue, or as a priority queue. Other advantages of the VLSI algorithm are also discussed.
[1]
David J. DeWitt,et al.
A taxonomy of parallel sorting
,
1984,
CSUR.
[2]
Charles E. Leiserson.
Systolic Priority Queues
,
1979
.
[3]
P.P.G. Kramer,et al.
Systolic computation and VLSI
,
1982
.
[4]
Lynn Conway,et al.
Introduction to VLSI systems
,
1978
.
[5]
H. T. Kung,et al.
Sorting on a mesh-connected parallel computer
,
1977,
CACM.
[6]
Donald Ervin Knuth,et al.
The Art of Computer Programming
,
1968
.
[7]
Chak-Kuen Wong,et al.
A "Zero-Time" VLSI Sorter
,
1983,
IBM J. Res. Dev..