data_test 是一个由带有 NaN 的数字填充的向量。
data_test = [NaN, 2, 3, 4, NaN,NaN,NaN, 12 ,44, 34, NaN,5,NaN];
我想根据 NaN 剪切 data_test
并创建一个包含 NaN 之间的 data_set
片段的元胞数组。
data_cell{1}=[2 3 4];
data_cell{2}=[12 44 34];
data_cell{3}=[5];
此时我需要过滤这些值(这没问题,只是作为示例,过滤后的值将与 data_test +1 相同)
data_cell{1} -> data_cell_filt{1}
data_cell{2} -> data_cell_filt{2}
data_cell{3} -> data_cell_filt{3}
并将过滤后的值放回data_test中。
data_cell_filt{1}
data_cell_filt{2} -> data_test
data_cell_filt{3}
为了 data_test 是
data_test = [NaN, 3, 4, 5, NaN,NaN,NaN, 13 ,45, 35, NaN, 6, NaN];
ps(我的例子中的 data_test 约为 20000 个元素)
最佳答案
您可以使用循环轻松完成此操作或使用arrayfun
,如下所示:
A = [NaN, 2, 3, 4, NaN, NaN, NaN, 13, 45, 35, NaN, 6, NaN]
i1 = find(diff(isnan(A))==-1)+1 %// Index where clusters of numbers begin
i2 = find(diff(isnan(A))==1) %// Index where clusters of numbers end
data_cell_filt = arrayfun(@(x,y)({A(x:y)}),i1,i2 ,'uni', false)
关于matlab - 根据 NaN 值切割向量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30807131/