STAT 497 LECTURE NOTE 9 DIAGNOSTIC CHECKS 1
After identifying and estimating a time series model, the goodness-of-fit of the model and validity of the assumptions should be checked. If we have a perfect model fit, then we can construct the ARIMA forecasts. 2
1. NORMALITY OF ERRORS Check the histogram of the standardized residuals,. Draw Normal QQ-plot of the standardized residuals (should be a straight line on 45 0 line). Look at Tukey’s simple 5-number summary + skewness (should be 0 for normal)+ kurtosis (should be 3 for normal) or excess kurtosis (should be 0 for normal) 3
1. NORMALITY OF ERRORS Jarque-Bera Normality Test: Skewness and kurtosis are used for constructing this test statistic. JB (1981) tests whether the coefficients of skewness and excess kurtosis are jointly 0. 4
1. NORMALITY OF ERRORS JB test statistic JB>, then reject the null hypothesis that residuals are normally distributed. 5
1. NORMALITY OF ERRORS The chi-square approximation, however, is overly sensitive for small samples, rejecting the null hypothesis often when it is in fact true. Furthermore, the distribution of p-values departs from a uniform distribution and becomes a right-skewed uni-modal distribution, especially for small p-values. This leads to a large Type I error rate. The table below shows some p-values approximated by a chi-square distribution that differ from their true alpha levels for very small samples. You can also use Shapiro-Wilk test. 6
1. NORMALITY OF ERRORS Calculated p-value equivalents to true alpha levels at given sample sizes True α level
2. DETECTION OF THE SERIAL CORRELATION In OLS regression, time residuals are often found to be serially correlated with their own lagged values. Serial correlation means – OLS is no longer an efficient linear estimator. – Standard errors are incorrect and generally overstated. – OLS estimates are biased and inconsistent if a lagged dependent variable is used as a regressor. 8
2. DETECTION OF THE SERIAL CORRELATION Durbin-Watson test is for regular regression with independent variables. It is not appropriate for time series models with lagged dependent variables. It only tests for AR(1) errors. There should be a constant term and deterministic independent variables in the model. 9
2. DETECTION OF THE SERIAL CORRELATION Serial Correlation Lagrange Multiplier (Breusch-Godfrey) Test is valid in the presence of lagged dependent variables. It tests for AR(p) errors. 10
2. DETECTION OF THE SERIAL CORRELATION The test hypothesis: Test statistic: Obtained from the auxiliary regression 11
2. DETECTION OF THE SERIAL CORRELATION Determination of r : No obvious answer exists. In empirical studies – for AR, ARMA: r=p+1 lags – For seasonal, r=s. 12
2. DETECTION OF THE SERIAL CORRELATION Ljung-Box (Modified Box-Pierce) or Portmanteau Lack-of-Fit Test: Box and Pierce (1970) have developed a test to check the autocorrelation structure of the residuals. Then, it is modified by Ljung and Box. The null hypothesis to be tested: 13
2. DETECTION OF THE SERIAL CORRELATION The test statistic: 14
2. DETECTION OF THE SERIAL CORRELATION If the correct model is estimated, If, reject H 0. This means that the autocorrelation exists in residuals. Assumption is violated. Check the model again. It is better to add another lag in AR or MA part of the model. 15
3. DETECTING HETEROSCEDASTICITY Heteroskedasticity is a violation of the constant error variance assumption. It occurs if variance of error changing by time. 16
3. DETECTING HETEROSCEDASTICITY ACF-PACF PLOT OF SQUARED RESIDUALS: Since {a t } is a zero mean process, the variance of a t is defined by the expected value of squared a t ’s. So, if a t ’s are homoscedastic, the variance will be constant (not change over time) and when we look at the ACF and PACF plots of squared residuals, they should be in 95% WN limits. If not, this is a sign of heteroscedasticity. 17
3. DETECTING HETEROSCEDASTICITY Let r t be the log return of an asset at time t. We are going to look at the study of volatility: the series is either serially uncorrelated or with minor lower order serial correlations, but it is a dependent series. Examine the ACF for the residuals and squared residuals for the calamari catch data. The catch data had a definite seasonality, which was removed. Then, the remaining series was modelled with an AR(5) model and the residuals of this model are obtained. There are various definitions of what constitutes weak dependence of a time series. However, the operational definition of independence here will be that both the autocorrelation functions of the series and the squared series show no autocorrelation. If there is no serial correlation of the series but there is of the squared series, then we will say there is weak dependence. This will lead us to examine the volatility of the series, since that is exemplified by the squared terms. 18
3. DETECTING HETEROSCEDASTICITY Figure 1: Residuals after AR(5) fitted to the deseasoned calamari data Figure 2: Autocorrelation of the squared residuals 19
3. DETECTING HETEROSCEDASTICITY Figure 3: Autocorrelation for the log returns for the Intel series 20
3. DETECTING HETEROSCEDASTICITY Figure 4: ACF of the squared returnsFigure 5: PACF for squared returns Combining these three plots, it appears that this series is serially uncorrelated but dependent. Volatility models attempt to capture such dependence in the return series 21
3. DETECTING HETEROSCEDASTICITY If we ignore heterocedasticity: – The OLS estimator is unbiased but not efficient. The GLS or WLS is the Gauss-Markov estimator. – The estimate of the variance of the OLS estimator is a biased estimator of the true variance. The classical testing procedures are invalidated. Now, the question is how we can detect heteroscedasticity? 22
3. DETECTING HETEROSCEDASTICITY White’s General Test for Heteroscedasticity: After identified model is estimated, we obtain the residuals,. Then, can be written as 23
3. DETECTING HETEROSCEDASTICITY Then, construct the following artificial regression The homocedastic case implies that 1 = 2 =... = 1 = 2 =…= 1 = 2 =…= 0, therefore 24
3. DETECTING HETEROSCEDASTICITY Then, the test statistics is given by under the null hypothesis of homoscedasticity where m is the number of variables in artificial regression except the constant term. 25
3. DETECTING HETEROSCEDASTICITY The Breush-Pagan Test: It is a Lagrange- Multiplier test for heteroscedasticity. Consider the IF of a time series. Let’s assume that we can write our model in AR(m). Then, consider testing 26
3. DETECTING HETEROSCEDASTICITY Note that we need to evaluate the conditional (on the independent variables) expectation of the squared of the error term, The homocedastic case implies that 1 = 2 =... = m = 0. 27
3. DETECTING HETEROSCEDASTICITY The problem, however, is that we do not know the error term, but it can be replaced by an estimate. A simple approach is to run a regression, and test if the slope coefficients are all equal to zero. 28
3. DETECTING HETEROSCEDASTICITY The test statistic under the null hypothesis of homoscedasticity where m is the number of variables in artificial regression except the constant term. 29
3. DETECTING HETEROSCEDASTICITY If we reject the null hypothesis, this means that the error variance is not constant. It is changing over time. Therefore, we need to model the volatility. ARCH (Autoregressive Conditional Heteroskedasticity) or GARCH (Generalized Autoregressive Conditional Heteroskedasticity) modeling helps us to model the error variance. 30
EXAMPLE (BEER) > library(TSA) > fit=arima(beer,order=c(3,1,0),seasonal=list(order=c(3,0,0), period=4)) > par(mfrow=c(1,3)) > plot(window(rstandard(fit),start=c(1975,1)), ylab='Standardized Residuals',type='o') > abline(h=0) > acf(as.vector(window(rstandard(fit),start=c(1975,1))), lag.max=36) > pacf(as.vector(window(rstandard(fit),start=c(1975,1))), lag.max=36) 31
EXAMPLE (BEER) > fit2=arima(beer,order=c(2,1,1),seasonal=list(order=c(3,0,1), period=4)) > fit2 Call: arima(x = beer, order = c(2, 1, 1), seasonal = list(order = c(3, 0, 1), period = 4)) Coefficients: ar1 ar2 ma1 sar1 sar2 sar3 sma s.e sigma^2 estimated as 1.564: log likelihood = , aic = > plot(window(rstandard(fit2),start=c(1975,1)), ylab='Standardized Residuals',type='o') > abline(h=0) > acf(as.vector(window(rstandard(fit2),start=c(1975,1))), lag.max=36) > pacf(as.vector(window(rstandard(fit2),start=c(1975,1))), lag.max=36) 32
EXAMPLE (BEER) 33
EXAMPLE (BEER) > hist(rstandard(fit2), xlab='Standardized Residuals') 34
EXAMPLE (BEER) > qqnorm(rstandard(fit2)) > qqline(rstandard(fit2)) 35
EXAMPLE (BEER) > shapiro.test(window(rstandard(fit2),start=c(1975,1))) Shapiro-Wilk normality test data: window(rstandard(fit2), start = c(1975, 1)) W = , p-value = > jarque.bera.test(resid(fit2)) Jarque Bera Test data: resid(fit2) X-squared = , df = 2, p-value =
EXAMPLE (BEER) > tsdiag(fit2) 37
EXAMPLE (BEER) > Box.test(resid(fit2),lag=15,type = c("Ljung-Box")) Box-Ljung test data: resid(fit2) X-squared = , df = 15, p-value = > Box.test(resid(fit2),lag=15,type = c("Box-Pierce")) Box-Pierce test data: resid(fit2) X-squared = , df = 15, p-value =
EXAMPLE (BEER) > rr=resid(fit2)^2 > par(mfrow=c(1,2)) > acf(rr) > pacf(rr) 39
EXAMPLE (BEER) > par(mfrow=c(1,1)) > result=plot(fit2,n.ahead=12,ylab='Series & Forecasts',col=NULL,pch=19) > abline(h=coef(fit2)) > forecast=result$pred > cbind(beer,forecast) > plot(fit2,n1=1975,n.ahead=12,ylab='Series, Forecasts, Actuals & Limits', pch=19) 40