Pairwise sorting network
Visualization of the Pairwise sorting network with 16 inputs | |
Class | Sorting algorithm |
---|---|
Data structure | Array |
Worst-case performance | parallel time |
Worst-case space complexity | non-parallel time |
Optimal | No |
The pairwise sorting network is a sorting network discovered and published by Ian Parberry in 1992 in Parallel Processing Letters.[1] The pairwise sorting network has the same size (number of comparators) and depth as the odd–even mergesort network. At the time of publication, the network was one of several known networks with a depth of . It requires comparators and has depth .
The sorting procedure implemented by the network is as follows (guided by the zero-one principle):
- Sort consecutive pairwise bits of the input (corresponds to the first layer of the diagram)
- Sort all pairs into lexicographic order by recursively sorting all odd bits and even bits separately (corresponds to the next 14 layers of the diagram)
- Sort the pairs in nondecreasing order using a specialized network (corresponds to the final layers of the diagram)
Relation to Batcher odd-even mergesort
The pairwise sorting network is very similar to the Batcher odd-even mergesort, but differs in the structure of operations. While Batcher repeatedly divides, sorts and merges increasingly longer subsequences, the pairwise method does all the subdivision first, then does all the merging at the end in the reverse sequence. In certain applications like encoding cardinality constraints, the pairwise sorting network is superior to the Batcher network.[2]
References
External links
- Sorting Networks – Archive of web page by the author.
- v
- t
- e
- Computational complexity theory
- Big O notation
- Total order
- Lists
- Inplacement
- Stability
- Comparison sort
- Adaptive sort
- Sorting network
- Integer sorting
- X + Y sorting
- Transdichotomous model
- Quantum sort
- Bubble sort
- Cocktail shaker sort
- Odd–even sort
- Comb sort
- Gnome sort
- Proportion extend sort
- Quicksort
- Selection sort
- Heapsort
- Smoothsort
- Cartesian tree sort
- Tournament sort
- Cycle sort
- Weak-heap sort
- Insertion sort
- Shellsort
- Splaysort
- Tree sort
- Library sort
- Patience sorting
- Bitonic sorter
- Batcher odd–even mergesort
- Pairwise sorting network
- Samplesort
This algorithms or data structures-related article is a stub. You can help Wikipedia by expanding it. |
- v
- t
- e