Lab Week 12: Sorting Networks
Outline
- Simple Sorting Algorithms
- Sorting Networks
- Sorting Activity
Last Time
Sorting by Divide and Conquer
- Merge sort
- sort left half
- sort left half
- merge sorted halves
- Quicksort
- pick pivot
- split according to pivot
- left half less than pivot
- right half at least pivot
- sort left half
- sort right half
Sorting Networks
Another view of sorting in parallel
Insertion Sort, Revisited
for (int i = 1; i < data.length; ++i) {
for (int j = i; j > 0; --j) {
if (data[j-1] > data[j]) {
swap(data, j-1, j)
}
}
}
Appealing Features of Insertion Sort
for (int i = 1; i < data.length; ++i) {
for (int j = i; j > 0; --j) {
if (data[j-1] > data[j]) {
swap(data, j-1, j)
}
}
}
- Only modifications are (adjacent) swaps
- Access pattern is independent of input
- inputs always read/compared in same order
- only difference between execution is outcomes of swaps
Comparators: Visualizing Swaps
if (data[i] > data[j]) {
swap(data, i, j)
}
data:image/s3,"s3://crabby-images/ed143/ed14351a17e9e4170e6a873278d52637654f930a" alt=""
Comparator Swap
data:image/s3,"s3://crabby-images/34f3a/34f3ab525a1a02250ab37370187ac281e29f492b" alt=""
Comparator No Swap
data:image/s3,"s3://crabby-images/03c0c/03c0ca3cc85e66c098dd123b86ed6ec3d37b0a93" alt=""
Sorting Array of Two Elements
data:image/s3,"s3://crabby-images/61ea4/61ea414551dc5f026c75823246bfbaa46dbc8b4a" alt=""
Insertion Sort
for (int i = 1; i < data.length; ++i) {
for (int j = i; j > 0; --j) {
if (data[j-1] > data[j]) {
swap(data, j-1, j)
}
}
}
data:image/s3,"s3://crabby-images/a4452/a44525d95ee139d1df8c3eb3af4d828106b9327c" alt=""
Insertion Sort: i = 1
data:image/s3,"s3://crabby-images/9bac4/9bac409637fe72b85abcf161f4320806d4ae2c66" alt=""
Insertion Sort: i = 2
data:image/s3,"s3://crabby-images/63095/63095d5da9024736fd1ea91ae794788d95309b9d" alt=""
Insertion Sort: i = 3
data:image/s3,"s3://crabby-images/fcc7a/fcc7ab01fcfbc5dc9d050fbeb3b9e01bb1c14676" alt=""
Which Operations can be Parallelized?
data:image/s3,"s3://crabby-images/fcc7a/fcc7ab01fcfbc5dc9d050fbeb3b9e01bb1c14676" alt=""
Parallelism
data:image/s3,"s3://crabby-images/dead9/dead9df208102d59c9a60e73c7660a35df5fde41" alt=""
Cleaner Parallel Representation
data:image/s3,"s3://crabby-images/f8b52/f8b52c8e9eefda3ec3bdca44b1833d3c10113e7f" alt=""
Depth
data:image/s3,"s3://crabby-images/93f8d/93f8dc0f0ebdc8f2179c502e16c8cf0223ceb448" alt=""
Insertion Sort: Larger Instance
data:image/s3,"s3://crabby-images/38c0b/38c0b0590489842ab0f1f7dcd3086ae8509596b5" alt=""
Done In Parallel?
data:image/s3,"s3://crabby-images/38c0b/38c0b0590489842ab0f1f7dcd3086ae8509596b5" alt=""
Done In Parallel!
data:image/s3,"s3://crabby-images/b76d3/b76d35b1007a65303f4574441a327ddaf8c0497f" alt=""
Cleaned Up
data:image/s3,"s3://crabby-images/f7058/f70589d11eeafa91c1a6b677e2c34b03bb5b2b1f" alt=""
Parallel Depth?
data:image/s3,"s3://crabby-images/31226/312268d27c5c6ff4580b29356b72e8176473dacf" alt=""
Bubble Sort
Consider:
for (int m = data.length - 1; m > 0; --m) {
for (int i = 0; i < m; ++i) {
if (data[i] > data[i+1]) {
swap(data, i, i+1)
}
}
}
Can we make a sorting network corresponding to bubble sort?
Bubble Sort: m = 6
data:image/s3,"s3://crabby-images/a8982/a8982e3afee91ae234510653e5d3d9e01fb6584f" alt=""
Bubble Sort: m = 5
data:image/s3,"s3://crabby-images/46670/46670a3720c0a6b64bce8e8cee45e99bb5e308a7" alt=""
Bubble Sort: m = 4
data:image/s3,"s3://crabby-images/0c2cc/0c2cc985a7ff2e3bee317fa22444df6f877db1f4" alt=""
Bubble Sort: m = 3
data:image/s3,"s3://crabby-images/0522d/0522dc7bca39ea5c63fdefcdb1179d8ad371f4ba" alt=""
Bubble Sort: m = 2
data:image/s3,"s3://crabby-images/4afec/4afec329ece8b0bfd07781d6400d5df5d1231888" alt=""
Bubble Sort Network
data:image/s3,"s3://crabby-images/4b907/4b907e54d0dbef8c152ad7d19403783a107c3167" alt=""
Bubble Sort Parallelized?
data:image/s3,"s3://crabby-images/4b907/4b907e54d0dbef8c152ad7d19403783a107c3167" alt=""
Does it Look Familiar?
data:image/s3,"s3://crabby-images/63580/6358043edc1435b8d89428ecdbec39a9f97fd36d" alt=""
Applications
- Sorting networks can be efficiently implemented in hardware
- can sort fixed number of items much faster than software sorting
- Depth corresponds to latency
- smaller depth = faster computations
Activity
Find a minimum depth sorting networks for small $n$!
Minimum Depth for $n = 4$?
Smaller Depth for $n = 6$?
Current State
What is known:
- Optimal depth sorting networks for $n \leq 17$
What is not known:
- Optimal depth sorting networks for $n \geq 18$