AR 预测模型的 Matlab 实现

时间序列模型建模流程图

#mermaid-svg-UDl3OGnf5kI0MUWB {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-UDl3OGnf5kI0MUWB .error-icon{fill:#552222;}#mermaid-svg-UDl3OGnf5kI0MUWB .error-text{fill:#552222;stroke:#552222;}#mermaid-svg-UDl3OGnf5kI0MUWB .edge-thickness-normal{stroke-width:2px;}#mermaid-svg-UDl3OGnf5kI0MUWB .edge-thickness-thick{stroke-width:3.5px;}#mermaid-svg-UDl3OGnf5kI0MUWB .edge-pattern-solid{stroke-dasharray:0;}#mermaid-svg-UDl3OGnf5kI0MUWB .edge-pattern-dashed{stroke-dasharray:3;}#mermaid-svg-UDl3OGnf5kI0MUWB .edge-pattern-dotted{stroke-dasharray:2;}#mermaid-svg-UDl3OGnf5kI0MUWB .marker{fill:#333333;stroke:#333333;}#mermaid-svg-UDl3OGnf5kI0MUWB .marker.cross{stroke:#333333;}#mermaid-svg-UDl3OGnf5kI0MUWB svg{font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;}#mermaid-svg-UDl3OGnf5kI0MUWB .label{font-family:"trebuchet ms",verdana,arial,sans-serif;color:#333;}#mermaid-svg-UDl3OGnf5kI0MUWB .cluster-label text{fill:#333;}#mermaid-svg-UDl3OGnf5kI0MUWB .cluster-label span{color:#333;}#mermaid-svg-UDl3OGnf5kI0MUWB .label text,#mermaid-svg-UDl3OGnf5kI0MUWB span{fill:#333;color:#333;}#mermaid-svg-UDl3OGnf5kI0MUWB .node rect,#mermaid-svg-UDl3OGnf5kI0MUWB .node circle,#mermaid-svg-UDl3OGnf5kI0MUWB .node ellipse,#mermaid-svg-UDl3OGnf5kI0MUWB .node polygon,#mermaid-svg-UDl3OGnf5kI0MUWB .node path{fill:#ECECFF;stroke:#9370DB;stroke-width:1px;}#mermaid-svg-UDl3OGnf5kI0MUWB .node .label{text-align:center;}#mermaid-svg-UDl3OGnf5kI0MUWB .node.clickable{cursor:pointer;}#mermaid-svg-UDl3OGnf5kI0MUWB .arrowheadPath{fill:#333333;}#mermaid-svg-UDl3OGnf5kI0MUWB .edgePath .path{stroke:#333333;stroke-width:2.0px;}#mermaid-svg-UDl3OGnf5kI0MUWB .flowchart-link{stroke:#333333;fill:none;}#mermaid-svg-UDl3OGnf5kI0MUWB .edgeLabel{background-color:#e8e8e8;text-align:center;}#mermaid-svg-UDl3OGnf5kI0MUWB .edgeLabel rect{opacity:0.5;background-color:#e8e8e8;fill:#e8e8e8;}#mermaid-svg-UDl3OGnf5kI0MUWB .cluster rect{fill:#ffffde;stroke:#aaaa33;stroke-width:1px;}#mermaid-svg-UDl3OGnf5kI0MUWB .cluster text{fill:#333;}#mermaid-svg-UDl3OGnf5kI0MUWB .cluster span{color:#333;}#mermaid-svg-UDl3OGnf5kI0MUWB div.mermaidTooltip{position:absolute;text-align:center;max-width:200px;padding:2px;font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:12px;background:hsl(80, 100%, 96.2745098039%);border:1px solid #aaaa33;border-radius:2px;pointer-events:none;z-index:100;}#mermaid-svg-UDl3OGnf5kI0MUWB :root{--mermaid-font-family:"trebuchet ms",verdana,arial,sans-serif;}

Y
N
Y
N
Y
Y
Y
N
获得观察值序列
白噪声检验
结束
平稳性检验
模型识别
平稳化处理
参数估计
模型检验
序列预测

