Replacing value by the mean of the two nearest neighbors
19 次查看(过去 30 天)
显示 更早的评论
I have a column vector:
B = [20; 18; NaN; 25; 100; 15; -50; 23]
I need to pre-process data, so I want to:
- replace numbers greater than a certain value (e.g. numbers greater than 40) with the average of the two adjacent numbers.
- replace numbers smaller than a certain value (e.g. numbers smaller than -10) with the average of the two adjacent numbers.
- replace missing value with the average of the two adjacent numbers.
Thank you!
2 个评论
Torsten
2022-9-26
The result will depend on the order in which you perform these operations.
So order doesn't matter ?
采纳的回答
David Hill
2022-9-26
B = [20; 18; NaN; 25; 100; 15; -50; 23; NaN; 15; -15; 30];
idx=find(isnan(B));
B(idx)=mean([B(idx-1),B(idx+1)],2);
idx=find(B<-10);
B(idx)=mean([B(idx-1),B(idx+1)],2);
idx=find(B>40);
B(idx)=mean([B(idx-1),B(idx+1)],2)
更多回答(0 个)
另请参阅
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!