[Numpy-discussion] Funky vectorisation question

Dan Goodman dg.gmane at thesamovar.net
Wed Apr 29 17:49:46 EDT 2009


David Warde-Farley wrote:
> On 29-Apr-09, at 5:06 PM, Dan Goodman wrote:
> 
>> Here's the problem I want to write vectorised code for. I start with  
>> an
>> array of indices, say I=array([0,1,0,2,0,1,4]), and I want to come up
>> with an array C that counts how many times each index has been seen so
>> far if you were counting through the array from the beginning to the
>> end, e.g. for that I, C=array([0,0,1,0,2,1,0]). This is easy enough to
>> do with a C loop, but trickier to do just with numpy. Any ideas?
> 
> How about this:
> 
> In [28]: I = array([0,1,0,2,0,1,4])
> 
> In [29]: C = empty(len(I),dtype=int)
> 
> In [30]: for idx in unique(I):
>     ....:     V = I == idx
>     ....:     C[V] = arange(len(V))
>     ....:
> 
> In [31]: C
> Out[31]: array([0, 0, 1, 0, 2, 1, 0])
> 
> David

Thanks David, that's nice but unfortunately that Python loop will kill 
me. I'm thinking about some simulation code I'm writing where this 
operation will be carried out many, many times, with large arrays I. I 
figure I need to keep the Python overheads to a fixed cost to get good 
performance.

Dan




More information about the NumPy-Discussion mailing list