GM(1,1)灰色预测及相关检验指标的MATLAB实现

2023-05-16

本篇文章的代码实现了以下三大方面的功能:

  • 一、计算级比和光滑比并做级比检验;
  • 二、序列的灰色预测;
  • 三、精度检验,主要做了以下内容:
  • ①相对残差Q检验(MAPE);
  • ②关联度检验;
  • ③方差比C检验;
  • ④小误差概率P检验

1 灰色预测模型

本部分内容参照了王佳佳的硕士学位论文《京津冀地区高速铁路对区域经济影响研究》,我觉得这篇论文讲灰色预测讲得蛮详细的,如果想学灰色预测的可以看看。

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

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

2 MATLAB实现

理论讲了一大堆,但实际实现起来却很容易,见代码:

function [G, params] = GM(A)
% G为预测数据,Q为相对残差Q检验,C为方差比C检验
% p为小误差概率p检验

%建立符号变量a(发展系数)和b(灰作用量)
% syms a b;
% c = [a u]';
n = length(A);
%% 级比检验
% 对原始数列 A 做累加得到数列 B
B = cumsum(A);

% 计算级比和光滑比
sig = zeros(1,n);
rho = zeros(1,n);
for i = 2:n
    sig(i) = B(i)/B(i-1);
    rho(i) = A(i)/B(i-1);
end

if sum(sig(4:end) >=2 ) == 0 && sum(rho(5:end) >= 0.5) == 0
    disp('数据满足光滑条件和指数规律')
else
    disp('数据不满足光滑条件和指数规律')
end

%% 数据预测
% 对数列 B 做紧邻均值生成
C = zeros(n,1);
for i = 2:n
    C(i) = (B(i) + B(i - 1))/2;  
end
C(1) = [];

% 构造数据矩阵 
B = [-C,ones(n-1,1)];
Y = A; Y(1) = []; 

