栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

为什么numba比numpy快?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

为什么numba比numpy快?

我认为这个问题突出了(某种程度上)从高级语言调用预编译函数的局限性。假设在C ++中,您编写如下内容:

for (int i = 0; i != N; ++i) a[i] = b[i] + c[i] + 2 * d[i];

编译器会在编译时看到整个表达式。它可以在这里做很多非常聪明的事情,包括优化临时文件(以及循环展开)。

但是在python中,请考虑发生了什么:当您使用numpy时,每个``+”都会在np数组类型上使用运算符重载(它们只是连续内存块的薄包装,即低级数组),并调出到一个fortran(或C
++)函数,该函数可以非常快速地执行添加操作。但是它只是做一个加法,并吐出一个临时值。

我们可以看到,虽然numpy很棒,方便且相当快,但它却使速度变慢,因为虽然看起来它正在调用一种快速的编译语言来进行艰苦的工作,但编译器却看不到整个程序,只喂一些孤立的小片段。这对编译器非常不利,特别是现代的编译器,它们非常聪明,当编写良好的代码时,每个周期可以退出多个指令。

另一方面,Numba使用了jit。因此,在运行时,它可以确定不需要临时工,并对其进行优化。基本上,Numba可以将程序作为一个整体进行编译,numpy只能调用本身已预先编译的小原子块。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/611958.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号