首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >考虑NaNs的Numpy cumsum

考虑NaNs的Numpy cumsum
EN

Stack Overflow用户
提问于 2012-10-24 22:15:31
回答 3查看 3.2K关注 0票数 11

我正在寻找一种简洁的方法来开始:

代码语言:javascript
复制
 a = numpy.array([1,4,1,numpy.nan,2,numpy.nan])

至:

代码语言:javascript
复制
  b = numpy.array([1,5,6,numpy.nan,8,numpy.nan])

目前我能做的最好的事情是:

代码语言:javascript
复制
b = numpy.insert(numpy.cumsum(a[numpy.isfinite(a)]), (numpy.argwhere(numpy.isnan(a)) - numpy.arange(len(numpy.argwhere(numpy.isnan(a))))), numpy.nan)

有没有更短的方法来完成同样的事情呢?沿着二维数组的轴线做累加怎么样?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2012-10-24 22:26:33

如何(对于不太大的数组):

代码语言:javascript
复制
In [34]: import numpy as np

In [35]: a = np.array([1,4,1,np.nan,2,np.nan])

In [36]: a*0 + np.nan_to_num(a).cumsum()
Out[36]: array([  1.,   5.,   6.,  nan,   8.,  nan])
票数 7
EN

Stack Overflow用户

发布于 2012-10-25 03:51:08

Pandas是一个构建在numpy之上的库。它的Series类有一个cumsum方法,它保留了nan的方法,并且比DSM提出的解决方案快得多:

代码语言:javascript
复制
In [15]: a = arange(10000.0)

In [16]: a[1] = np.nan

In [17]: %timeit a*0 + np.nan_to_num(a).cumsum()
1000 loops, best of 3: 465 us per loop

In [18] s = pd.Series(a)

In [19]: s.cumsum()
Out[19]: 
0       0
1     NaN
2       2
3       5
...
9996    49965005
9997    49975002
9998    49985000
9999    49994999
Length: 10000

In [20]: %timeit s.cumsum()
10000 loops, best of 3: 175 us per loop
票数 8
EN

Stack Overflow用户

发布于 2012-10-24 22:42:59

Masked arrays就是针对这种情况的。

代码语言:javascript
复制
>>> import numpy as np
>>> from numpy import ma
>>> a = np.array([1,4,1,np.nan,2,np.nan])
>>> b = ma.masked_array(a,mask = (np.isnan(a) | np.isinf(a)))
>>> b
masked_array(data = [1.0 4.0 1.0 -- 2.0 --],
         mask = [False False False  True False  True],
   fill_value = 1e+20)
>>> c = b.cumsum()
>>> c
masked_array(data = [1.0 5.0 6.0 -- 8.0 --],
         mask = [False False False  True False  True],
   fill_value = 1e+20)
>>> c.filled(np.nan)
array([  1.,   5.,   6.,  nan,   8.,  nan])
票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/13051103

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档