[Numpy-discussion] Numpy speed ups to simple tasks - final findings and suggestions
Fri Jan 4 00:50:37 CST 2013
On 02/01/2013 7:56 AM, Nathaniel Smith wrote:
> On Fri, Dec 21, 2012 at 7:20 PM, Raul Cota <firstname.lastname@example.org> wrote:
>> On Dec/2/2012 I sent an email about some meaningful speed problems I was
>> facing when porting our core program from Numeric (Python 2.2) to Numpy
>> (Python 2.6). Some of our tests went from 30 seconds to 90 seconds for
> Hi Raul,
> This is great work! Sorry you haven't gotten any feedback yet -- I
> guess it's a busy time of year for most people; and, the way you've
> described your changes makes it hard for us to use our usual workflow
> to discuss them.
Sorry about that.
>> These are the actual changes to the C code,
>> For bottleneck (a)
>> In general,
>> - avoid calls to PyObject_GetAttrString when I know the type is
>> List, None, Tuple, Float, Int, String or Unicode
>> - avoid calls to PyObject_GetBuffer when I know the type is
>> List, None or Tuple
> This definitely seems like a worthwhile change. There are possible
> quibbles about coding style -- the macros could have better names, and
> would probably be better as (inline) functions instead of macros --
> but that can be dealt with.
> Can you make a pull request on github with these changes? I guess you
> haven't used git before, but I think you'll find it makes things
> *much* easier (in particular, you'll never have to type out long
> awkward english descriptions of the changes you made ever again!) We
> have docs here:
> and your goal is to get to the point where you can file a "pull request":
> Feel free to ask on the list if you get stuck of course.
>> For bottleneck (b)
>> I noticed that PyFloat * Float64 resulted in an unnecessary "on the fly"
>> conversion of the PyFloat into a Float64 to extract its underlying C
>> double value. This happened in the function
>> _double_convert_to_ctype which comes from the pattern,
> This also sounds like an excellent change, and perhaps should be
> extended to ints and bools as well... again, can you file a pull
>> b.2) This is the change that may not be very popular among Numpy users.
>> I modified Float64 operations to return a Float instead of Float64. I
>> could not think or see any ill effects and I got a fairly decent speed
> Yes, unfortunately, there's no way we'll be able to make this change
> upstream -- there's too much chance of it breaking people's code. (And
> numpy float64's do act different than python floats in at least some
> cases, e.g., numpy gives more powerful control over floating point
> error handling, see np.seterr.)
I thought so. I may keep a fork of the changes for myself.
> But, it's almost certainly possible to optimize numpy's float64 (and
> friends), so that they are themselves (almost) as fast as the native
> python objects. And that would help all the code that uses them, not
> just the ones where regular python floats could be substituted
> instead. Have you tried profiling, say, float64 * float64 to figure
> out where the bottlenecks are?
Seems to be split between
- (primarily) the memory allocation/deallocation of the float64 that is
created from the operation float64 * float64. This is the reason why
float64 * Pyfloat got improved with one of my changes because PyFloat
was being internally converted into a float64 before doing the
- the rest of the time is the actual multiplication path way.
I attach an image of the profiler using the original numpy code with a
val = float64 * float64 * float64 * float64
Let me know if something is not clear.
> NumPy-Discussion mailing list
-------------- next part --------------
A non-text attachment was scrubbed...
Size: 39190 bytes
Desc: not available
Url : http://mail.scipy.org/pipermail/numpy-discussion/attachments/20130103/93fbb731/attachment-0001.png
More information about the NumPy-Discussion