相关链接:
自协方差函数的 Matlab 实现
时间序列平稳化的 8 种方法比较及 Matlab 实现
AR 模型的预测课件
AR 模型的预测课件(附最小二乘原理)
程序源代码打包下载

开发环境

------------------------------------------------------------------------------------------------
MATLAB 版本: 9.12.0.1884302 (R2022a)
MATLAB 许可证编号: 968398
操作系统: macOS  Version: 12.3 Build: 21E230
Java 版本: Java 1.8.0_202-b08 with Oracle Corporation Java HotSpot(TM) 64-Bit Server VM mixed mode
------------------------------------------------------------------------------------------------

读取数据

上证指数数据集:SH600031.csv

该数据集描述了三一重工 2017 年每日的开盘、最高、最低、收盘、成交量、成交额.

下面取连续500次成交量的观测数据进行建立时间序列模型并预测.

前 10 行数据预览

"2017/01/03"    "09:35"    "6.10"    "6.14"    "6.10"    "6.13"    "2851.00"    "1745600.00""2017/01/03"    "09:40"    "6.13"    "6.13"    "6.11"    "6.13"    "1413.00"    "865200.00" "2017/01/03"    "09:45"    "6.13"    "6.18"    "6.12"    "6.18"    "5662.00"    "3487800.00""2017/01/03"    "09:50"    "6.18"    "6.19"    "6.17"    "6.18"    "4891.00"    "3022800.00""2017/01/03"    "09:55"    "6.17"    "6.18"    "6.17"    "6.18"    "3300.00"    "2038900.00""2017/01/03"    "10:00"    "6.18"    "6.18"    "6.17"    "6.17"    "2649.00"    "1635400.00""2017/01/03"    "10:05"    "6.17"    "6.18"    "6.16"    "6.16"    "3107.00"    "1917000.00""2017/01/03"    "10:10"    "6.17"    "6.18"    "6.16"    "6.18"    "5671.00"    "3499300.00""2017/01/03"    "10:15"    "6.18"    "6.19"    "6.17"    "6.18"    "6490.00"    "4011200.00""2017/01/03"    "10:20"    "6.19"    "6.19"    "6.17"    "6.17"    "3041.00"    "1877400.00"

程序源代码

clc,clear
%% 读取数据
filename='SH600031.csv';
Data = readmatrix(filename, 'OutputType', 'string');
data = str2double(Data(1:500,7));
N = length(data);

原数据可视化

程序源代码

%% 原数据可视化
figure(1)
plot(data);
title('三一重工股票成交量时序图')
ylabel('成交量')
figure(2)
histogram(data);
title('原始数列直方图')

划分训练集和验证集

因为要对数据进行预测,所以我们将数据分为 70% 的训练集及 30% 的测试集.

程序源代码

%% 划分训练集和测试集
trg = round(0.7*N);
TrainData = data(1:trg);
TestData = data(trg+1:end);

数据白噪声检验

程序源代码

%% 数据白噪声检验
disp('数据白噪声检验')
[hLBQ,pLBQ] = lbqtest(TrainData);
disp('检验结果如下')
hLBQ,pLBQ

命令行窗口输出

数据白噪声检验
检验结果如下hLBQ =logical1pLBQ =0

输出变量说明:

hLBQ 表示测试的结果

hLBQ = 1 表示拒绝数据无自相关的零假设而选择备择假设.(非白噪声序列)

hLBQ = 0 表示接受数据无自相关的零假设.(白噪声序列)

pLBQ 表示 lb 检验统计量的概率 p 值.

数据平稳性检验

程序源代码

