exec'ing functions

Mel Wilson mwilson at the-wire.com
Thu Dec 9 18:10:12 EST 2004


In article <5SPtd.210910$HA.146444 at attbi_s01>,
Steven Bethard <steven.bethard at gmail.com> wrote:
>Jeff Shannon wrote:
>> I was referring to functions which have an internal exec statement, not
>> functions which are created entirely within an exec -- i.e., something
>> like this:
>
>Thanks for the clarification.  Here's the results for some functions
>with internal exec statements:
>
> > cat fib.py
>def fib1(n):
>     a, b = 0, 1
>     while True:
>         a, b = b, a + b
>         yield a
>
>
>exec """\
>def fib2(n):
>     a, b = 0, 1
>     while True:
>         a, b = b, a + b
>         yield a
>"""
>
>def fib3(n):
>     a, b = 0, 1
>     while True:
>         exec "a, b = b, a + b"
>         yield a
>
>def fib4(n):
>     exec "a, b = 0, 1"
>     while True:
>         exec "a, b = b, a + b"
>         yield a
>
> >
> > python -m timeit -s "import fib" "fib.fib1(100)"
>1000000 loops, best of 3: 0.71 usec per loop
>
> > python -m timeit -s "import fib" "fib.fib2(100)"
>1000000 loops, best of 3: 0.678 usec per loop
>
> > python -m timeit -s "import fib" "fib.fib3(100)"
>1000000 loops, best of 3: 0.826 usec per loop
>
> > python -m timeit -s "import fib" "fib.fib4(100)"
>1000000 loops, best of 3: 0.821 usec per loop
>
>I'm not sure I'd say they're *much* slower, but you're right; they're
>definitely slower.

   The thing is, that once you drop local-namespace
optimization, the entire function gets slowed down, possibly
by 40%:



def fib5 (n):
    a, b, i = 0, 1, n
    while i > 0:
        a, b = b, a+b
        yield a
        i -= 1


def fib6 (n):
    exec "a, b, i = 0, 1, n"
    while i > 0:
        a, b = b, a+b
        yield a
        i -= 1



f:\home\mwilson\projects\python>python  e:\bin\python23\lib\timeit.py -s "import
 fib" "[i for i in fib.fib5(100)]"
1000 loops, best of 3: 1.95e+003 usec per loop

f:\home\mwilson\projects\python>python  e:\bin\python23\lib\timeit.py -s "import
 fib" "[i for i in fib.fib6(100)]"
100 loops, best of 3: 2.82e+003 usec per loop


        Regards.    Mel.



More information about the Python-list mailing list