[Numpy-discussion] efficient 3d histogram creation
Thu May 7 17:20:34 CDT 2009
after looking at it for a while, I don't see a way to easily speed it up
using pure numpy.
As a matter of fact, the behavior shown below is a little confusing. Using
fancy indexing, multiples of the same index are interpreted as a single call
to that index, probably this a for a reason that I dont currently
understand. I would think multiple calls to the same index would cause
multiple increments in the example below.
For the life of me, I can't think of how to do this 3d histogram in numpy
without a for loop.
########## example code #############
>>> a = np.arange(0,8,1).reshape((2,2,2))
>>> indx =
>>> indx = indx.reshape(4,2,3)
>>> a[indx[:,:,0], indx[:,:,1], indx[:,:,2]]+=1
>>> indx2 = np.zeros((4,2,3)).astype(np.uint8)
>>> a[indx2[:,:,0], indx2[:,:,1], indx2[:,:,2]]+=1
On Thu, May 7, 2009 at 5:35 PM, Charles R Harris
> 2009/5/7 Dag Sverre Seljebotn <firstname.lastname@example.org>
>> Stéfan van der Walt wrote:
>> > 2009/5/7 Chris Colbert <email@example.com>:
>> >> This was really my first attempt at doing anything constructive with
>> >> It was actually unbelievably easy to work with. I think i spent less
>> >> working on this, than I did trying to find an optimized solution using
>> >> numpy and python.
>> > One aspect we often overlook is how easy it is to write a for-loop in
>> > comparison to vectorisation. Besides, for-loops are sometimes easier
>> > to read as well!
>> > I think the Cython guys are planning some sort of templating, but I'll
>> > CC Dag so that he can tell us more.
>> We were discussing how it would/should look like, but noone's committed
>> to implementing it so it's pretty much up in the blue I think -- someone
>> might jump in and do it next week, or it might go another year, I can't
>> While I'm here, also note in that code Chris wrote that you want to pay
>> attention to the change of default division semantics on Cython 0.12
>> (especially for speed).
> Hi Dag,
> Numpy can now do separate compilations with controlled export of symbols
> when the object files are linked together to make a module. Does Cython have
> anyway of controlling the visibility of symbols or should we just include
> the right files in Numpy to get the needed macros?
> Numpy-discussion mailing list
-------------- next part --------------
An HTML attachment was scrubbed...
More information about the Numpy-discussion