%% 数据平稳性检验
disp('使用 PP 检验, 如果不能拒绝原假设, 则说明序列存在单位根')
[hp,hpValue,stat,cValue,reg] = pptest(TrainData,'model','Ts');
disp('检验结果如下:')
hp,hpValue
diff = 0;
while hp == 0disp('hp=0,说明原始序列不平稳')disp('对序列作差分处理,再对差分数据进行 PP 检验,检验结果如下:')smooth_data = diff(TrainData);
%     % 去除趋势(线性拟合)
%     smooth_data=trend_fitting(smooth_data');
%     % 去除趋势(多项式拟合)
%     smooth_data = polynomial_fitting(smooth_data',4);
%     % 去周期(季节分析)
%     [smooth_data,I]= seasonal_analysis(smooth_data',12);
%     % 去除趋势(k 阶差分)
%     smooth_data= difference(smooth_data,1);
%     % 去周期(k 步季节差分)smooth_data= seasonal_difference(smooth_data,12);[hp,hpValue,stat,cValue,reg] = pptest(smooth_data,'model','Ts');hp,hpValuediff = diff + 1;
end
disp('hp=1,原始序列平稳')
smooth_data = TrainData;

命令行窗口输出

使用 PP 检验, 如果不能拒绝原假设, 则说明序列存在单位根
检验结果如下:hp =logical1hpValue =1.0000e-03hp=1,原始序列平稳

模型识别

自相关及偏自相关图像

程序源代码

%% 自相关及偏自相关图像
%原序列图片
figure(3)
subplot(2,1,1)
autocorr(TrainData);
title('成交量的自相关图像')
subplot(2,1,2)
parcorr(TrainData)
title('成交量的偏自相关图像')
if diff >=1% 平滑化后图片figure(4)subplot(2,1,1)autocorr(smooth_data);title('平稳化后的自相关图像')subplot(2,1,2)parcorr(smooth_data)title('平稳化后的偏自相关图像')
end

从自相关及偏自相关图像可以看出, 自相关系数缓慢衰减,可以判定自相关系数拖尾,而偏自相关系数在延迟 2 阶后都在2 倍标准差范围里面. 可以认为 2 阶后偏自相关系数为零, 所以偏自相关系数 2 阶后截尾, 由 AR 模型的统计特性,可以初步判定该数据是 AR(2) 模型.

AIC & BIC 准则定阶

在对 AR 模型识别时, 根据其样本偏自相关系数的截尾步数, 可初步得到 AR\mathrm{AR}AR 模型的阶数 ppp. 然而, 此时建立的 AR⁡(p)\operatorname{AR}(p)AR(p) 模型末必是最优的. 一个好模型通常要求残差序列方差较小, 同时模型也相对简单, 即要求阶数较低. 因此, 我们需要一些准则来比较不同阶数的模型之间的优劣, 从而确定最合适的阶数.

  1. Akaike 信息准则

Akaike 信息准则, 简称为 AIC 准则, 是一种基于观测数据选择最优参数模型的信息准则, 它既要衡量模型对原始数据的拟合程度, 又要考虑模型中所含待估参数的个数, 即模型的复杂程度.

定义 AIC 信息准则如下:
AIC⁡(p)=ln⁡σ^2+2(p+1)N,\operatorname{AIC}(p)=\ln \hat{\sigma}^{2}+\frac{2(p+1)}{N}, AIC(p)=lnσ^2+N2(p+1)​,
其中 p+1p+1p+1 为待估参数个数, 即 AR⁡(p)\operatorname{AR}(p)AR(p) 模型的 ppp 个自回归系数 a1,⋯,apa_{1}, \cdots, a_{p}a1​,⋯,ap​ 以及随机误差的方差 σ2\sigma^{2}σ2.

程序源代码

%% AIC 准则定阶
maxLags = 8;
AIC = zeros(maxLags,1);
for j=1:maxLagsmdl = ar(smooth_data,j);AIC(j) = mdl.Report.Fit.AIC;
end
% 画热度图来表示 AIC 数值的分布
figure(4)
heatmap(AIC/1000);
xlabel("AIC")
ylabel("AR Lags")
OptimalARLags_AIC = find(AIC==min(AIC));
title('Optimal AR ')

AIC 准则下的最优 AR 模型的阶数为 4 阶.

  1. BIC 准则

模拟研究结果表明, 当观测序列长度 NNN 较大时, AIC 准则有使 ppp 值估计 过高的倾向. 通过修正拟合残差方差和拟合模型参数个数之间的权重, 得到贝叶斯信息准则, 简称为 BIC 准则, 其定义如下:
BIC(p)=ln⁡σ^2+ln⁡N(p+1)N.\mathrm{BIC}(p)=\ln \hat{\sigma}^{2}+\frac{\ln N(p+1)}{N} . BIC(p)=lnσ^2+NlnN(p+1)​.
AIC\mathrm{AIC}AIC 准则与 BIC 准则的差异仅在于将 AIC\mathrm{AIC}AIC 中后一项中的 2 换为 ln⁡N\ln NlnN, 而这一项表示模型阶数 ppp 对 AIC 和 BIC 取值大小的作用, 2 和 ln⁡N\ln NlnN 相当于对 ppp 的加权系数. 当 NNN 较大时, 有 ln⁡N≫2\ln N \gg 2lnN≫2, 因此在 BIC 准则中模型阶数 ppp 的 增加对 BIC 值的影响较大, 所以 BIC 准则确定的实用模型的阶数将低于 AIC 准则确定的阶数. 可以证明, BIC 准则确定的模型阶数是其真值的一致估计.

事实上, 定义不同的准则函数, 是为了对拟合残差与参数个数之间进行不同的权衡, 以体现使用者在模型拟合误差与模型复杂程度之间的不同侧重.

程序源代码

%% BIC 准则定阶
maxLags = 8;
BIC = zeros(maxLags,1);
for j=1:maxLagsmdl = ar(smooth_data,j);BIC(j) = mdl.Report.Fit.BIC;
end
% 画热度图来表示 BIC 数值的分布
figure(5)
heatmap(BIC/1000);
xlabel("BIC")
ylabel("AR Lags")
OptimalARLags_BIC = find(BIC==min(BIC));
title('Optimal AR ')

BIC 准则下的最优 AR 模型的阶数为 2 阶.

参数估计

通过以上分析可知, BIC 准则下的最优 AR 模型的阶数为 2 阶. 于是考虑建立 AR(2) 模型.

程序源代码

%%  参数估计
disp("建立的 AR 模型如下")
mdl = ar(smooth_data,OptimalARLags_BIC)
a = zeros(length(mdl.Report.Parameters.ParVector),1);
a(1:length(mdl.Report.Parameters.ParVector)) = -mdl.Report.Parameters.ParVector;

命令行窗口输出

建立的 AR 模型如下mdl =
Discrete-time AR model: A(z)y(t) = e(t)A(z) = 1 - 0.6436 z^-1 - 0.2325 z^-2 采样时间: 1 secondsParameterization:Polynomial orders:   na=2Number of free coefficients: 2Use "polydata", "getpvec", "getcov" for parameters and their uncertainties.Status:
Estimated using AR ('fb/now') on time domain data "smooth_data".
Fit to estimation data: 30.82%
FPE: 3.296e+07, MSE: 3.259e+07

残差的白噪声检验

程序源代码

%% 残差的白噪声检验
epsilon = zeros(length(TrainData)-OptimalARLags_BIC,1);
x_hat = zeros(length(TrainData)-OptimalARLags_BIC,1);
for j =OptimalARLags_BIC+1:length(TrainData)x_hat(j) = smooth_data(j-OptimalARLags_BIC:j-1)'*flipud(a(1:length(mdl.Report.Parameters.ParVector)));epsilon(j) =  smooth_data(j) - x_hat(j);
end
var_epsilon = var(epsilon);
mean_epsilon=mean(epsilon);
figure(6)
subplot(1,2,1)
qqplot((epsilon-mean_epsilon)/sqrt(var_epsilon))
x = -4:.05:4;
[f,xi] = ksdensity((epsilon-mean_epsilon)/sqrt(var_epsilon));
subplot(1,2,2)
plot(xi,f,'k','LineWidth',2);
hold on
plot(x,normpdf(x),'r--','LineWidth',2);
legend('标准化残差','标准正态')
hold off
figure(7)
subplot(2,1,1)
plot((epsilon-mean_epsilon)/sqrt(var_epsilon));
title('标准化残差的时序图')
subplot(2,1,2)
autocorr((epsilon-mean_epsilon)/sqrt(var_epsilon))
title('标准化残差的自相关图像')
disp('检查残差是否存在相关性')
[hLBQ,pLBQ] = lbqtest(epsilon);
disp('检验结果如下')
hLBQ,pLBQ

命令行窗口输出

检查残差是否存在相关性
检验结果如下hLBQ =logical0pLBQ =0.1111

输出变量说明

hLBQ 表示测试的结果

hLBQ = 1 表示拒绝数据无自相关的零假设而选择备择假设.(非白噪声序列)

hLBQ = 0 表示接受数据无自相关的零假设.(白噪声序列)

pLBQ 表示 lb 检验统计量的概率 p 值.

可以看到此时 hLBQ = 0, 于是可判定残差不具有相关性, 因此模型可以信任.

预测

我们利用建好的模型进行最佳线性预测,预测训练集后的数据,并画出预测数据的 95%95\%95% 置信区间.

Xt+kX_{t+k}Xt+k​ 的最佳线性预测可表示为
X^t(k)=L(Xt+k∣Xt)={∑j=1pajXt+1−jk=1∑j=1k−1ajX^t(k−j)+∑j=kpajXt+k−j,1<k⩽p∑j=1pajX^t(k−j),k>p\begin{aligned} \hat{X}_{t}(k) &=L\left(X_{t+k} \mid \boldsymbol{X}_{t}\right) \\ &= \begin{cases}\sum_{j=1}^{p} a_{j} X_{t+1-j}& k=1 & \\ \sum_{j=1}^{k-1} a_{j} \hat{X}_{t}(k-j)+\sum_{j=k}^{p} a_{j} X_{t+k-j}, & 1<k \leqslant p \\ \sum_{j=1}^{p} a_{j} \hat{X}_{t}(k-j), & k>p\end{cases} \end{aligned} X^t​(k)​=L(Xt+k​∣Xt​)=⎩⎪⎨⎪⎧​∑j=1p​aj​Xt+1−j​∑j=1k−1​aj​X^t​(k−j)+∑j=kp​aj​Xt+k−j​,∑j=1p​aj​X^t​(k−j),​k=11<k⩽pk>p​​

预测的 (1−α)(1-\alpha)(1−α) 的置信区间为
(x^t(k)±zα2(1+g12+⋯+gk−12)12σ)\left(\hat{x}_{t}(k) \pm z_{\frac{\alpha}{2}}\left(1+g_{1}^{2}+\cdots+g_{k-1}^{2}\right)^{\frac{1}{2}} \sigma\right) (x^t​(k)±z2α​​(1+g12​+⋯+gk−12​)21​σ)
式中 zα2z_{\frac{\alpha}{2}}z2α​​ 表示标准正态分布的上 α2\frac{\alpha}{2}2α​ 分位数.

程序源代码

%% 预测
step = 150;
% 计算 AR(2) 的 Green 系数
g = zeros(step,1);
g(1) = 1;
g(2) = a(1)*g(1);
for j = 3:stepg(j) = a(1)*g(j-1) + a(2)*g(j-2);
end
Yf_1 = forecast(mdl,smooth_data,step);
Yf_2 = zeros(N,1);
Yf_2(1:length(smooth_data))=smooth_data;
YMSE = zeros(N,1);
for k =length(TrainData)+1:length(TrainData)+stepYf_2(k) = Yf_2(k-OptimalARLags_BIC:k-1)'*flipud(a(1:length(mdl.Report.Parameters.ParVector)));YMSE(k) = sum(g(1:k-length(TrainData)).^2)*var(epsilon);
end
error = Yf_1-Yf_2(length(smooth_data)+1:end);
figure(8)
plot(error)
ylabel('差值')
max_error = max(error);
fprintf('最大模范数:%f\n',max_error);
upper = Yf_2 + 1.96*sqrt(YMSE);
lower = Yf_2 - 1.96*sqrt(YMSE);
figure(9)
h1 = plot(data,'b');
hold on
h2 = plot(trg + 1:trg + step,Yf_2(trg + 1:trg + step),'r','LineWidth',2);
h3 = plot(trg + 1:trg + step,upper(trg + 1:trg + step),'k--','LineWidth',1.5);
plot(trg + 1:trg + step,lower(trg + 1:trg + step),'k--','LineWidth',1.5);
title('预测结果(95% 置信区间)')
ylabel('成交量')
legend([h1,h2,h3],'原始数据','预测值','95% 置信区间','Location','NorthWest')
hold off

命令行窗口输出

最大模范数:0.000000

可以看到调用 Matlab 自带的预测函数 forecast 与使用作者根据最佳线性预测公式计算的预测值残差达到 10−1310^{-13}10−13 量级, 由此可以验证此部分程序的正确性.

可以看到未来走势在 95%95\%95% 置信区间内.

修正预测

预测的步长越长, 末知信息就越多, 从而估计的精度就越差. 然而, 随着时间的发展, 我们在原有的观测值 {⋯,xt−1,xt}\left\{\cdots, x_{t-1}, x_{t}\right\}{⋯,xt−1​,xt​} 的基础上, 不断获得新的观测 值 {xt+1,xt+2,⋯}\left\{x_{t+1}, x_{t+2}, \cdots\right\}{xt+1​,xt+2​,⋯}. 这些新观测值带来更多的信息, 从而预测末来时刻的末知信息逐渐减少. 因此, 利用新观测值的信息, 我们可以更好地预测末来的序列值 xt+kx_{t+k}xt+k​, 预测精度将提高. 这就是所谓的修正预测.

修正预测有两种处理方式. 一种处理方法是把新的观测值和原数据合并, 重新拟合模型, 然后再利用拟合后的模型预测 xt+kx_{t+k}xt+k​; 另一种处理方法是利用原 来的拟合模型, 然后利用新观测值修正原来的拟合模型, 从而得到新的拟合模型. 当新的观测序列很多时或易于操作时, 可采用第一种方法. 然而, 当新的观 测并不多时, 第一种方法不是最佳选择. 此时, 第二种方法将更加简便. 下面介绍第二种处理方法.

一般地, 假如获得新观测值 xt+1,⋯,xt+l(1⩽l<k)x_{t+1}, \cdots, x_{t+l}(1 \leqslant l<k)xt+1​,⋯,xt+l​(1⩽l<k), 则 xt+kx_{t+k}xt+k​ 的修正预测值为
x^t+1(k−1)=gk−lεt+l+⋯+gk−1εt+1+gkεt+gk+1εt−1+⋯=gk−lεt+l+⋯+gk−1εt+1+x^t(k)\begin{aligned} \hat{x}_{t+1}(k-1) &=g_{k-l} \varepsilon_{t+l}+\cdots+g_{k-1} \varepsilon_{t+1}+g_{k} \varepsilon_{t}+g_{k+1} \varepsilon_{t-1}+\cdots \\ &=g_{k-l} \varepsilon_{t+l}+\cdots+g_{k-1} \varepsilon_{t+1}+\hat{x}_{t}(k) \end{aligned} x^t+1​(k−1)​=gk−l​εt+l​+⋯+gk−1​εt+1​+gk​εt​+gk+1​εt−1​+⋯=gk−l​εt+l​+⋯+gk−1​εt+1​+x^t​(k)​
其中 εt+j=xt+j−x^(t+j−1)+1(1⩽j⩽l)\varepsilon_{t+j}=x_{t+j}-\hat{x}_{(t+j-1)+1}(1 \leqslant j \leqslant l)εt+j​=xt+j​−x^(t+j−1)+1​(1⩽j⩽l) 为 xt+jx_{t+j}xt+j​ 的一步预测误差. 此时, 修正后的预测方差为
Var⁡(et+l(k−l))=(1+g12+⋯+gk−l−12)σ2.\operatorname{Var}\left(e_{t+l}(k-l)\right)=\left(1+g_{1}^{2}+\cdots+g_{k-l-1}^{2}\right) \sigma^{2} . Var(et+l​(k−l))=(1+g12​+⋯+gk−l−12​)σ2.
从上面的分析可知, 当我们获得新的观测值时, 修正后的预测方差将减少, 从而提高了预测精度. 而且这种修正方式简单, 易于操作.

程序源代码

%% 修正预测
step = 150;
% 计算 AR(2) 的 Green 系数
g = zeros(N,1);
g(N-step + 1) = 1;
g(N-step + 2) = a(1)*g(N-step + 1);
for j = N-step + 3:Ng(j) = a(1)*g(j-1) + a(2)*g(j-2);
end
% Revised_forecast = forecast(mdl,smooth_data,step);
Revised_forecast = zeros(N,1);
Revised_forecast(1:length(smooth_data))=smooth_data;
YMSE = zeros(N,1);
epsilon_hat = zeros(N,1);
for l = 1:120for k =length(TrainData)+1:length(TrainData)+lRevised_forecast(k) = Revised_forecast(k-OptimalARLags_BIC:k-1)'*flipud(a(1:length(mdl.Report.Parameters.ParVector)));epsilon_hat(k) = TestData(k-length(TrainData)) - Revised_forecast(k);endfor k =length(TrainData)+1:length(TrainData)+stepRevised_forecast(k) = Revised_forecast(k-OptimalARLags_BIC:k-1)'*flipud(a(1:length(mdl.Report.Parameters.ParVector)));Revised_forecast(k) = Revised_forecast(k) + g(k+1-l:k+1-1)'*flipud(epsilon_hat(length(TrainData)+1:length(TrainData)+l));YMSE(k) = sum(g(1:k).^2)*var(epsilon);endupper = Revised_forecast + 1.96*sqrt(YMSE);lower = Revised_forecast - 1.96*sqrt(YMSE);figure(10)h1 = plot(data,'b');hold onh2 = plot(trg + 1:trg + step,Revised_forecast(trg + 1:trg + step),'r','LineWidth',2);h3 = plot(trg + 1:trg + step,upper(trg + 1:trg + step),'k--','LineWidth',1.5);plot(trg + 1:trg + step,lower(trg + 1:trg + step),'k--','LineWidth',1.5);title(['获得 ',num2str(l),' 个新观测值后修正预测结果(95% 置信区间)'])ylabel('成交量')legend([h1,h2,h3],'原始数据','预测值','95% 置信区间','Location','NorthWest')hold offgetframe;
end

参考文献

[1] 周永道,王会琦,吕王勇. 时间序列分析及应用. 北京:高等教育出版社,2015.

[2] 江渝,李幸,卓金武. MATLAB时间序列方法与实践. 北京:电子工业出版社,2019.

[3] 茆诗松,程依明,濮晓龙. 概率论与数理统计教程. 北京:高等教育出版社,2011.


本人非统计专业,若有不妥之处, 恳请批评指正.

作者: 图灵的猫

作者邮箱: turingscat@126.com

AR 预测模型的 Matlab 实现(超详细建模流程)相关推荐

  1. 冒泡排序Matlab程序超详细注释

    冒泡排序Matlab程序超详细注释 bubble_sort.m function y=bubble_sort(x) % %冒泡算法: x_len=length(x);%度量数量长度,为排序做准备 fo ...

  2. 零基础怎么建模?超详细建模教程——第一期

    有同学私信问我零基础怎么建模,这里我给大家出一份超详细的建模教程,篇幅较长,咱们拆开来慢慢学. 第-节,界面认知 1.以下为在启动max软件后的界面(此为2018版本)∶ ⒉首先认识一下File(文件 ...

  3. ccs matlab联调,超详细干货:matlab2017a与 CCS 6.2联调设置

    电脑配置:win10 64 位系统. 所需软件:CCS v6.2.0050 + MATLAB 2017a + controlsui te 3.4.7 一.前期准备 1.下载并安装相关软件. Mi nG ...

  4. [转载] 基于LSTM的股票预测模型_python实现_超详细

    参考链接: 从Python获取输入 文章目录 一.背景二.主要技术介绍1.RNN模型2.LSTM模型3.控制门工作原理四.代码实现五.案例分析六.参数设置七.结论完整程序下载 一.背景 近年来,股票预 ...

  5. 基于LSTM的股票预测模型_python实现_超详细

    文章目录 一.背景 二.主要技术介绍 1.RNN模型 2.LSTM模型 3.控制门工作原理 四.代码实现 五.案例分析 六.参数设置 七.结论 运行环境 完整程序下载 一.背景 近年来,股票预测还处于 ...

  6. 径向基神经网络(RBF)回归预测MATLAB实现超详细

    在机械学习算法的过程中,我们常用到一种神经网络就是径向基神经网络,这是一种使用径向基函数作为激活函数的人工神经网络.这种神经网络也有很多用途,比如时间序列预测.数据分类以及回归预测等等,今天主要讲解径 ...

  7. Vue - 实现微信扫码登录功能(项目植入微信扫码登录功能)超详细完整流程详解及详细代码及注释,附带完整功能源码、常见问题解决方案

    前言 如果您需要 Nuxt.js 版本的教程,请访问 Nuxt.js - 微信扫码登录功能. 网上的大部分教程都太乱且没有任何注释和解释,对于新手而言简直是根本无从下手, 本文将站在新手小白的角度,从 ...

  8. Nuxt - 实现微信扫码登录功能(SSR 服务端渲染项目植入微信扫码登录功能)超详细完整流程详解及详细代码及注释,附带完整功能源码、常见问题解决方案

    前言 如果您需要 Vue.js 版本的教程,请访问 Vue.js - 微信扫码登录功能. 网上的大部分教程都太乱且没有任何注释和解释,对于新手而言简直是根本无从下手, 本文将站在新手小白的角度,从 0 ...

  9. tensorflow使用object detection实现目标检测超详细全流程(视频+图像集检测)

    向AI转型的程序员都关注了这个号

最新文章

  1. 7纳米duv和euv_要超车台积电 三星宣布采用EUV技术7纳米制程完成验证
  2. Android新手之旅(10) 嵌套布局
  3. 原来小清新色调是这样调出来的~
  4. QT的QDBusPendingReply类的使用
  5. java获取下周一整周的日期_当前日期得到本周的开始和结束日期
  6. 如何搭建私密云存储之ownCloud
  7. 如何自学web安全(详细路径)
  8. HD1394 Minimum Inversion Number
  9. matlab inline feval,matlab中关于函数句柄、feval函数以及inline函数的解析
  10. java 字符串的编码与C#的区别
  11. 大家身边极度聪明的人是什么样子?
  12. css-modules,可视化介绍CSS Modules是什么?
  13. shell之旅--将目录下的文件重命名为md5码+后缀名
  14. 微前端(single-spa和qiankun)
  15. MySQL之Innodb引擎的4大特性
  16. LabVIEW编程LabVIEW开发视频教学例程与相关资料
  17. 使用pyecharts绘制系统依赖关系图
  18. mongod.conf
  19. 电力系统微网故障检测数据集及代码python
  20. 2天赚了4个W,手把手教你用Threejs搭建一个Web3D汽车展厅 | 大帅老猿threejs特训

热门文章

  1. 人为什么要长大呢?可又怎能不长大!其实越长大越孤单
  2. 代码随想录训练营第25天|216.组合总和 Ⅲ、17.电话号码的字母组合
  3. Html5标签(列表、行级、文本格式、字符实体、语义化)
  4. poi导出Excel直接在浏览器下载
  5. 2008春晚诗朗诵:温暖2008
  6. MTK驱动---平台待机功耗分析流程
  7. C程序中图片调用技巧(程序来自潜艇大站游戏)
  8. c++ primer第五版----学习笔记(十五)Ⅱ
  9. [转载]健康养肾的最佳动作(图)
  10. stm32cubemx PWM