Matlab怎么实现灰色预测
发表于:2025-01-19 作者:千家信息网编辑
千家信息网最后更新 2025年01月19日,这篇文章主要介绍"Matlab怎么实现灰色预测"的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇"Matlab怎么实现灰色预测"文章能帮助大家解决问题。模型介绍略微
千家信息网最后更新 2025年01月19日Matlab怎么实现灰色预测
这篇文章主要介绍"Matlab怎么实现灰色预测"的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇"Matlab怎么实现灰色预测"文章能帮助大家解决问题。
模型介绍
略微带过一下原理:
灰色预测对于趋势不强的数据,将其原始数据进行累加后得到具有明显趋势的新数据进行拟合,假设原数据为:
则新数据集X(1)中数据为:
通常认为累加数据服从指数分布,欸那我们直接假设:
直接进行一个非线性拟合不就完事了,但是,从小学二年级开始,老师就教导我们,像这用指数函数拟合啊,各个参数的变化对于整体曲线的影响效果差别很大啊,直接拟合误差会很大啊,怎么能给他整成一个线性拟合啊?(直接拟合我有试过,能够大体描述趋势并做出预测,但是误差会比灰色预测大一点)。
指数函数一般符合一个微分方程:
解常微分方程易得:
这样我们只需要将a,u这俩常数求出来就能得到x(1)(t) ,就能得到X(1)序列然后逐项做差就能得到X(0)序列。
当k≤t≤k+1时,有:
带入回之前的微分方程就有:
实际上直接进行线性拟合就好了,当然我们也可以拿最小二乘法装模作样的分析一下,令:
基础代码
核心代码非常短,只有六行,代码中给出了详细的注释,基础绘图还是MATLAB风比较简陋,后面会给出图像修饰代码。
X0=[15 16.1 17.3 18.4 18.7 19.1 19.9 21.3 22.5];t=1:9; % 原始数据自变量范围pt=10:12; % 预测数据自变量范围X1=cumsum(X0); % 累加生成趋势明显新序列Z=X1(1:end-1)+diff(X1)./2; % 均值,即(X1(1:end-1)+X1(2:end))./2a_u=polyfit(-Z,X0(2:end),1); % a_u=(B'*B)\B'*Y,B=[-Z,ones]a=a_u(1);u=a_u(2);P=(X1(1)-u/a)./exp(a.*([t,pt]-1))+u/a; % 求X1拟合值P=[P(1),diff(P)]; % X1逐项做差求预测值% 绘图plot([t,pt],P,'*-');hold onplot(t,X0,'s-') legend('预测值','真实值');
基础代码+修饰
X0=[15 16.1 17.3 18.4 18.7 19.1 19.9 21.3 22.5];t=1:9; % 原始数据自变量范围pt=10:12; % 预测数据自变量范围X1=cumsum(X0); % 累加生成趋势明显新序列Z=X1(1:end-1)+diff(X1)./2; % 均值,即(X1(1:end-1)+X1(2:end))./2a_u=polyfit(-Z,X0(2:end),1); % a_u=(B'*B)\B'*Y,B=[-Z,ones]a=a_u(1);u=a_u(2);P=(X1(1)-u/a)./exp(a.*([t,pt]-1))+u/a; % 求X1拟合值P=[P(1),diff(P)]; % X1逐项做差求预测值% 绘图plot([t,pt],P,'s-','Color',[82,124,179]./255,'MarkerFaceColor',[82,124,179]./255,... 'MarkerEdgeColor',[1,1,1],'LineWidth',2,'MarkerSize',16) hold onplot(t,X0,'d-.','Color',[169,64,71]./255,'MarkerFaceColor',[169,64,71]./255,... 'MarkerEdgeColor',[1,1,1],'LineWidth',2,'MarkerSize',16) % 增添图例lgd=legend('fitting result','original data');lgd.Location='best';lgd.FontSize=16;% 坐标区域修饰ax=gca;grid on;box offax.LineWidth=2;ax.Color=[249,250,245]./255;ax.XMinorTick='on';ax.YMinorTick='on';ax.GridLineStyle='-.';ax.XColor=[1,1,1].*.2;ax.YColor=[1,1,1].*.2;ax.FontName='Cambria';ax.FontSize=14;
关于"Matlab怎么实现灰色预测"的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注行业资讯频道,小编每天都会为大家更新不同的知识点。
数据
灰色
代码
趋势
序列
自变量
范围
原始
明显
微分方程
基础
微分
指数
方程
知识
预测值
绘图
很大
指数函数
函数
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
网络安全有必要学算法吗
产品数据库意义是什么
数据库取值中文乱码java
广东科技学院的互联网工程
网络安全保护等级包含动作规程
腾讯软件开发测试方向
母鸡看家连接不到服务器
海南州软件开发商家
吉林刀片服务器虚拟主机
心动网络 java服务器
国金证券软件开发待遇好吗
加强智能网联汽车网络安全
没有服务器的app怎么管理
软件开发怎么设置试用期
数据库编程软件多少钱
数据库建主键
计算机网络技术都考啥
网络安全企业的劣势
网络安全职业技能竞赛报名
数据库安装步骤重启失败
挖财网络技术有限公司规模多大
利用电脑做服务器建网站
华事达互联网科技
保护网络安全手抄报的内容
绿盟 网络安全态势感知
一般数据库隔离级别
腾讯买的服务器可以退吗
网络安全审计 日志审计
名片制作软件开发
cdn 缓存服务器