gm21模型python_GM11灰色模型

作者:桂。

时间: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 all

set(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;

end

Y = x0(2:end);

belta = pinv(G'*G)*G'*Y;

a = belta(1);

u = belta(2);

%predict

x_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;

end

x_pre(1) = x0(1);

for k = 1:n-1

x_pre(k+1) = x_pre1(k+1)-x_pre1(k);

end

结果图:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
嗨!对于使用Python实现GM(1,1)灰色预测模型,你可以按照以下步骤进行操作: 1. 导入所需的库: ``` import numpy as np import matplotlib.pyplot as plt ``` 2. 定义GM(1,1)灰色预测函数: ``` def gm11(x): n = len(x) # 累加生成 cum_x = np.cumsum(x) # 紧邻均值生成 z = (cum_x[:-1] + cum_x[1:]) / 2.0 # 紧邻均值级比生成 B = np.append(-z.reshape((n-2, 1)), np.ones_like(z.reshape((n-2, 1))), axis=1) Y = x[1:].reshape((n-1, 1)) # 矩阵运算求参数 [[a], [b]] = np.dot(np.dot(np.linalg.inv(np.dot(B.T, B)), B.T), Y) # 模型精度的后验差检验 delta = np.abs(Y - (a * z + b)) C = delta.std() / y.std() P = 1.0 * (np.abs(delta - delta.mean()) < 0.6745 * y.std()).sum() / len(delta) # 修正后的灰色预测模型 result = (x[0] - b / a) * np.exp(-a * (list(range(n)) - 1)) - (x[0] - b / a) * np.exp(-a * (list(range(n)) - 2)) # 预测数据 predict = np.abs(result - np.append(x[0], x[:-1])).tolist() return result, predict, C, P ``` 3. 输入数据并调用灰色预测函数进行预测: ``` x = np.array([1, 2, 3, 4, 5, 6]) # 输入数据 result, predict, C, P = gm11(x) # 调用GM(1,)灰色预测函数 ``` 4. 可视化结果: ``` plt.plot(list(range(len(x))), x, marker='o', label='原始数据') plt.plot(list(range(len(x))), result, marker='o', label='预测数据') plt.plot(list(range(len(x))), predict, marker='o', label='残差') plt.xlabel('x') plt.ylabel('y') plt.legend() plt.show() ``` 这样,你就可以使用Python编写GM(1,1)灰色预测模型了。希望对你有所帮助!如有其他问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值