How can I sort an array of points/vectors by counter-clockwise increasing angle from a given axis vector?
For example:

If 0 is the axis vector I would expect the sorted array to be in the order 2, 3, 1.
I’m reasonably sure it’s possible to do this with cross products, a custom comparator, and std::sort().
Yes, you can do it with a custom comparator based on the cross-product. The only problem is that a naive comparator won’t have the transitivity property. So an extra step is needed, to prevent angles either side of the reference from being considered close.
This will be MUCH faster than anything involving trig. There’s not even any need to normalize first.
Here’s the comparator:
Demo: http://ideone.com/YjmaN