how to find a value from a timeseries?

33 ビュー (過去 30 日間)
Tony Castillo
Tony Castillo 2018 年 7 月 16 日
編集済み: Guillaume 2018 年 7 月 16 日
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 件のコメント
KSSV
KSSV 2018 年 7 月 16 日
The values are 69.9 and 70, there is no 79 in the data.
Tony Castillo
Tony Castillo 2018 年 7 月 16 日
Oh, I think I have attached the wrong time series, but surely you could check the value 70, it appears twice. How do you do? Thanks in advance

サインインしてコメントする。

採用された回答

KSSV
KSSV 2018 年 7 月 16 日
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 件のコメント
KSSV
KSSV 2018 年 7 月 16 日
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
Guillaume 2018 年 7 月 16 日
編集済み: Guillaume 2018 年 7 月 16 日
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.

サインインしてコメントする。

その他の回答 (0 件)

カテゴリ

Help Center および File ExchangeLogical についてさらに検索

製品


リリース

R2017a

Community Treasure Hunt

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

Start Hunting!

Translated by