Find the last non-nan in large array
21 次查看(过去 30 天)
显示 更早的评论
I have very large 4-dimensional arrays with dimensions being time,depth, lat, lon. I want to find the linear index in the depth dimension to the last non-nan data value to I can evaluate the values at the "bottom". I am looking for the output to be 3-D (time, lat, lon) with linear indexes to the last depth with a value (non-nan).
Any idea how to do this efficiently? I have a bunch of very large files to run this on.
0 个评论
采纳的回答
Guillaume
2019-5-30
One way:
%m: a 4D matrix (time x depth x lat x lon
[~, idx] = max(cumsum(~isnan(m), 2), [], 2)
This relies on the fact that max returns the index of the first max value if several are identical. The first max value of cumsum(~isnan) is the last number before zero or more nan.
3 个评论
Pepe Grillo
2021-2-24
Hi, I was looking exactly the same, but when I run this code I get a 4D array and when plt is the number of values before the last NaN, but I want to plot the value,
what I am doing wrong?
[~, idx] = max(cumsum(~isnan(m), 3), [], 3) %??
Thanks
Walter Roberson
2021-2-24
I am not clear as to what size your m is ? You should expect the output, idx, to be the same size as m, except with the third dimension now scalar.
更多回答(0 个)
另请参阅
类别
在 Help Center 和 File Exchange 中查找有关 General Applications 的更多信息
产品
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!