2012年6月27日水曜日

nzmath.arith1.log is faster than math.log

nzmath.arith1.log(n) is faster than int(math.log(n)) if base is 2:
$ python -m timeit -s 'import math' '[int(math.log(i, 2)) for i in range(1, 10000000, 1000)]'
10 loops, best of 3: 91.6 msec per loop
$ python -m timeit -s 'import nzmath.arith1' '[nzmath.arith1.log(i, 2) for i in range(1, 10000000, 1000)]'
10 loops, best of 3: 32.5 msec per loop
It's true also for base 10:
$ python -m timeit -s 'import math' '[int(math.log(i, 10)) for i in range(1, 1000000000, 100000)]'
10 loops, best of 3: 93.1 msec per loop
$ python -m timeit -s 'import nzmath.arith1' '[nzmath.arith1.log(i, 10) for i in range(1, 1000000000, 100000)]'
100 loops, best of 3: 16.5 msec per loop
It isn't fair if I stop here.
$ python -m timeit -s 'import math' '[int(math.log(i, 3)) for i in range(1, 1000000000, 100000)]'
10 loops, best of 3: 93.2 msec per loop
$ python -m timeit -s 'import nzmath.arith1' '[nzmath.arith1.log(i, 3) for i in range(1, 1000000000, 100000)]'
10 loops, best of 3: 121 msec per loop