Fritz Henglein has done some interesting work on fast sorting/grouping. I think Generic Discrimination
Sorting and Partitioning Unshared Data in Linear Time[1] is the main paper. Ed Kmett took those ideas and refined them into the discrimination[2] library for Haskell, and gave a very interesting tech talk about it[3].