How can I determine the indices and length of consecutive non-NaN values in an array?

8 views (last 30 days)
Say I have a vector A = [NaN NaN NaN 10 22 NaN 33 28 21 NaN 20 98 NaN], how do I:
1) determine the indices of consecutive non-NaN values; and
2) extract the count and length of these 'consecutive events'
Thank you!

Accepted Answer

Stephan
Stephan on 28 Jun 2019
Edited: Stephan on 28 Jun 2019
1. FInd the indexes:
B = find(isnan(A))
2. To find consecutive blocks you could use the diff function on a logical array:
C = isnan(A) % gives a logical array
diff(C) % --> is different from zero, when a block changes (1 for start and -1 for end of block)
  2 Comments
Stephen23
Stephen23 on 29 Jun 2019
Note that the code Stephan shows to "find consecutive blocks" will not detect when the non-NaN blocks occur at the ends of the vector.

Sign in to comment.

More Answers (1)

Stephen23
Stephen23 on 28 Jun 2019
Edited: Stephen23 on 28 Jun 2019
1)
>> A = [NaN NaN NaN 10 22 NaN 33 28 21 NaN 20 98 NaN];
>> find(~isnan(A))
ans =
4 5 7 8 9 11 12
or do you mean something else by "consecutive non-NaN values" ? Do you only want to get the indices at the beginning+end of each run of non-NaNs ?
2)
>> D = diff([false,~isnan(A),false]);
>> L = find(D<0)-find(D>0) % length
L =
2 3 2
>> N = numel(L) % count
N = 3

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!