У меня есть следующий цикл for для построения списка значений:
p = 7
A = []
for i in range(0, 10**p):
A.append(i**3 + i**2)
Чтобы ускорить создание списка, я создал его в виде массива Numpy, используя векторизованный подход. Этот подход намного быстрее, чем эквивалентный цикл for, особенно для больших значений p
, что увеличивает диапазон.
import numpy as np
from numba import autojit
p = 7
m = np.arange(0, 10**p)
D = np.empty(len(m))
D = m**3 + m**2
Чтобы еще больше ускорить создание массива, я решил попробовать использовать пакет Numba. Ниже моя текущая попытка.
@autojit
def func(a):
a = np.asarray(a)
n = np.arange(0, 10**p)
a = np.append(a, n**3 + n**2)
return a
e = []
E = func(e)
К сожалению, я не вижу никакого прироста производительности от использования Numba, который почти в 3 раза медленнее, чем векторизованный подход, использующий только Numpy.
Любые предложения о том, как использовать Numba для этого?
@autojit
будет иметь огромное значение в подходе с цикломfor
- person Saullo G. P. Castro   schedule 14.10.2014for
в функцию с autojit? Можете ли вы отправить ответ с таким подходом и сравнить время? - person wigging   schedule 15.10.2014