Want to share your content on R-bloggers? click here if you have a blog, or here if you don't.
I’ve had a few questions on this topic lately. Here is an email received today:
I use Eviews to estimate time series, but I have been checking out R recently, and your Forecast package.
I cannot understand why 2 similar equations in Eviews and R are giving different estimated output. Your insights will be invaluable for my work.
The equations are:
R: Arima(log(fee),order=c(1,1,0), seasonal=list(order=c(1,0,0),period=4), include.drift=TRUE) Eviews: dlog(fee) c ar(1) sar(1)Even with
include.drift=FALSE
in R or withoutc
in Eviews they give different output.Much appreciated if you could share your view.
There are several issues here.
- The Eviews model is not what it seems. To fit an ARIMA(1,1,0)(1,0,0)4 in Eviews, you need to use
dlog(fee) c ar(1) sar(4)
The seasonal order needs to be specified in the
sar
term. I’ve always thought this was a bizarre choice of syntax because it is so easy to make mistakes. - Even with that correction, the two models are not quite equivalent. In the Eviews code, the differencing is done before estimation, whereas in the R code the differencing is implicit in the model. In estimating the model in R, a state space representation is used and the non-stationary components are given a diffuse prior, rather than simply differenced away. (See
help(arima)
in R.) This will lead to different parameter estimates. A model equivalent to the (corrected) Eviews formulation can be specified in R usingArima(diff(log(fee),order=c(1,0,0),seasonal=list(order=c(1,0,0),period=4), include.mean=TRUE)
Here the differencing is explicit.
- R and Eviews use different estimation methods. Eviews uses nonlinear least squares while R uses maximum likelihood estimation. So the objective functions are not the same and the parameter estimates will therefore differ.
- Even if the two models were identical, and the two optimization criteria were identical, it is possible for different packages to give different results because they use different optimization algorithms. With nonlinear optimization, such as in estimating ARIMA models, there are several available algorithms for finding the optimal parameters. While they should all give very similar results, they often differ after the first few decimal places.
Provided the model is correctly specified, none of this should make too much difference to the forecasts obtained, but be prepared for some variations from different packages, and even from different versions of the same package.
R-bloggers.com offers daily e-mail updates about R news and tutorials about learning R and many other topics. Click here if you're looking to post or find an R/data-science job.
Want to share your content on R-bloggers? click here if you have a blog, or here if you don't.