Задайте модель регрессии с ошибками SARIMA

В этом примере показано, как задать модель регрессии с мультипликативными сезонными ошибками ARIMA.

Загрузите набор данных Авиакомпании от корневой папки MATLAB® и загрузите набор данных рецессии. Постройте ежемесячные пассажирские общие количества и логарифмические общие количества.

load('Data_Airline.mat')
load Data_Recessions; 

y = Data; 
logY = log(y); 

figure
subplot(2,1,1) 
plot(y)
title('{\bf Monthly Passenger Totals (Jan1949 - Dec1960)}')
datetick
subplot(2,1,2)
plot(log(y))
title('{\bf Monthly Passenger Log-Totals (Jan1949 - Dec1960)}')
datetick

Figure contains 2 axes objects. Axes object 1 with title blank M o n t h l y blank P a s s e n g e r blank T o t a l s blank ( J a n 1 9 4 9 blank - blank D e c 1 9 6 0 ) contains an object of type line. Axes object 2 with title blank M o n t h l y blank P a s s e n g e r blank L o g - T o t a l s blank ( J a n 1 9 4 9 blank - blank D e c 1 9 6 0 ) contains an object of type line.

Логарифмическое преобразование, кажется, линеаризует временные ряды.

Создайте этот предиктор, который является, была ли страна в рецессии в произведенный период. 0 означает, что страна не была в рецессии и 1 средние значения, что это было в рецессии.

X = zeros(numel(dates),1); % Preallocation
for j = 1:size(Recessions,1)
    X(dates >= Recessions(j,1) & dates <= Recessions(j,2)) = 1;
end

Подбирайте простую модель линейной регрессии,

yt=c+Xtβ+ut

к данным.

Fit = fitlm(X,logY);

Fit LinearModel это содержит оценки методом наименьших квадратов.

Выполните остаточный диагноз путем графического вывода остаточных значений несколько путей.

figure
subplot(2,2,1)
plotResiduals(Fit,'caseorder','ResidualType','Standardized',...
    'LineStyle','-','MarkerSize',0.5)
h = gca;
h.FontSize = 8; 
subplot(2,2,2)
plotResiduals(Fit,'lagged','ResidualType','Standardized')
h = gca;
h.FontSize = 8;
subplot(2,2,3)
plotResiduals(Fit,'probability','ResidualType','Standardized')
h = gca;
h.YTick = h.YTick(1:2:end); 
h.YTickLabel = h.YTickLabel(1:2:end,:); 
h.FontSize = 8;
subplot(2,2,4)
plotResiduals(Fit,'histogram','ResidualType','Standardized')
h = gca;
h.FontSize = 8; 

Figure contains 4 axes objects. Axes object 1 with title Case order plot of residuals contains 2 objects of type line. Axes object 2 with title Plot of residuals vs. lagged residuals contains 3 objects of type line. Axes object 3 with title Normal probability plot of residuals contains 2 objects of type line. Axes object 4 with title Histogram of residuals contains an object of type patch.

r = Fit.Residuals.Standardized;
figure
subplot(2,1,1)
autocorr(r)
h = gca;
h.FontSize = 9;
subplot(2,1,2)
parcorr(r)    
h = gca;
h.FontSize = 9;

Figure contains 2 axes objects. Axes object 1 with title Sample Autocorrelation Function contains 4 objects of type stem, line. Axes object 2 with title Sample Partial Autocorrelation Function contains 4 objects of type stem, line.

Остаточные графики показывают, что остаточные значения автокоррелируются. График вероятности и гистограмма, кажется, указывают, что остаточные значения являются Гауссовыми.

ACF остаточных значений подтверждает, что они автокоррелируются.

Возьмите 1-е различие остаточных значений и постройте ACF и PACF differenced остаточных значений.

dR = diff(r);

figure
subplot(2,1,1)
autocorr(dR,'NumLags',50)
h = gca;
h.FontSize = 9;
subplot(2,1,2)
parcorr(dR,'NumLags',50)    
h = gca;
h.FontSize = 9;

Figure contains 2 axes objects. Axes object 1 with title Sample Autocorrelation Function contains 4 objects of type stem, line. Axes object 2 with title Sample Partial Autocorrelation Function contains 4 objects of type stem, line.

ACF показывает, что существуют значительно большие автокорреляции, особенно в каждой 12-й задержке. Это указывает, что остаточные значения имеют 12-ю степень сезонное интегрирование.

Возьмите первые и 12-е различия остаточных значений. Постройте differenced остаточные значения, и их ACF и PACF.

DiffPoly = LagOp([1 -1]);
SDiffPoly = LagOp([1 -1],'Lags',[0, 12]);
diffR = filter(DiffPoly*SDiffPoly,r);

figure
subplot(2,1,1)
plot(diffR)
axis tight
subplot(2,2,3)
autocorr(diffR)
axis tight
h = gca;
h.FontSize = 7;
subplot(2,2,4)
parcorr(diffR)
axis tight    
h = gca;
h.FontSize = 7; 

Figure contains 3 axes objects. Axes object 1 contains an object of type line. Axes object 2 with title Sample Autocorrelation Function contains 4 objects of type stem, line. Axes object 3 with title Sample Partial Autocorrelation Function contains 4 objects of type stem, line.

Остаточные значения напоминают белый шум (с возможным heteroscedasticity). Согласно Полю и Дженкинсу (1994), Глава 9, ACF и PACF указывают, что безусловные воздействия IMA(0,1,1)×(0,1,1)12 модель.

Задайте модель регрессии с IMA(0,1,1)×(0,1,1)12 ошибки:

yt=Xtβ+ut(1-L)(1-L12)ut=(1+b1L)(1+B12L12)εt.

Mdl = regARIMA('MALags',1,'D',1,'Seasonality',12,'SMALags',12) 
Mdl = 
  regARIMA with properties:

     Description: "ARIMA(0,1,1) Error Model Seasonally Integrated with Seasonal MA(12) (Gaussian Distribution)"
    Distribution: Name = "Gaussian"
       Intercept: NaN
            Beta: [1×0]
               P: 13
               D: 1
               Q: 13
              AR: {}
             SAR: {}
              MA: {NaN} at lag [1]
             SMA: {NaN} at lag [12]
     Seasonality: 12
        Variance: NaN

Mdl модель регрессии с IMA(0,1,1)×(0,1,1)12 ошибки. По умолчанию инновации являются Гауссовыми, и всеми параметрами является NaN. Свойство:

  • P = p + D + sps + s = 0 + 1 + 0 + 12 = 13.

  • Q = q + sqs = 1 + 12 = 13.

Поэтому программное обеспечение требует, чтобы по крайней мере 13 преддемонстрационных наблюдений инициализировали модель.

Передайте MdlY, и X в estimate оценить модель. Для того, чтобы симулировать или предсказать ответы с помощью simulate или forecast, необходимо установить значения ко всем параметрам.

Ссылки:

Поле, G. E. P. Г. М. Дженкинс и Г. К. Рейнсель. Анализ Временных Рядов: Прогнозирование и Управление. 3-й редактор Englewood Cliffs, NJ: Prentice Hall, 1994.

Смотрите также

| | | |

Связанные примеры

Больше о