3.6 Classical decomposition
Model time series \(\{x_t\}\) as a combination of
- trend (\(m_t\))
- seasonal component (\(s_t\))
- remainder (\(e_t\))
\(x_t = m_t + s_t + e_t\)
3.6.1 1. The trend (\(m_t\))
We need a way to extract the so-called signal. One common method is via “linear filters”
\[ m_t = \sum_{i=-\infty}^{\infty} \lambda_i x_{t+1} \]
For example, a moving average
\[ m_t = \sum_{i=-a}^{a} \frac{1}{2a + 1} x_{t+i} \]
If \(a = 1\), then
\[ m_t = \frac{1}{3}(x_{t-1} + x_t + x_{t+1}) \]
3.6.2 Example of linear filtering
Here is a time series.
data:image/s3,"s3://crabby-images/da08d/da08d52507c7569248babd63cc681a5d707eb7f8" alt="Monthly airline passengers from 1949-1960"
Figure 3.5: Monthly airline passengers from 1949-1960
A linear filter with \(a=3\) closely tracks the data.
data:image/s3,"s3://crabby-images/24242/24242228486960c14bddd81ad4345d42040b3082" alt="Monthly airline passengers from 1949-1960 with a low filter."
Figure 3.6: Monthly airline passengers from 1949-1960 with a low filter.
As we increase the length of data that is averaged from 1 on each side (\(a=3\)) to 4 on each side (\(a=9\)), the trend line is smoother.
data:image/s3,"s3://crabby-images/eaee3/eaee341309f8f2a6533e74108eaf22f4967cd0f1" alt="Monthly airline passengers from 1949-1960 with a medium filter."
Figure 3.7: Monthly airline passengers from 1949-1960 with a medium filter.
When we increase up to 13 points on each side (\(a=27\)), the trend line is very smooth.
data:image/s3,"s3://crabby-images/884c2/884c24a7ba15df318607f4735ebfcad459029017" alt="Monthly airline passengers from 1949-1960 with a high filter."
Figure 3.8: Monthly airline passengers from 1949-1960 with a high filter.
3.6.3 2. Seasonal effect (\(s_t\))
Once we have an estimate of the trend \(m_t\), we can estimate \(s_t\) simply by subtraction:
\[ s_t = x_t - m_t \]
This is the seasonal effect (\(s_t\)), assuming \(\lambda = 1/9\), but, \(s_t\) includes the remainder \(e_t\) as well. Instead we can estimate the mean seasonal effect (\(s_t\)).
<- decompose(xx)$seasonal
seas_2 par(mai = c(0.9, 0.9, 0.1, 0.1), omi = c(0, 0, 0, 0))
plot.ts(seas_2, las = 1, ylab = "")
data:image/s3,"s3://crabby-images/51bd1/51bd1d9bfd872c2dc6936d870c3eb591a5b69a33" alt="Mean seasonal effect."
Figure 3.9: Mean seasonal effect.
3.6.4 3. Remainder (\(e_t\))
Now we can estimate \(e_t\) via subtraction:
\[ e_t = x_t - m_t - s_t \]
<- decompose(xx)$random
ee par(mai = c(0.9, 0.9, 0.1, 0.1), omi = c(0, 0, 0, 0))
plot.ts(ee, las = 1, ylab = "")
data:image/s3,"s3://crabby-images/f58c0/f58c02bf52a6a9c073b6f8b265c9d952277b73db" alt="Errors."
Figure 3.10: Errors.