This time I will talk about a simple way to speed up python calculations, which is to use the numba library. The numba library can be compiled on-the-fly using JIT technology to achieve high performance. In addition, the computing power of cuda GPU can also be used. Acceleration is a very good tool library for speeding up Python. It is simple to use, but the installation is slightly more complicated.
#numba can be used after the installation is completed. (Recommended learning: Python video tutorial)
Write a small case below to see the difference between the accelerated program and the pre-accelerated program, borrowing the most classic example from the official website:
#!/usr/bin/env python # coding=utf-8 from numba import jit from numpy import arange import time @jit def sum2d(arr): M, N = arr.shape result = 0.0 for i in range(M): for j in range(N): result += arr[i,j] return result a = arange(9).reshape(3,3) start_time = time.time() for i in range(10000000): sum2d(a) end_time = time.time() print (end_time - start_time)
Here we use numpy to generate a matrix with three rows and three columns, [[0,1,2],[3,4,5],[6,7,8]] and then do two-dimensional accumulation calculation , the value should obviously be 36. We have done 10000000 such calculations here. Using @jit annotation, we can directly use numba jit technology to compile in real time, thus improving the speed. The final running time is about 3.86s. If the annotation is removed, the running time is about It is 25.45s. It can be seen from here that there is about a 6.6 times performance improvement, so it is indeed convenient and simple to use numba to accelerate python programs.
For more Python related technical articles, please visit the Python Tutorial column Get studying!
The above is the detailed content of How to speed up Python programs. For more information, please follow other related articles on the PHP Chinese website!