Cleaning Matrix

5 次查看(过去 30 天)
Xavier
Xavier 2011-9-13
Hi,
I have the following matrix called Data(size=n*1) (actually tenth of them) that I need to clean. The idea is simple:
If there is a number then no change
If there is not a number then, I replace by:
the previous number, if there is one.
the next number, if there is no previous number.
Example Data matrix
Data=
[]
[]
20
[]
25
[]
100
Result=
20
20
20
20
25
25
100
Your help would be much appreiated.
Thanks
Xavier

采纳的回答

Andrei Bobrov
Andrei Bobrov 2011-9-13
Data={[]
[]
20
[]
25
[]
100};
t = ~cellfun(@isempty,Data)
Data(1) = Data(find(t,1,'first'))
t = [true;t(2:end)]
idx = cumsum(t)
D1 = Data(t)
out = D1(idx)

更多回答(1 个)

Walter Roberson
Walter Roberson 2011-9-13
It is not possible to construct such matrices in MATLAB.
Are you using cell arrays? If so then if the empty matrix shows up then should only the first element of the previous / next number be copied, or should it be full cell entry that is copied?
Or where you show [] in your example, is that really NaN "not a number" ?
Does NaN ("not a number") count as being a number for your purposes? E.g., if you had [] nan 20 then should that become nan nan 20 or should it become 20 20 20 ?

类别

Help CenterFile Exchange 中查找有关 Logical 的更多信息

产品

Community Treasure Hunt

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

Start Hunting!

Translated by