博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
GM11灰色模型
阅读量:6117 次
发布时间:2019-06-21

本文共 1279 字,大约阅读时间需要 4 分钟。

作者:桂。

时间:2017-08-12  08:34:06

链接: 


前言

  灰色模型(Gray model)常用来对数据进行预测,这里简要记录其思路。

一、名称由来

灰色模型(Gray Model),邓聚龙教授1982年提出。
  常见系统分类:
  • 白色系统是指一个系统的内部特征是完全 已知的,即系统的信息是完全充分的。
  • 黑色系统是指一个系统的内部信息对外界来说是一无所知的,只能通过它与外界的联系来加以观测研究。
  • 灰色系统内的一部分信息是已知的,另一部分信息是未知的,系统内各因素间有不确定的关系。
通常成灰色预测模型为GM(n,h)模型,常用来预测的是GM(1,1):

二、算法原理

  A-模型建立
有观测序列:
计算一阶累加序列:
其中
假设生成序列的一阶模型( 核心思想):
对其积分(连续转化为离散):
从而上式转化为:
其中:
借助矩阵表示:
这便是一个 问题。
   B-参数求解
定义:
计算均值生成序列:
得出参数估计
  C-序列预测
这里取

将其带入上面一阶方程解(参数已求出)

取t为离散值(t = k+1)

这样便完成了预测。

三、代码实现

主函数

clc;clear all;close allset(0,'defaultfigurecolor','w');%{参考:《离散模型与灰色预测模型建模机理》,谢乃明,刘思峰本程序主要用来计算根据灰色理论建立的模型的预测值。应用的数学模型是 GM(1,1)。原始数据的处理方法是一次累加法。%}f = @(t,b)(0.3*t.^2+b+0.3*randn(1,length(t)));%定义待预测函数t = 0:.2:5;b = 3;x0 = f(t,b);x_pre = GM11(x0);plot(t,x0,'k',t,x_pre,'r--');xlabel('时间(年)');ylabel('幅度');title('GM11预测模型');legend('原始数据','预测数据');

GM11的function:

function x_pre = GM11(x0)x0 = x0(:);n = length(x0);x1 = cumsum(x0);for i = 1:n-1    G(i,1) = -(x1(i)+x1(i+1))/2;    G(i,2) = 1;endY = x0(2:end);belta = pinv(G'*G)*G'*Y;a = belta(1);u = belta(2);%predictx_pre1 = zeros(n,1);x_pre = x_pre1;for k = 0:n-1    x_pre1(k+1) = (x0(1)-u/a)*exp(-a*k)+u/a;endx_pre(1) = x0(1);for k = 1:n-1    x_pre(k+1) = x_pre1(k+1)-x_pre1(k);end

结果图:

转载于:https://www.cnblogs.com/xingshansi/p/7348714.html

你可能感兴趣的文章
写给对前途迷茫的朋友:五句话定会改变你的人生
查看>>
并行程序设计学习心得1——并行计算机存储
查看>>
JAVA入门到精通-第86讲-半双工/全双工
查看>>
bulk
查看>>
js document.activeElement 获得焦点的元素
查看>>
C++ 迭代器运算
查看>>
【支持iOS11】UITableView左滑删除自定义 - 实现多选项并使用自定义图片
查看>>
day6-if,while,for的快速掌握
查看>>
JavaWeb学习笔记(十四)--JSP语法
查看>>
【算法笔记】多线程斐波那契数列
查看>>
java8函数式编程实例
查看>>
jqgrid滚动条宽度/列显示不全问题
查看>>
在mac OS10.10下安装 cocoapods遇到的一些问题
查看>>
angularjs表达式中的HTML内容,如何不转义,直接表现为html元素
查看>>
css技巧
查看>>
Tyvj 1728 普通平衡树
查看>>
[Usaco2015 dec]Max Flow
查看>>
javascript性能优化
查看>>
多路归并排序之败者树
查看>>
java连接MySql数据库
查看>>