news 2026/4/16 11:03:16

今天咱们聊聊用MATLAB玩时间序列预测的野路子。别被那些AR、ARIMA之类的缩写吓到,说白了就是找规律猜未来的游戏。直接上代码更实在,咱边写边唠

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
今天咱们聊聊用MATLAB玩时间序列预测的野路子。别被那些AR、ARIMA之类的缩写吓到,说白了就是找规律猜未来的游戏。直接上代码更实在,咱边写边唠

几种时间序列预测方法(MATLAB R2021B) 算法运行环境为MATLAB R2021B,执行几种时间序列预测方法,包括: 1) Autoregression (AR) 2) Moving Average 3) Autoregressive Moving Average 4) Autoregressive Integrated Moving Average (ARIMA) 5) Seasonal Autoregressive Integrated Moving-Average (SARIMA) 6) Seasonal Autoregressive Integrated Moving Average with Exogenous Regressors (SARIMAX) 7) Vector Autoregression (VAR) 8) GARCH Model 9) Glostan, Jagannathan and Runkle GARCH Model

先整点数据热身。假设手头有个股票收盘价序列,长度500天:

data = cumsum(randn(500,1)*0.5 + 0.01) + 50; % 带趋势的随机游走 plot(data) title('假装这是股票价格')

这串随机数生成器造的数据有微弱正趋势,标准差0.5,初始值50。cumsum让数据有持续性特征,符合金融时间序列特性。

AR模型实战

自回归的核心就是拿历史数据当预测依据。比如用前3天的数据预测明天:

Mdl = arima('ARLags',1:3); EstMdl = estimate(Mdl, data); [YF, YMSE] = forecast(EstMdl, 5, data); % 预测未来5天

这里'ARLags'参数指定滞后阶数,1:3表示用t-1,t-2,t-3时刻的值。estimate函数会返回模型参数估计值,注意MATLAB自动做了标准化处理。预测时YMSE是预测方差,可以画置信区间。

ARIMA进阶版

加上差分处理非平稳数据更带劲:

Mdl = arima(2,1,1); % AR阶2,差分阶1,MA阶1 EstMdl = estimate(Mdl, data); [YF, YMSE] = forecast(EstMdl, 5, 'Y0', data);

差分阶数1表示做一阶差分消除趋势。模型训练时注意看命令行输出的参数显著性,p值小于0.05的项才有保留价值。如果MA项系数不显著,可以降阶试试。

GARCH家族玩波动

搞金融预测必须处理波动聚集现象:

Mdl = garch('GARCHLags',1,'ARCHLags',1); EstMdl = estimate(Mdl, diff(data)); % 对收益率建模 condVar = infer(EstMdl, diff(data)); % 提取条件方差 plot([diff(data), condVar]) legend('收益率','波动率')

这里用差分后的收益率数据,infer函数能提取波动率估计。GARCH(1,1)模型里,ARCH项反映新息冲击,GARCH项体现波动持续性。如果发现杠杆效应(跌的时候波动更大),可以升级到GJR-GARCH:

Mdl = gjr('GARCHLags',1,'ARCHLags',1,'LeverageLags',1); EstMdl = estimate(Mdl, diff(data));

多了个LeverageLags参数来捕捉不对称效应。回测时要注意,这类模型对参数初值敏感,可能需要多试几次初值设定。

多变量搞事情——VAR模型

当多个时间序列互相影响时:

data_multi = [data, randn(500,1)*2 + 5]; % 伪造第二个变量 Mdl = varm(2,2); % 两个变量,滞后2阶 EstMdl = estimate(Mdl, data_multi); [YF, YMSE] = forecast(EstMdl, 5, data_multi);

varm模型会自动估计变量间的交叉影响。注意数据要先做平稳性检验,可以用MATLAB的adftest做单位根检验。预测时输出的YF是矩阵,每列对应一个变量的预测值。

季节杀器SARIMA

处理像销售额这种有季节波动的:

Mdl = arima('ARLags',1:2,'D',1,'Seasonality',12,... 'MALags',1,'SMALags',12); EstMdl = estimate(Mdl, data);

这里设置季节周期为12(比如月度数据),Seasonality参数自动创建季节性差分。实际操作中要先用季节图判断周期长度,别瞎猜参数。可以用x13as工具做季节调整,再喂给模型。

代码跑完别急着收工,几个避坑指南:

  1. 预测前务必做残差诊断:用lbqtest检验自相关性
  2. 模型对比用AIC/BIC指标,别光看拟合误差
  3. 样本外预测要用滚动窗口验证,防止过拟合
  4. 用parfor加速参数寻优,特别是SARIMAX这种参数多的模型

说到底,时间序列预测就是平衡bias和variance的艺术。没有通吃所有场景的银弹,多备几把刷子,根据数据特征选兵器才是王道。下次遇到震荡市,不妨试试GARCH系模型;要是数据有明显周期规律,SARIMA可能更香。代码只是工具,理解数据内在逻辑才是真功夫。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 11:01:53

853-040482-301 RF匹配模块

853-040482-301 RF 匹配 MOK 模块 产品特点:高精度匹配对射频信号进行精确阻抗匹配,提高功率传输效率,减少信号反射。宽频带适应性支持宽频段操作,适用于多种射频应用和设备环境。低插入损耗优化电路设计,最大限度降低…

作者头像 李华
网站建设 2026/4/15 20:32:29

基于A*算法的四旋翼城市物流无人机三维路径规划MATLAB实现

使用MATLAB完成基于A*算法的无人机三维路径规划代码(单独环境创建代码80,打包所有规划及改进代码280),背景是四旋翼的城市物流无人机。做了拐弯次数改进,程序运行计时,路线远离障碍物等改进,垂直…

作者头像 李华
网站建设 2026/4/15 9:35:52

反激式开关电源设计全解析:从理论到实操

反激式开关电源全套设计资料(百度) 反激变压器参数自动计算,连续模式CCM,断续模式DCM, 联系送电源管理芯片资料,最新更新310份芯片图片和PDF资料。 变压器参数计算 原边匝数计算 副边匝数计算 原边电感量计…

作者头像 李华
网站建设 2026/4/16 10:08:19

Google Play 上架:12 人 + 14 天封测机制深度解析(2026 实操版)

为了提升应用整体质量,Google Play 自 2023 年 11 月 13 日起,对新创建的个人开发者账号新增了强制性封闭测试要求:在申请发布正式版 App 前,必须完成:至少 12 名测试用户连续 14 天 持续参与封闭测试(Clos…

作者头像 李华
网站建设 2026/4/14 15:06:40

FreeRTOS环境搭建与第一个任务创建

系列文章目录 文章目录 系列文章目录前言一、开发环境准备1. 硬件选择2. 软件工具(1) STM32CubeMX(2) Keil MDK-ARM(3) ST-Link驱动 二、使用STM32CubeMX配置FreeRTOS1. 新建项目2. 配置时钟和外设(1) 配置RCC(时钟)(2) 配置SYS(系统&#xf…

作者头像 李华
网站建设 2026/4/15 7:19:11

30、虚拟专用网络协议配置与故障排除全解析

虚拟专用网络协议配置与故障排除全解析 1. 客户端系统VPN配置 在排查VPN问题时,若已检查ISP且服务器对其他用户连接正常,下一步就需排查客户端系统。而在排查客户端连接之前,需先对客户端进行配置。 1.1 配置Windows XP Professional VPN客户端 以下是具体步骤: 1. 选…

作者头像 李华