Fitting time series with polynomials exploits the function ao/polyfit. Details on the agorithm can be found in the appropriate help page.

Fitting time series with polynomials

During this exercise we will:

  1. Load time series noise
  2. Fit data with ao/polyfit
  3. Check results

Let's open a new editor window and load test data.

    a = ao(plist('filename', 'topic5/T5_Ex04_TestNoise.xml'));
    a.setYunits('');
    a.setName;

Try to fit data with ao/polyfit. We decide to fit with a 6th order polynomial.

    plfit = plist('N', 6);
    p     = polyfit(a, plfit, plist('vector_out', false));

The variable p is a cdata analysis object containing the coefficients of the fitted polynimial.

    ----------- ao 01: polyfit(a) -----------
           name:  polyfit(a)
           data: -3.36e-14 1.00e-10 -9.19e-08 3.98e-05 -0.0123 1.0209 -87.6426
                 -------- cdata 01 ------------
                      y:  [1x7], double
                     dy:  [0x0], double
                 yunits:  []
                 ------------------------------

           hist:  ao / polyfit / SId: polyfit.m,v 1.32 2009/08/27 19:31:28 hewitson Exp S
        mdlfile:  empty
    description:
           UUID:  eeed5493-1695-40d3-bb63-0268d275b52a
    -----------------------------------------

Once we have the model coefficients, we can evaluate the model. We simply need to construct an analysis object with the parameters polyval and t. We pass as polyval the AO containing the fit coefficients and as t the AO with original data so that time base of the objects will be the same.

    b = ao(plist('polyval', p, 't', a));
    b.setYunits(a.yunits);
    b.setName;

Now, check fit result with some plotting. Compare data with fitted model and look at the fit residuals.

    iplot(a,b)
    iplot(a-b)

You could also try using ao/detrend on the input time-series to yield a very similar result as that shown in the last plot.