Info
This question is closed. Reopen it to edit or answer.
matrix
2 views (last 30 days)
Show older comments
I have a matrix (100000x16) where the columns refer to depths and the rows refer to days and the data is of temperature. Some of the data is faulty i.e. gives readings which are obviously wrong. If every row is a measurement taken every 4 minutes how is it possible to state that if any temperature varies by one degree compared to the next measurement (i.e. the next row) to change it to nan?
cheers
0 Comments
Answers (2)
Robert Cumming
on 17 Nov 2011
something like:
data(data(2:end,:)-data(1:end-1,:)>1)=NaN
3 Comments
Robert Cumming
on 17 Nov 2011
it should still work with NaN in your matrix - when you say it doesn;t seem to work - do you get an error message?
Walter Roberson
on 17 Nov 2011
Robert's suggestion of
data(data(2:end,:)-data(1:end-1,:)>1)=NaN
should be close, but his logical matrix will be one element short, which will lead to difficulties.
Ricco, you need to define specifically: when you have two consecutive values that differ by more than 1 degree, is it the first value that should be set to NaN, or the second value? The choice will determine whether Robert's logical array needs to be padded at the beginning or the end.
Also, there should be an abs() wrapped around the difference calculation.
0 Comments
This question is closed.
See Also
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!