How to fit time series to the curve-linear trend

조회 수: 4 (최근 30일)
Zain
Zain 2019년 1월 24일
댓글: Adam Danz 2019년 1월 25일
Hi,
I have fluctuating data with its own curve-linear trend(2) and by polynomial fitting I got curve-linear trend(1). How can I fit fluctuating data(2) to the curve-linear trend(1), so that data are extended by symetric reflection or any kind of data extension?
Like in the figure below.
(Thank you Adam Danz)
untitled1_c.png
  댓글 수: 3
Zain
Zain 2019년 1월 24일
편집: Zain 2019년 1월 25일
Line "1" is not covered, it is just polynomial fit trend extension of line "2" trend. I don't want to do any vertical shifting, I want instead of curve (1) to have similar fluctuations as in curve (2). So I tried to multiply 1st 15000* points of data from (2) with the curve (1) and take square root
sqrt(data2(15000:-1:1).*data1)
, but than I get this (around 2 times narrower characteristic than original):
* number of points for which data set is expanded.
Adam Danz
Adam Danz 2019년 1월 24일
Ahhh, I see. I'll continue in the answer section below.

댓글을 달려면 로그인하십시오.

답변 (1개)

Adam Danz
Adam Danz 2019년 1월 24일
편집: Adam Danz 2019년 1월 24일
Since your data look approximately normally distributed, you can measure the standard deviation of your data and use that to produce random numbers from a normal distrubution with a mean of your trendline. Here's general instructions.
Step 1: standardize your data by subtracting the mean (which is the trend line): dataStandard = data - trendline
Step 2: calcuate the standard deviation of the standardized data: sd = std(dataStandard)
Step 3: produce random-normal noise with standard deviation calucated in step 2 and the mean will be your red trend line.: newData = normrnd(0, sd, 1, length(trendline)) + trendline.
Step 4: plot the new data: plot(trendline, newData)
  댓글 수: 4
Zain
Zain 2019년 1월 25일
Your last solution, I understood as:
dataStandard = data - trendline;
new_data = dataStandard + trendline; new_data = data?
To answer your question - yes, there are no y values between let's say x = 0:15000, that is why I want to symetrically reflect data from x=15001:30001 in a way x(30001:-1:150001) and fit it to follow the trend line.
Adam Danz
Adam Danz 2019년 1월 25일
To clarify my solution (which seems like it would work in your explanation above),
dataStandard = data - trendlineBlue;
new_data = dataStandard + trendlineRed;

댓글을 달려면 로그인하십시오.

카테고리

Help CenterFile Exchange에서 Get Started with Curve Fitting Toolbox에 대해 자세히 알아보기

Community Treasure Hunt

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

Start Hunting!

Translated by