homepage

This issue tracker has been migrated to GitHub , and is currently read-only.
For more information, see the GitHub FAQs in the Python's Developer Guide.

classification
Title: Performance regression in 2.5
Type: behavior Stage:
Components: Interpreter Core Versions: Python 2.5
process
Status: closed Resolution: wont fix
Dependencies: Superseder:
Assigned To: rhettinger Nosy List: amaury.forgeotdarc, georg.brandl, ggenellina, inducer, rhettinger, tim.peters
Priority: normal Keywords:

Created on 2007年08月28日 15:06 by inducer, last changed 2022年04月11日 14:56 by admin. This issue is now closed.

Files
File name Uploaded Description Edit
periodic_test.py inducer, 2007年08月28日 15:06
Messages (6)
msg55366 - (view) Author: Andreas Kloeckner (inducer) Date: 2007年08月28日 15:06
The attached program uncovers a two-fold performance regression in
Python 2.5 with respect to Python 2.4. Below, the "element-wise" case
goes from 2.5 seconds in 2.4 to about 4 in 2.5. Since that's a pretty
serious increase, I thought I'd point it out.
$ python2.5 periodic_test.py
elwise 3.91989398003
collective 1.21577095985
$ python2.4 periodic_test.py
elwise 2.50014710426
tuplewise 1.35589385033 
msg55547 - (view) Author: Gabriel Genellina (ggenellina) Date: 2007年09月01日 02:01
I've narrowed the problem to the usage of generator expressions. 
Generator expressions appear to be MUCH slower on 2.5 than on 2.4.
>python -m timeit "tuple([1 for _ in xrange(3)])"
2.4 -> 2.23us
2.5 -> 2.31us (a bit slower, but not so much)
>python -m timeit "tuple(1 for _ in xrange(3))"
2.4 -> 3.32us
2.5 -> 8.03us (240% slower than 2.4)
It appears to be a fixed cost, or startup cost, of the generator 
expression; differences get smaller when building large tuples (but 
always Python 2.5 runs slower than 2.4)
msg55610 - (view) Author: Georg Brandl (georg.brandl) * (Python committer) Date: 2007年09月03日 07:32
May this be a byproduct of the new generator features in 2.5?
msg57875 - (view) Author: Amaury Forgeot d'Arc (amaury.forgeotdarc) * (Python committer) Date: 2007年11月27日 18:04
The slowdown is due to the new function _PyObject_LengthHint: on my
Win2K machine, 
the command
 python -m timeit "tuple(1 for _ in xrange(3))"
answers:
 100000 loops, best of 3: 4.14 usec per loop
By adding a line "return rv;" on the second line of
_PyObject_LengthHint, I get:
 100000 loops, best of 3: 2.71 usec per loop
Should we disable this function for some known built-in types?
msg57876 - (view) Author: Raymond Hettinger (rhettinger) * (Python committer) Date: 2007年11月27日 18:12
I'll take a look at it next week -- want to think through the various 
cases. The current setup provides nice speedups when the length_hint 
is available. Possibly, it may be worthwhile to skip that check when 
the input is a generator. For the most part, I'm more concerned about 
the inner-loop time than the constant startup time outside the loop.
msg57878 - (view) Author: Raymond Hettinger (rhettinger) * (Python committer) Date: 2007年11月27日 18:41
FWIW, the 2.4 to 2.5 timing difference came from renaming __len__ to 
__length_hint__. This was at Guido's request so that the value of bool
(iter(obj)) would always be True. The consequence of the change was 
that we lost the fast slot lookup for __len__ and instead have to do a 
dictionary based attribute lookup.
For the most part, I don't care about the overhead as it is constant. 
The inner-loop cost dominates. If you do care, the choices are to add 
some ugly, hackish specific type checks to bypass the attribute lookup 
in cases like generator objects where we know the type is absent. A 
more general, cleaner solution is to add a new slot for a length hint. 
Personally, I would rather leave this as is and live with the small 
constant lookup time. If you concur, please close this report. If 
not, please submit a patch for adding a new slot (model the code after 
that in PyObject_Size()).
History
Date User Action Args
2022年04月11日 14:56:26adminsetgithub: 45386
2008年01月14日 23:27:52rhettingersetstatus: open -> closed
resolution: wont fix
2007年11月27日 18:41:58rhettingersetmessages: + msg57878
2007年11月27日 18:12:26rhettingersetmessages: + msg57876
2007年11月27日 18:04:17amaury.forgeotdarcsetnosy: + amaury.forgeotdarc
messages: + msg57875
2007年11月27日 17:37:18rhettingersetassignee: tim.peters -> rhettinger
nosy: + rhettinger
2007年09月17日 08:01:08jafosetpriority: normal
assignee: tim.peters
nosy: + tim.peters
2007年09月03日 07:32:32georg.brandlsetnosy: + georg.brandl
messages: + msg55610
2007年09月01日 02:01:49ggenellinasetnosy: + ggenellina
messages: + msg55547
components: - Library (Lib)
2007年08月28日 15:06:24inducercreate

AltStyle によって変換されたページ (->オリジナル) /