% 使用最小二乘法计算参数 a(发展灰数)和b(内控制灰数)
c = inv(B'*B)*B'*Y;
a = c(1);
u = c(2);

% 预测后续数据
F(1) = A(1);
for i = 2:n+2    % 预测两年的数据
    F(i) = (A(1)-u/a)/exp(a*(i-1))+ u/a;
end

% 对数列 F 累减还原,得到预测出的数据
G(1) = A(1);
for i = 2:n+2  
    G(i) = F(i) - F(i-1); %得到预测出来的数据
end
G = G';

%% 精度检验
H = G(1:n);
% 计算残差序列
epsilon = A - H;

% 法一:相对残差Q检验(MAPE)
% 计算相对残差
delta = abs(epsilon./A);
% 计算相对误差平均值Q
Q = mean(delta);
% 计算所对应的的绝对误差百分比
MAPE = abs(sum(epsilon./A)/(n-1))*100;

% 法二:关联度检验
r = sum((min(min(abs(epsilon)))+0.5*max(max(abs(epsilon))))./(abs(epsilon)+0.5*max(max(abs(epsilon)))))/n;

% 法三:方差比C检验
C = std(epsilon, 1)/std(A, 1);

% 法四:小误差概率P检验
S1 = std(A, 1);
tmp = find(abs(epsilon - mean(epsilon))< 0.6745 * S1);
P = length(tmp)/n;

params = [a,u,r,C,P,MAPE];
end
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

GM(1,1)灰色预测及相关检验指标的MATLAB实现 的相关文章

  • Command ‘[‘where‘, ‘cl‘]‘ returned non-zero exit status 1.

    在环境变量中Path 那一项中添加两个路径 xff1a 在环境变量中新建一个LIB 变量 xff0c 并添加三个路径 xff08 记得加分号 xff09 xff1a 在环境变量中新建一个INCLUDE 变量 xff0c 并添加两个路径 xf
  • 尝试DCGAN+Self Attention

    先看一下DCGAN的G模型 xff1a 再看一下Self Attention的网络结构 xff1a 话不多说 xff0c 上代码 xff1a G D的model文件如下 xff1a import torch import torch nn
  • 2022基于GAN的去雾去雨论文

    目录 去雨CVPR2022 xff1a 使用双重对比学习的不成对深度图像去雨 去雨CVPR2021 xff1a 闭环 xff1a 通过解开图像转换生成和去除联合雨 去雨CVPR2021 xff1a 从雨水产生到雨水清除 去雾CVPR2020
  • Single image dehazing for a variety of hazescenarios using back projected pyramid network

    论文名 xff1a Single image dehazing for a variety of haze scenarios using back projected pyramid network 基于反投影金字塔网络的多雾场景单幅图像
  • Yolov7论文详解

    论文地址 xff1a https arxiv org pdf 2207 02696 pdf https arxiv org pdf 2207 02696 pdf 项目地址 xff1a WongKinYiu yolov7 Implementa
  • python logging 配置 输出 测试 根据时间生成日志文件,每天一个日志文件

    链接 https www cnblogs com xianyulouie p 11041777 html 链接 https www cnblogs com nancyzhu p 8551506 html 使用config惊醒logging配
  • 201809-3-元素选择器

    试题编号 xff1a 201809 3 试题名称 xff1a 元素选择器 时间限制 xff1a 1 0s 内存限制 xff1a 256 0MB 问题描述 xff1a import java util public class Main pu
  • VTK三维重建面绘制算法之MC表面重建

    面绘制 面绘制算法是基于表面实现的一种三维重建算法 该类算法实现的响应速度快 xff0c 对于一些实时的交互操作中不存在卡顿问题 xff0c 在日常使用中有助于提高处理效率 xff0c 但该算法在细节特征上的重建效果是不如体绘制方法 基于算
  • git clone 换源 / GitHub 国内镜像

    由于国内政策原因 xff0c 访问 GitHub 会被限制速度 xff0c 在 clone GitHub 上的代码时很容易出现连接超时的情况 xff0c 给无法翻墙的同学造成了很多困扰 xff0c 本博客旨在提供有效的国内镜像 xff0c
  • 安卓与串口通信-实践篇

    前言 在上一篇文章中我们讲解了关于串口的基础知识 xff0c 没有看过的同学推荐先看一下 xff0c 否则你可能会不太理解这篇文章所述的某些内容 这篇文章我们将讲解安卓端的串口通信实践 xff0c 即如何使用串口通信实现安卓设备与其他设备例
  • STM32复习之路——按键控制流水灯中断

    stm32复习之路1 STM32性能与结构 这里介绍的是STM32F103VET6 价格便宜 xff0c 实用性强 xff0c 其中的V为100引脚 xff0c E表示512K的FLASH xff0c T表示封装形式为LQFP xff0c
  • NXP LPC1768最小系统板Keil开发环境流程演示

    关键字 xff1a NXP LPC1768 最小系统 Keil MDK 开发环境 J Link 仿真器 概述 xff1a 以 MDK4 74版本配合 J Link 仿真器为例演示一下最小系统板的调试过程 首先运行 J Link Comman
  • ubuntu 下查看conda镜像源配置文件并修改

    查看源 xff1a conda config show sources root condarc为配置文件所在位置 xff0c 可以对其进行备份 cp condarc condarc bkp 然后修改 ls a vim condarc添加各
  • vscode+cmake配置普通c++项目

    目录 写在前面代码命令行编译与运行vscode配置编译与调试调试参考 写在前面 1 本文内容 vscode 43 cmake配置普通c 43 43 项目 2 平台 ubuntu vscode 3 转载请注明出处 xff1a https bl
  • Vscode 使用Remote-SSH 连接到虚拟机ubuntu18.04(以及遇到的错误和解决办法)

    vscode版本 xff1a 1 40 0 ubuntu xff1a 18 04 一 vscode安装remote ssh插件 二 设置要连接的主机IP地址和用户名 1 Crtl 43 P呼出命令栏 xff0c 输入 gt Remote S
  • 7、结构体之结构体数组

    结构体这块本来学着没有什么问题的 xff0c 但是 xff0c 有时候的学习不知道怎么的 xff0c 可能是课程进度有点快 xff0c 会让自己把前面的知识点与现学的联系起来 xff0c 从而使自己迷惑起来 好了 xff0c 先说问题 xf
  • 输入n个数字,并求出它们中间的最大值与最小值

    做题觉得简单 xff0c 拿着编译器一编程就各种小毛病出来了 xff0c 这样下去的进度就太慢了 既然是n个数 xff0c 那么肯定就要有输入 xff0c 定义一个数组a 5 来接收从键盘输入的数字 xff0c 怎么将接收的数值依次传入数组
  • 二叉树和堆(理论)

    树 1 树其实就是不包含回路的连通无向图 2 一棵树中的任意两个结点有且仅有唯一的一条路径连通 3 一棵树如果有n个结点 xff0c 那么它一定恰好有n 1条边 二叉树 二叉树是一种特殊的树 二叉树的特点是每个结点最多有两个儿子 xff0c
  • 十进制转八进制

    给一个十进制数 xff0c 输出它的八进制数 由于取余所得得到数需要逆序输出 xff0c 符合栈的特征 xff08 后进先出 xff09 xff0c 所以使用栈来完成 源代码 xff1a include lt stdio h gt incl
  • 矩阵各项求和

    include span class token generics function span class token punctuation lt span stdio span class token punctuation span

随机推荐