爱上python系列------python性能(十一):numexpr比numpy更加高速

在python数据领域处理数据使用numpy越来越多了,因为numpy相对来说是很快的,不过当 数据量较大时numexpr会更快

比如先做实验试试:

先准备数据:

import numexpr
import numpy as np

ls1=np.array([int(np.random.rand()*100) for i in range(1<<25)])
ls2=np.array([int(np.random.rand()*100) for i in range(1<<25)])

接下来对比一下加法:

使用numpy: 

%timeit ls1+ls2

##结果
## 10 loops, best of 3: 74 ms per loop

使用numexpr:

%timeit numexpr.evaluate('ls1+ls2')

##结果
## 10 loops, best of 3: 40.5 ms per loop

加法速度有所提升,不过不算很大(数据量越大会差距越明显),接下来看乘法,变化就很大:

使用numpy: 

%timeit ls1**2+ls2**3

##结果
## 1 loop, best of 3: 251 ms per loop

使用numexpr:

%timeit numexpr.evaluate('ls1**2+ls2**3')

##结果
## 10 loops, best of 3: 51.7 ms per loop

这个实验里面直接快了5倍,在很多其他实验速度可以快几十倍 

numexpr这玩意不仅仅会加速,而且会比numpy节约内存,会比numpy少产生临时的中间变量

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值