gpt4 book ai didi

python - 为什么将一个列表(长度为 n)传递给 numba nopython 函数是一个 O(n) 操作

转载 作者:行者123 更新时间:2023-11-30 22:35:39 25 4
gpt4 key购买 nike

这只是一个满足我好奇心的问题,我实际上并不打算使用列表作为 numba 函数的参数。

但我想知道为什么将列表传递给 numba 函数看起来像是一个 O(n) 操作,而在纯 Python 中却是一个 O(1) 操作功能。

一些简单的示例代码:

import numba as nb

@nb.njit
def take_list(lst):
return None

take_list([1, 2, 3]) # warmup

时间安排:

for size in [10, 100, 1000, 10000, 100000, 1000000]:

lst = [0]*size
print(len(lst))
%timeit take_list(lst) # IPythons "magic" timeit

结果:

10
4.06 µs ± 26.1 ns per loop (mean ± std. dev. of 7 runs, 100000 loops each)
100
14 µs ± 360 ns per loop (mean ± std. dev. of 7 runs, 100000 loops each)
1000
109 µs ± 434 ns per loop (mean ± std. dev. of 7 runs, 10000 loops each)
10000
1.08 ms ± 17.8 µs per loop (mean ± std. dev. of 7 runs, 1000 loops each)
100000
10.7 ms ± 26.2 µs per loop (mean ± std. dev. of 7 runs, 100 loops each)
1000000
112 ms ± 383 µs per loop (mean ± std. dev. of 7 runs, 10 loops each)

最佳答案

操作 Python 列表需要调用 Python API,这在 nopython 模式下是被禁止的。 Numba 实际上将列表内容复制到自己的数据结构中,这所花费的时间与列表的大小成正比。

关于python - 为什么将一个列表(长度为 n)传递给 numba nopython 函数是一个 O(n) 操作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44489126/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com