This commit is contained in:
guanjihuan 2025-03-15 00:00:04 +08:00
parent 7635346f96
commit 90d2b600e4
3 changed files with 92 additions and 55 deletions

View File

@ -1,42 +0,0 @@
from numba import jit
import numpy as np
import time
def for_sum(numpy_array):
sum = 0
for number in numpy_array:
sum += number
return sum
@jit
def numba_for_sum(numpy_array):
sum = 0
for number in numpy_array:
sum += number
return sum
numpy_array = np.arange(0,2e8,1)
start = time.time()
result = sum(numpy_array)
end = time.time()
print('\nresult:', result)
print('python中sum()函数求和时间:', end - start)
start = time.time()
result = np.sum(numpy_array)
end = time.time()
print('\nresult:', result)
print('numpy.sum()函数求和时间:', end - start)
start = time.time()
result = for_sum(numpy_array)
end = time.time()
print('\nresult:', result)
print('for循环求和numpy数组的时间', end - start)
start = time.time()
result = numba_for_sum(numpy_array)
end = time.time()
print('\nresult:', result)
print('numba加速for循环求和numpy数组的时间', end - start, '\n')

View File

@ -0,0 +1,78 @@
from numba import jit
import numpy as np
import time
numpy_array = np.arange(0,1e5,1)
times = 1000
def for_sum(numpy_array):
sum = 0
for number in numpy_array:
sum += number
return sum
start = time.time()
for _ in range(times):
result = for_sum(numpy_array)
end = time.time()
print('for循环求和时间', end - start)
start = time.time()
for _ in range(times):
result = sum(numpy_array)
end = time.time()
print('sum()函数求和时间:', end - start)
start = time.time()
for _ in range(times):
result = np.sum(numpy_array)
end = time.time()
print('numpy.sum()函数求和时间:', end - start)
print()
@jit
def numba_for_sum(numpy_array):
sum = 0
for number in numpy_array:
sum += number
return sum
@jit
def numba_np_sum(numpy_array):
result = np.sum(numpy_array)
return result
@jit(nopython=True)
def numba_nopython_np_sum(numpy_array):
result = np.sum(numpy_array)
return result
@jit(nopython=True, parallel=True)
def numba_nopython_parallel_np_sum(numpy_array):
result = np.sum(numpy_array)
return result
start = time.time()
for _ in range(times):
result = numba_for_sum(numpy_array)
end = time.time()
print('numba + for循环求和时间', end - start)
start = time.time()
for _ in range(times):
result = numba_np_sum(numpy_array)
end = time.time()
print('numba + numpy.sum()函数求和时间:', end - start)
start = time.time()
for _ in range(times):
result = numba_nopython_np_sum(numpy_array)
end = time.time()
print('numba(nopython) + numpy.sum()函数求和时间:', end - start)
start = time.time()
for _ in range(times):
result = numba_nopython_parallel_np_sum(numpy_array)
end = time.time()
print('numba(nopython,parallel) + numpy.sum()函数求和时间:', end - start)

View File

@ -3,6 +3,9 @@ from numba import prange
import time
import numpy as np
numpy_array = np.arange(0,1e5,1)
times = 1000
def for_sum(numpy_array):
sum = 0
for number in numpy_array:
@ -30,28 +33,26 @@ def numba_for_sum_3(numpy_array):
sum += numpy_array[i]
return sum
numpy_array = np.arange(0,1e9,1)
start = time.time()
result = for_sum(numpy_array)
for _ in range(times):
result = for_sum(numpy_array)
end = time.time()
print('\nresult:', result)
print('for循环时间', end - start)
start = time.time()
result = numba_for_sum_1(numpy_array)
for _ in range(times):
result = numba_for_sum_1(numpy_array)
end = time.time()
print('\nresult:', result)
print('@jit时间', end - start, '\n')
print('@jit时间', end - start)
start = time.time()
result = numba_for_sum_2(numpy_array)
for _ in range(times):
result = numba_for_sum_2(numpy_array)
end = time.time()
print('\nresult:', result)
print('@jit(nopython=True)时间:', end - start, '\n')
print('@jit(nopython=True)时间:', end - start)
start = time.time()
result = numba_for_sum_3(numpy_array)
for _ in range(times):
result = numba_for_sum_3(numpy_array)
end = time.time()
print('\nresult:', result)
print('@jit(nopython=True, parallel=True)时间:', end - start, '\n')
print('@jit(nopython=True, parallel=True)时间:', end - start)