Detrend each column of a matrix.
Syntax: @coldetrend(m)
m: matrix
Return: matrix
Returns the matrix containing the results from detrending each column of m.
Detrending produces the residuals of the OLS regression of the data in column
data:image/s3,"s3://crabby-images/bed8e/bed8ee60a43aaa1d96dbfc8dd0b5d6435376758b" alt=""
versus an intercept and implicit time trend. For each element of the output matrix
data:image/s3,"s3://crabby-images/20b26/20b26e488bb944c7d4f3b8aef35697c6f837b021" alt=""
:
where
data:image/s3,"s3://crabby-images/e5991/e5991e6a47f60483860c2606cb764a131e44b70b" alt=""
and
data:image/s3,"s3://crabby-images/d2e06/d2e0631116d846b26249fc5a8355cb220398296c" alt=""
are the intercept and slope coefficients of a regression of the data in column
data:image/s3,"s3://crabby-images/b186c/b186c1603a0f4b5836df4b0562f6c0666258577b" alt=""
on a constant and time trend. If there are missing values in a column, they are ignored.
Examples
matrix m1 = @mnrnd(50, 4)
matrix m1d = @coldetrend(m1)
detrends each column of M1 and places the results in M1D.
This operation is equivalent to
vector cintercepts = @cintercept(m1)
vector ctrendcs = @ctrendcoef(m1)
matrix m2d = m1 - @kronecker(@ones(m1.@rows), cintercepts.@t) - @kronecker(@range(0, m1.@rows-1), ctrendcs.@t)
where @cintercept and @ctrendcoef are used to compute the coefficients of the column trend regressions.
Cross-references