在NaN重置Matlab cumsum?

时间:2012-10-21 05:57:26

标签: matlab vectorization

如果我有一个1或NaN的向量,那么:

[1 1 1 NaN 1 1 NaN 1 1 1 1]

如何在以下NaN的位置将cumsum重置为零:

[1 2 3 0 1 2 0 1 2 3 4]

理想情况下,我想要一个矢量化解决方案,因为我需要对大矩阵中的每一列执行此操作,并且NaN的位置在列中不是恒定的。

提前致谢。

3 个答案:

答案 0 :(得分:12)

您可以尝试以下两个“矢量化”行:

A(isnan(A)) = 1-diff([0 find(isnan(A))]);
cumsum(A)

ans =

  1     2     3     0     1     2     0     1     2     3     4

诀窍是将NaN替换为会在这些点重置cumsum0的值。

答案 1 :(得分:7)

我只能想到一些通过解决方案:

v = [1 1 1 NaN 1 1 1 1 NaN 1];
a = v==v;              %% convert the values first to [1 1 1 0 1 1 1 1 0 1] format
n = a==0;              %% positions of the NaNs
c = cumsum(a);         %% your intermediate result
d = diff([0 c(n)]);    %% runs of ones
v(n) = -d;             %% replace Nans by -3, -4      [1 1 1 -3 1 1 1 1 -4 1] 
cumsum(v)              %% the answer [1 2 3 0 1 2 3 4 0 1]

注意:尚未检查极端条件(NaN在第一个/最后一个位置,连续NaN等。

答案 2 :(得分:7)

有一个很好的FEX文件可以在link中处理这个问题。该代码具有用户指定的NaN处理。它允许用户用零替换NaN,或者跳过它们,或者重置NaN,将NaN保留为占位符。