In general a parsimonious model is a good model. A model with too many parameters is likely to overfit the data. So how do we determine when a model is “complex enough” but not “too complex”?
We can use a significance test to determine whether the value of each parameter is significantly different from its null value. For many parameters the null value will simply be 0 but, as we will see, there are some parameters for which this is not true.
Parameter estimates will invariably be non-zero. This is because those estimates are obtained using numerical techniques. And those techniques might converge on a value of 0.001 or 0.000000857 (or any other really tiny value) for a parameter where the true value is precisely zero.
We can use a statistical test to determine whether the estimated value is significantly different from zero (“significant” in the sense that it is still different from zero taking into account the uncertainty associated with the numerical method).
Let’s start by building a GJR GARCH model for the Tata Steel returns, using a Skewed Student-t Distribution and modelling the mean as an AR(1) process.
flexible <- ugarchspec( mean.model = list(armaOrder = c(1, 0)), variance.model = list(model = "gjrGARCH"), distribution.model = "sstd" ) overfit <- ugarchfit(data = TATASTEEL, spec = flexible)
This model has eight parameters. Is that too many?
coef(overfit) mu ar1 omega alpha1 beta1 1.310861e-03 -3.064634e-02 7.481843e-06 1.054478e-02 9.516358e-01 gamma1 skew shape 5.655076e-02 1.050852e+00 5.050698e+00
Looking at the parameter estimates alone is not enough to make a decision on the validity of the parameter estimates. A few of the estimates are pretty close to zero. But are they close enough that they are effectively zero? We need more information to make a decision on this point. Specifically, we need to know what the associated uncertainties are because these will provide us with a suitable scale to evaluate “close enough”.
We have to make a relatively obscure incantation to get the information that we need, looking at the matcoef
element on the fit
slot of the model object. This gives us the parameter estimates, the standard errors, t-statistics and \(p\)
-values.
round(overfit@fit$matcoef, 3) Estimate Std. Error t value Pr(>|t|) mu 0.001 0.001 2.319 0.020 ar1 -0.031 0.024 -1.258 0.208 omega 0.000 0.000 2.561 0.010 alpha1 0.011 0.003 3.127 0.002 beta1 0.952 0.006 147.758 0.000 gamma1 0.057 0.016 3.566 0.000 skew 1.051 0.037 28.517 0.000 shape 5.051 0.658 7.676 0.000
The t-statistic is the ratio of the parameter estimate to the standard error. Larger (absolute) values are more significant. A rule of thumb for assessing the t-statistic:
If the t-statistic is greater than 2 then reject the null hypothesis at the 5% level.
This means that if the parameter estimate differs from the null value by more than two standard errors then it is regarded as significant.
The default null hypothesis is that the parameter is zero (that is, the null value is zero). Most of the parameter estimates are significant. For example, the value for shape
seems to be obviously non-zero, and if we consider the associated standard error then we see that it differs from zero by a few standard errors. It’s a safe bet. The value for alpha1
is rather small and one might be tempted to think that it’s effectively zero. However, if you take into account the associated standard error then you see that it’s actually a few standard errors away from zero. So it’s also safely significant.
Things are different with the estimate for ar1
though. The value is just a little more than one standard error away from zero and so is not statistically significant (it also has a large \(p\)
-value, which indicates the same thing).
The estimate for skew
appears to be significant, but the t-statistic and associated \(p\)
-value are misleading. The null value used by default is 0.
(1.050847 - 0) / 0.036851 [1] 28.51611
However, in the case of skew
we should be using a null value of 1 (for a symmetric distribution with no skew).
(1.050847 - 1) / 0.036851 [1] 1.3798
The estimate for skew
does not differ from 1 by more than two standard errors, so this parameter should also be considered insignificant.
An better model might replace the Skewed Student-t Distribution with a plain Student-t Distribution and use a constant mean model. We could, equivalently, have used setfixed()
to set the value for ar1
to zero, but that would defeat the purpose of using an AR(1) model!
specification <- ugarchspec( mean.model = list(armaOrder = c(0, 0)), variance.model = list(model = "gjrGARCH"), distribution.model = "std" ) fit <- ugarchfit(data = TATASTEEL, spec = specification) Estimate Std. Error t value Pr(>|t|) mu 0.000932 0.000531 1.755574 0.079161 omega 0.000007 0.000003 2.066620 0.038770 alpha1 0.011020 0.000918 12.001779 0.000000 beta1 0.952105 0.006375 149.347874 0.000000 gamma1 0.056788 0.016077 3.532193 0.000412 shape 5.138337 0.675746 7.603951 0.000000
Now all of the model parameters are significant.
Suppose that you’ve created two models for the same data. How do you determine which model is better?
Calculate the mean squared prediction error for the mean.
mean(residuals(fit) ** 2) [1] 0.0006138637 mean(residuals(overfit) ** 2) [1] 0.0006126068
The overfit
model looks slightly better. However, this comparison is deeply misleading because we are comparing the models on the basis of their performance on the training data and, of course, the more flexible (and overfit) model is going to perform better!
You can also compare models using the model likelihood, a measure of how likely the data are given a specific set of parameters. A higher likelihood suggests that the model is a better description of the data. The likelihood in isolation is not particularly useful (it’s not measured on an absolute scale, so it’s hard to independently identify a “good” likelihood). Normally you’d compare the likelihoods of two or more models.
likelihood(fit) [1] 3491.23 likelihood(overfit) [1] 3493.11
The overfit
model has a higher likelihood and so appears to be a better representation of the data. However, here we run into the same problem as in the previous comparison: likelihood can be misleading because it is calculated using in-sample data and does not factor in how well the model performs on unseen data. A more flexible (and potentially overfit) model will probably achieve a higher likelihood.
Another approach is to use an information criterion. These criteria balance model complexity (number of model parameters) against how well a model describes the data (the likelihood). There are various such criteria. A lower (more negative) information criterion indicates a better (and more parsimonious) model.
How many parameters does each model have?
length(coef(fit)) [1] 6 length(coef(overfit)) [1] 8
The overfit
model has more parameters. It’s more flexible and thus able to capture more information from the data. However, at the same time, it’s also more prone to overfitting.
infocriteria(fit) Akaike -4.697076 Bayes -4.675637 Shibata -4.697108 Hannan-Quinn -4.689085 infocriteria(overfit) Akaike -4.696913 Bayes -4.668328 Shibata -4.696971 Hannan-Quinn -4.686258
This paints a different picture of the models. Now fit
is better because it has lower (more negative) values for all information criteria.
Let’s try with the {tsgarch}
package.
library(tsgarch) specification <- garch_modelspec( TATASTEEL, model = "gjrgarch", distribution = "sstd", constant = TRUE ) fit <- estimate(specification)
You don’t need to work as hard to examine the statistical properties of the parameter estimates: just use the summary()
method.
summary(fit) GJRGARCH Model Summary Coefficients: Estimate Std. Error t value Pr(>|t|) mu 1.278e-03 5.847e-04 2.186 0.02878 * omega 7.330e-06 3.997e-06 1.834 0.06663 . alpha1 1.041e-02 8.412e-03 1.238 0.21588 gamma1 5.769e-02 1.818e-02 3.173 0.00151 ** beta1 9.515e-01 1.258e-02 75.618 < 2e-16 *** skew 1.053e+00 3.720e-02 28.320 < 2e-16 *** shape 5.131e+00 7.000e-01 7.329 2.31e-13 *** persistence 9.914e-01 7.185e-03 137.982 < 2e-16 *** --- Signif. codes: 0 '***' 0.001 '**' 0.01 '*' 0.05 '.' 0.1 ' ' 1 N: 1484 V(initial): 0.0006137, V(unconditional): 0.0008561 Persistence: 0.9914 LogLik: 3492.21, AIC: -6968.42, BIC: -6926
The AIC()
and BIC()
generic functions yield the Akaike (AIC) and Bayesian (BIC) Information Criteria.
AIC(fit) [1] -6968.419 BIC(fit) [1] -6925.999
Comparing these values to those obtained earlier it’s apparent that these metrics are being normalised differently, underlining the fact that they can only be used for making comparisons.