Matlab怎么实现灰色预测
发表于:2024-12-13 作者:千家信息网编辑
千家信息网最后更新 2024年12月13日,这篇文章主要介绍"Matlab怎么实现灰色预测"的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇"Matlab怎么实现灰色预测"文章能帮助大家解决问题。模型介绍略微
千家信息网最后更新 2024年12月13日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安全错误
数据库的锁怎样保障安全
如何制作数据库用于查询
网络安全 中职 培养方案
黑魂三无法登陆服务器2022
大学生零基础学软件开发
兴弘网络技术有限公司
镇江企业网络安全准入控制系统
数据库控件怎么安装
服务器的管理后台
体育科技与互联网技术
oncomine数据库关闭了
cms系统连接数据库
db2数据库PVU
数据库封锁的特点
一个服务器有多少高阶督军
软件开发工程师工作特点
成都信息安全相关培训网络安全
电脑数据库fox
软件开发主修课程是什么
浦东新区无线网络技术包括什么
目前网络安全现状及发展趋势
肇庆智能家居软件开发公司
工行软件开发中心社招笔试
数据库物理设计的内容有几方面
pubg2服务器推荐
oncomine数据库关闭了
按键精灵计算数据库
外盘期货软件开发公司哪家强
河西租房软件开发
电视网络安全性怎么更改
网络安全维护口号