用 numexpr 库优化 numpy 计算速度

NumPy 在处理复杂大量计算时可能较慢,numexpr 是一个能有效提升 Numpy 性能的库。它专注于数据存储优化,并且支持自动多线程计算,无需复杂的配置。numexpr 对程序修改简单,对支持的函数和表达式加速显著,且几乎不占用编译时间。
摘要由CSDN通过智能技术生成

注:本文同步也发表在我的独立博客中。

NumPy 虽然通过底层高度优化过的计算库可以实现接近C的高效计算,但在计算复杂且计算量庞大的时候多少还是有些嫌慢。Numexpr 库是最近发现的一个非常简单易用的 Numpy性能提升工具,很大程度上从我的需求上解决了性能的问题。

先看一个例子:

import numpy as np
import numexpr as ne
nx, ny = 1200, 1500
a = np.linspace(0.,3.1416,nx*ny).reshape(nx,ny)
for i in range(100):
    b = np.sin(a+i)**2 + np.cos(a+i)**2 + a**1.5

这个程序对一个较大的网格,进行一个较复杂的计算,在使用 Numpy的情况下,我的电脑大约需要运行35.5秒。

如果对其中最后一行进行修改,改成 numexpr 的表达式:

b = ne.evaluate("sin(a+i)**2 + cos(a+i)**2 + a**
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值