Вот результаты синхронизации:
lebigot@weinberg ~ % python -m timeit 'abs(3.15)'
10000000 loops, best of 3: 0.146 usec per loop
lebigot@weinberg ~ % python -m timeit -s 'from numpy import abs as nabs' 'nabs(3.15)'
100000 loops, best of 3: 3.92 usec per loop
numpy.abs()
медленнее, чем abs()
, поскольку он также обрабатывает массивы Numpy: он содержит дополнительный код, обеспечивающий эту гибкость.
ОднакоNumpy быстрее для массивов:
lebigot@weinberg ~ % python -m timeit -s 'a = [3.15]*1000' '[abs(x) for x in a]'
10000 loops, best of 3: 186 usec per loop
lebigot@weinberg ~ % python -m timeit -s 'import numpy; a = numpy.empty(1000); a.fill(3.15)' 'numpy.abs(a)'
100000 loops, best of 3: 6.47 usec per loop
(PS: '[abs(x) for x in a]'
медленнее в Python 2.7, чем лучше map(abs, a)
, что примерно на 30% быстрее, что все ещенамного медленнее, чем NumPy.)
Таким образом, numpy.abs()
не займет намного больше времени для 1000 элементов, чем для 1 одиночного плавающего!