Inline generator expressions with Cython
Besides any() and all(), Cython also has support for inline generator expressions in sum() now - and it’’s fast!
# CPython 2.6.5: timeit "sum(i for i in xrange(10000))" 1000 loops, best of 3: 584 usec per loop
# Cython 0.13-pre:
def range_sum_typed(int N):
cdef int result = sum(i for i in range(N))
return result
timeit "range_sum_typed(10000)"
100000 loops, best of 3: 2 usec per loop
Obviously a really stupid benchmark, but still - that’’s what I call a difference!
Here’’s another benchmark for looping over a fixed list of Python integers instead:
# CPython 2.6.5: timeit -s "r=range(10000)" "sum((i*i for i in r), 100)" 1000 loops, best of 3: 868 usec per loop
# Cython 0.13-pre:
def typed_sum_squares(seq, int start):
cdef long i, result
result = sum((i*i for i in seq), start)
return result
timeit -s "r=range(10000)" "typed_sum_squares(r, 100)"
10000 loops, best of 3: 49.9 usec per loop
Not exactly what I”d call “closer”.