NPE*_*NPE 4 python numpy pytables numexpr
如何有效地表达以下内容numexpr?
z = min(x-y, 1.0) / (x+y)
Run Code Online (Sandbox Code Playgroud)
在这里,x与y具有相同的形状的一些大型NumPy的阵列.
换句话说,我想盖x-y到1.0除以之前x+y.
我想使用单个numexpr表达式来做这个(x并且y很大,我不想不止一次迭代它们).
也许这样的事情可行吗?
In [11]: import numpy as np
In [12]: import numexpr as ne
In [13]:
In [13]: x = np.linspace(0.02, 5.0, 1e7)
In [14]: y = np.sin(x)
In [15]:
In [15]: timeit z0 = ((x-y) - ((x-y) > 1) * (x-y - 1))/(x+y)
1 loops, best of 3: 1.02 s per loop
In [16]: timeit z1 = ne.evaluate("((x-y) - ((x-y) > 1.) * ((x-y) - 1.))/(x+y)")
10 loops, best of 3: 120 ms per loop
In [17]: timeit z2 = ne.evaluate("((x-y)/(x+y))")
10 loops, best of 3: 103 ms per loop
Run Code Online (Sandbox Code Playgroud)
对分区以上的上限进行处罚,但这并不算太糟糕.不幸的是,当我为一些较大的阵列尝试它时,它会分裂.: - /
更新:这更漂亮,也更快一点:
In [40]: timeit w0 = ne.evaluate("where(x-y>1,1,x-y)/(x+y)")
10 loops, best of 3: 114 ms per loop
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
433 次 |
| 最近记录: |