Я пытался изучить и применить модели ARIMA. Я читал превосходный текст об ARIMA от Панкраца - Прогнозирование с помощью однофакторной рамки - Модели Дженкинса: концепции и случаи . В тексте автор особо подчеркивает принцип скупости при выборе моделей ARIMA.
Я начал играть с auto.arima()
функцией в R пакета прогноза . Вот что я сделал, я смоделировал ARIMA и затем применил auto.arima()
. Ниже приведены 2 примера. Как вы можете видеть в обоих примерах, auto.arima()
четко обозначена модель, которую многие сочли бы не экономной. Особенно в примере 2, где auto.arima()
идентифицируется ARIMA (3,0,3), когда фактически ARIMA (1,0,1) будет достаточным и экономным.
Ниже мои вопросы. Буду признателен за любые предложения и рекомендации.
- Существуют ли какие-либо указания относительно того, когда использовать / модифицировать модели, определенные с использованием автоматических алгоритмов, например
auto.arima()
? - Есть ли какие-то проблемы с использованием AIC (который, я думаю,
auto.arima()
использует) для идентификации моделей? - Можно ли построить автоматический алгоритм, который является экономным?
Кстати, я использовал auto.arima()
только в качестве примера. Это относится к любому автоматическому алгоритму.
Ниже приведен пример № 1:
set.seed(182)
y <- arima.sim(n=500,list(ar=0.2,ma=0.6),mean = 10)
auto.arima(y)
qa <- arima(y,order=c(1,0,1))
qa
Ниже приведены результаты auto.arima()
. Обратите внимание, что все коэффициенты незначительны. т.е. значение <2.
ARIMA(1,0,2) with non-zero mean
Coefficients:
ar1 ma1 ma2 intercept
0.5395 0.2109 -0.3385 19.9850
s.e. 0.4062 0.4160 0.3049 0.0878
sigma^2 estimated as 1.076: log likelihood=-728.14
AIC=1466.28 AICc=1466.41 BIC=1487.36
Ниже приведены результаты регулярного запуска arima()
с заказом ARIMA (1,0,1).
Series: y
ARIMA(1,0,1) with non-zero mean
Coefficients:
ar1 ma1 intercept
0.2398 0.6478 20.0323
s.e. 0.0531 0.0376 0.1002
sigma^2 estimated as 1.071: log likelihood=-727.1
AIC=1462.2 AICc=1462.28 BIC=1479.06
Пример 2:
set.seed(453)
y <- arima.sim(n=500,list(ar=0.2,ma=0.6),mean = 10)
auto.arima(y)
qa <- arima(y,order=c(1,0,1))
qa
Ниже приведены результаты auto.arima()
:
ARIMA(3,0,3) with non-zero mean
Coefficients:
ar1 ar2 ar3 ma1 ma2 ma3 intercept
0.7541 -1.0606 0.2072 0.1391 0.5912 0.5491 20.0326
s.e. 0.0811 0.0666 0.0647 0.0725 0.0598 0.0636 0.0939
sigma^2 estimated as 1.027: log likelihood=-716.84
AIC=1449.67 AICc=1449.97 BIC=1483.39
Ниже приведены результаты регулярного выполнения arima()
заказа ARIMA (1,0,1).
Series: y
ARIMA(1,0,1) with non-zero mean
Coefficients:
ar1 ma1 intercept
0.2398 0.6478 20.0323
s.e. 0.0531 0.0376 0.1002
sigma^2 estimated as 1.071: log likelihood=-727.1
AIC=1462.2 AICc=1462.28 BIC=1479.06