how to find a value from a timeseries?
34 views (last 30 days)
Show older comments
hi Guys, I got a problem analyzing a time series, because of its length I need to find out a way to obtain the required value without need to scroll all the time series. For instance, how to find from the attached time series the value 79?, it must appear twice in the same time series?. Could you help me?.
2 Comments
Accepted Answer
KSSV
on 16 Jul 2018
Go for logical indexing:
S = load('soc.mat') ;
t = S.soc.Time ;
y = S.soc.Data ;
idx = abs(y-70)<10^-5 ;
[t(idx) y(idx)]
3 Comments
KSSV
on 16 Jul 2018
I want to get y values which are equal to 70. So I need to check which values of y are equal to 70 an pick those indices. To compare floating point numbers it is suggested to use abs(y-val)<tolerance. 10^-5 is a tolerance factor, so I am picking those values from y on subtracting from 70, the difference should be less then tolerance.
Guillaume
on 16 Jul 2018
Edited: Guillaume
on 16 Jul 2018
Do a search on floating point comparison to learn all about it.
To check that two floating point numbers are equal, you check that there difference is sufficiently small that you can consider them the same. KSSV chose 10e-5 for that sufficiently small difference. It's arbitrary, the value being informed by the magnitude of the numbers and the precision that you require.
Note that you musn't use == to compare floating point numbers, due to the limited precision inheritent to storing floating point numbers on a computer. In particular, a computer will tell you that
(0.1 + 0.1 + 0.1) == 0.3
is false, as computers can't store 0.1 exactly.
Again, do a search to learn more.
More Answers (0)
See Also
Categories
Find more on Logical in Help Center and File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!