【MATLAB第89期】基于MATLAB的差分自回归滑动平均模型ARIMA时间序列预测模型含预测未来

【MATLAB第89期】基于MATLAB的差分自回归滑动平均模型ARIMA时间序列预测模型含预测未来

往期文章
【MATLAB第82期】基于MATLAB的季节性差分自回归滑动平均模型SARIMA时间序列预测模型含预测未来

一、模型介绍

1、模型简介

差分自回归移动平均模型(Autoregressive Integrated Moving Average Model, ARIMA),又称为差分自回归移动平均模型,是时间序列预测常用的分析方法之一,常应用于不包含趋势和季节性的单变量数据的预测。

2、模型参数

ARIMA结构参数有七个:(p,d,q)

1、非季节性差分数
d:代表时序数据需要进行几阶差分化,才是稳定的,也叫Integrated项。使用ARIMA模型要求数据平稳。ARIMA的差分项有两个,非季节性差分通常在0~3之间。确定非季节性差分数d从0至3循环,平稳后停止,当检验模型参数时d=0时数据已经平稳。

2、确定ARIMA模型阶数
这个步骤中需要确定的阶数有2个:AR阶数p,MA阶数q。用基于AICBIC准则的方法定阶。
p:代表预测模型中采用的时序数据本身的滞后数(lags) ,也叫做AR/Auto-Regressive项。p通常在0~3之间,通过循环可得p=2时,AICBIC值最小。
q:代表预测模型中采用的预测误差的滞后数(lags),也叫做MA/Moving Average项。q通常在0~3之间,通过循环可得q=3时,AICBIC值最小。

3、残差检测
为了确保确定的阶数合适,还需要进行残差检验。残差即原始信号减掉模型拟合出的信号后的残余信号。如果残差是随机正态分布的、不自相关的,这说明残差是一段白噪声信号,也就说明有用的信号已经都被提取到模型中了
在这里插入图片描述

上图为残差检验的结果图。Standardized Residuals是查看残差是否接近正态分布,理想的残差要接近正态分布;ACF和PACF检验残差的自相关和偏自相关,理想的结果应该在图中不存在超出蓝线的点;最后一张QQ图是检验残差是否接近正太分布的,理想的结果中蓝点应该靠近红线。
除了上述图像检验方法,还可以通过Durbin-Watson对相关性进行检验:
Durbin-Watson 统计是计量经济学分析中最常用的自相关度量,该值接近2,则可以认为序列不存在一阶相关性。
运算结果为1.99,这个值越接近2越说明残差不存在一阶相关性。
上述检验可以证明,残差接近正态分布,且相互独立,可以认为ARIMA建模符合要求。

二、预测效果对比

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
表 ARIMA训练集和测试集预测结果评价指标
样本 RMSE MSE MAE R2
训练集 5.8556 34.2885 3.6008 0.87792
测试集 7.0661 49.9298 4.074 0.86357

表 SARIMA训练集和测试集预测结果评价指标
样本 RMSE MSE MAE R2
训练集 2.101 4.4143 0.88828 0.93821
测试集 1.6282 2.6511 1.1039 0.97196

从评价指标数值表的角度看,SARIMA相比ARIMA在销量预测上有较高的精度,测试所得的误差值较小,能深入挖掘长时间序列数据的深层规律。SARIMA对周期性波动性的挖掘较为深入。

三、部分代码展示

close all
clear all
%% 1.加载数据
xall= importdata('经营数据2.xlsx');%导入数据
time=xall.textdata;%时间数据
xnum = datenum(time(2:end,1)); % 将日期转为数值
data= xall.data(:,2);% 时间序列数据 
data1=data;
step = 12;%% 2.d从03循环,平稳后停止
for d = 0:3dY = diff(data)%对原数据进行差分运算  if(getStatAdfKpss(dY)) %数据平稳disp(['非季节性差分数为',num2str(d)]);break;end
end
%% 3.确定阶数ARlags,MALags
max_ar = 3;    %ARlags上限
max_ma = 3;    %MALags上限
id=1;
[STD1, EstMdl1, canshu] = find_pdq_arima(id,max_ar,max_ma);

