What you actually need to do is get the inverse of the sorting order of your array:
import numpy as np
x = np.random.rand(10)
y = np.empty(x.size,dtype=np.int64)
y[x.argsort()] = np.arange(x.size)
Example run (in ipython):
In [367]: x
Out[367]:
array([ 0.09139335, 0.29084225, 0.43560987, 0.92334644, 0.09868977,
0.90202354, 0.80905083, 0.4801967 , 0.99086213, 0.00933582])
In [368]: y
Out[368]: array([1, 3, 4, 8, 2, 7, 6, 5, 9, 0])
Alternatively, if you want to get the number of elements greater than each corresponding element in x
, you have to reverse the sorting from ascending to descending. One possible option to do this is to simply swap the construction of the indexing:
y_rev = np.empty(x.size,dtype=np.int64)
y_rev[x.argsort()] = np.arange(x.size)[::-1]
another, as @unutbu suggested in a comment, is to map the original array to the new one:
y_rev = x.size - y - 1