Suppose I have
>>> v
array([1, 1, 1, 1, 1, 2, 2, 2, 3, 4, 3, 4, 3, 4, 3, 4, 5, 5, 5])
Is there an efficient numpy way to find each index where the value changes? For instance, I would want some result like,
>>> index_of_changed_values(v)
[0, 5, 8, 9, 10, 11, 12, 13, 14, 15, 16]
If this is not possible with some numpy routine, what is a fast way to do it in python? It would also be useful to me to be referred to some good numpy tutorials since I am a numpy beginner.
You can get this functionality in numpy by comparing each element with it's neighbor;
to get the indices you use the "where" function
From here you can prepend the first element and add a one to get to the same indexing scheme you have in your question.
Maybe It's because Python 3.5 but the above codes did not work for me.
Looks like
v[:-1] != v[1:]
does not return aniterable
but a singlebool
.I came up with following list comprehension using
zip
andenumerate
Someone looking for solution in py3.5 might find this useful!
Similar to @kith answer, but requires less massaging of the result:
No need to prepend 0 or add 1. Example:
EDIT: as @Praveen mentioned, this fails when the last and the first elements are equal.