四、代码获取

1.阅读首页置顶文章
2.关注CSDN
3.根据自动回复消息,回复“89期”以及相应指令,即可获取对应下载方式。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/606441.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【BIAI】Lecture 5 - Auditory system

Lecture 5 - Auditory system 专业术语 auditory system 听觉系统 pinna 耳廓 auditory canal 耳道 tympanic membrane 鼓膜 cochlea 耳蜗 ossicles 听骨 auditory-vestibular nerve 前庭神经 oval window 椭圆窗 attenuation reflex 衰减反射 tensor tympani muscle 鼓膜张肌…

网络安全与IP地址:构建数字世界的前沿堡垒

网络安全是当今数字社会中不可忽视的挑战之一。而IP地址,作为互联网通信的基础协议,既是数字化时代的桥梁,也是网络安全的关键节点。本文将剖析IP地址在网络安全领域的作用,以及如何利用其特性建立有效的网络安全策略。 IP地址&a…

LeetCode119. Pascal‘s Triangle II

文章目录 一、题目二、题解 一、题目 Given an integer rowIndex, return the rowIndexth (0-indexed) row of the Pascal’s triangle. In Pascal’s triangle, each number is the sum of the two numbers directly above it as shown: Example 1: Input: rowIndex 3 Ou…

10个linux文件管理命令

1. ls – 列出目录内容 ls可能是每个Linux用户在其终端中键入的第一个命令。它允许您列出您想要的目录的内容(默认情况下是当前目录),包括文件和其他嵌套目录。 它有很多选择,所以最好使用 --help 来获得一些帮助。此标志返回所…

卡码网Java基础课 | 6. 数组的倒序与隔位输出

卡码网Java基础课|6. 数组的倒序与隔位输出 数组ArrayList增强for循环6. 数组的倒序与隔位输出 数组 Java中的数组是一种用于存储相同数据类型的元素的数据结构。 相同数据类型的元素指的是数组中的所有元素都必须是相同的数据类型;固定大小,连续存储&…

yum安装及常用操作

yum安装及常用操作 1. 安装yum2. yum常用命令2.1. 基本语法2.2. [option] 常用选项2.3. [command] 常用命令 1. 安装yum 使用wget下载yum的安装包,这里以CentOS 7为例,如果是其他版本的系统,请根据实际情况修改下载链接,如果wget也…

华为三层交换机通 过VLANIF虚拟接口实现跨VLAN通信

S1配置 vlan batch 2 to 3interface Vlanif2ip address 192.168.2.254 255.255.255.0interface Vlanif3ip address 192.168.3.254 255.255.255.0interface GigabitEthernet0/0/2port link-type accessport default vlan 2interface GigabitEthernet0/0/3port link-type access…

DNS重绑定攻击记录(绕过同源策略、绕过IP黑名单、SSRF绕过)

目录 概念 DNS重绑定情景举例认识 DNS绑定机制 DNS重要记录类型 域名解析过程 TTL 请求域名解析

如何进行sql优化?

在日常工作中都避免不了要和各种SQL语句打交道,无论是开发还是后期维护,一条执行效率高的SQL语句都会对系统性能产生巨大影响。那么,如何进行有效的SQL优化呢?下面将为大家深入浅出地讲解SQL优化的各个方面: 1、了解数…

社科院与美国杜兰大学金融管理硕士项目——勇当开路先锋,争做事业闯将

随着金融行业的不断发展,在职金融人员面临着越来越多的机遇和挑战。在这个充满变革的时代,金融人员需要具备开拓进取的精神,勇当开路先锋,争做事业闯将。只有这样,才能在激烈的竞争中立于不败之地,为企业创…

