815902569f6a467a99304f9ac1482386.png


1 numba介绍


numba是一个用于编译Python数组和数值计算函数的编译器,这个编译器能够大幅提高直接使用Python编写的函数的运算速度。


numba使用LLVM编译器架构将纯Python代码生成优化过的机器码,通过一些添加简单的注解,将面向数组和使用大量数学的python代码优化到与c,c++和Fortran类似的性能,而无需改变Python的解释器。numba的编译方式如下图所示:


415553959bb3466abc7861b8a7d91756.png


为什么选择numba?


选择Numbade 原因很简单,不需要为了获得一些的加速来改变代码,我们只需要添加一个装饰器到Python函数中即可完成加速,而且加速效果与cython代码相当。


2.numba的使用方法


numba对代码进行加速时,给要优化的函数加上@jit优化器即可。使用jit的时候可以让numba来决定什么时候以及怎么做优化。如下简单的例子所示:


from numba import jit
def f(x, y):
    return x + y


这段代码的计算在被调用是第一次执行,numba将在调用期间推断参数类型,然后基于这个信息生成优化后的代码。numba也能够基于输入的类型编译生成特定的代码。例如,对于上面的代码,传入整数和浮点数作为参数将会生成不同的代码:


8dc3680a7e304dfd9a3cc78ae379f5cc.png


Numba编译的函数可以调用其他编译函数。 例如:


@jit
def hypot(x, y):
    return math.sqrt(square(x) + square(y))


我们现在看一个例子:


from numba import jit
import time
def foo():
    x = []
    for a in range(100000000):
        x.append(a)
def foo_withoutfit():
    y = []  
    for b in range(100000000):
        y.append(b)


现在我们定义相同的方法,实现的功能也是一样的,一个是利用numba进行加速,一个没有加速,我们看下他们的运行时间:


dcf9d2822062458f816b634eb5f93032.png


从结果中可以看出,当我们使用了numba进行加速,速度提升了10倍以上。


总结


1.numba是进行python加速的工具包

2.在要进行加速的python函数中添加装饰器@jit即可实现代码的加速

【报错解决】ERROR: pip‘s dependency resolver does not currently take into account all the packages numpy 报错:”AttributeError: module ‘numpy‘ has no attribute ‘bool‘“ fatal: unable to access ‘https://github xxxxxxxxx的解决方法 MMdetection框架速成系列 第03部分:简述整体构建细节与模块+训练测试模块流程剖析+深入解析代码模块与核心实现 Linux使用解压命令unzip报错:unzip: cannot find zipfile directory in one of xxx.zip 智慧交通day01-算法库03:cv.dnn
使用方便。DNN模块提供了内建的CPU和GPU加速,无需依赖第三方库,若项目中之前使用了OpenCV,那么通过DNN模块可以很方便的为原项目添加深度学习的能力。
智慧交通day01-算法库02:imutils
imutils是在OPenCV基础上的一个封装,达到更为简结的调用OPenCV接口的目的,它可以轻松的实现图像的平移,旋转,缩放,骨架化等一系列的操作。
【报错解决】ERROR: pip‘s dependency resolver does not currently take into account all the packages numpy 报错:”AttributeError: module ‘numpy‘ has no attribute ‘bool‘“ fatal: unable to access ‘https://github xxxxxxxxx的解决方法 MMdetection框架速成系列 第03部分:简述整体构建细节与模块+训练测试模块流程剖析+深入解析代码模块与核心实现 Linux使用解压命令unzip报错:unzip: cannot find zipfile directory in one of xxx.zip