03 详细的Git命令使用大全

常用命令&#xff1a; git init&#xff1a;初始化一个新的Git仓库。git add <文件名>&#xff1a;将文件添加到暂存区&#xff0c;准备进行提交。git commit -m "备注"&#xff1a;提交暂存区的文件到仓库&#xff0c;并添加提交备注。git status&#xff1a;…

算法32:针对算法31货币问题进行扩展,并对从左往右模型进行总结

本算法是在算法31的基础之上进行推理总结的&#xff0c;因此&#xff0c;在看本章之前&#xff0c;必须先去了解算法31&#xff0c;否则会觉得莫名其妙。 算法31的推理过程&#xff1a; 如果 x y1 y2 y3 y4 y5 y6. x1 y2 y3 y4 y5 y6 那么 x y1 x1. 根据以…

使用高版本JDK编译低版本代码

背景 SonarQube运行于Java17&#xff0c;使用Sonar的Maven插件编译时&#xff0c;如果编译使用的JDK版本低于SonarQube使用的Java17&#xff0c;则会提示Java文件不匹配问题。 Error during SonarScanner execution java.lang.UnsupportedClassVersionError: org/sonar/batch/…

Codeforces Round 911 C. Anji‘s Binary Tree

原题&#xff1a; C. Anji’s Binary Tree time limit per test 2.5 seconds memory limit per test 256 megabytes input standard input output standard output Keksic keeps getting left on seen by Anji. Through a mutual friend, he’s figured out that Anji really …

浏览器刷新页面,缓存的处理方式,强制刷新

刷新页面的缓存处理的方式对比 地址栏回车/直接访问 URL保留强缓存&#xff0c;保留协商缓存&#xff0c;走正常请求流程点击浏览器刷新按钮忽略强缓存&#xff0c;保留协商缓存按f5【command r】忽略强缓存&#xff0c;保留协商缓存ctrl f5 【command shift r 】忽略强缓…

ECharts 图表简单示例,中国地图

目录 ECharts官网链接: [ECharts](https://echarts.apache.org/zh/index.html)在项目中引入 Apache ECharts柱状图折线图饼图仪表盘中国地图完整示例代码 ECharts官网链接: ECharts 在项目中引入 Apache ECharts <!DOCTYPE html> <html><head><meta char…

JavaWeb——后端AOP面向特定方法编程

七、AOP 1. 概述 AOP&#xff08;Aspect Oriented Programming&#xff09;&#xff1a;面向切面编程、面向方法编程&#xff0c;其实就是面向特定方法编程 场景&#xff1a; 案例部分功能运行较慢&#xff0c;定位执行耗时较长的业务方法&#xff0c;此时需要统计每个业务…

数据分析:从数据中获取有价值的洞察

在当今数据驱动的世界中&#xff0c;数据分析已经成为了企业和组织取得成功的关键因素。通过对数据的深入分析&#xff0c;我们可以揭示隐藏在数据背后的模式、趋势和关系&#xff0c;从而为决策提供有力的支持。本文将探讨数据分析的重要性&#xff0c;常用的分析方法、工具和…

C语言中的关键字与标识符详解

1. 关键字(keyword) 定义&#xff1a; 关键字是C语言中预定义的一组特殊字符串&#xff0c;它们具有特定的含义和用途。在程序编译过程中&#xff0c;编译器会根据这些关键字执行相应的操作。 特点&#xff1a; 所有C语言的关键字均采用小写字母形式。 举例&#xff1a; 例如…

2024年数学建模美赛能用chatGPT之类的AI吗?官方给了明确规定!

这两年chatGPT等大语言模型火了&#xff0c;能对话&#xff0c;自然也能回答数学建模方面的问题。 那美赛能不能用这些AI呢&#xff1f;2024年美赛官方对chatGPT等的使用做出了明确的规定&#xff08;其中的VI. Contest Instructions部分&#xff09;&#xff1a; https://ww…