数学建模【GM(1, 1)灰色预测】

一、GM(1, 1)灰色预测简介

乍一看,这个名字好奇怪,其实是有含义的

  • G:Grey(灰色)
  • M:Model(模型)
  • (1, 1):只含有一个变量的一阶微分方程模型

提到灰色,就得先说说白色和黑色

白色系统

  • 典型例子:电阻器件
  • 特点:内部特征是完全已知的,电压、电流和电阻之间的关系(欧姆定律)是已知的
  • 知道电阻大小后,输入电压值,就能算出电流值
  • 白色系统课“计算”出想要的结果

黑色系统

  • 典型例子:一辆车
  • 特点:内部特征是完全未知的,开车并不需要懂发动机设计和工作原理等
  • 非专业人士虽然可以控制汽车,然而内部出故障时并不会修
  • 黑色系统具有“不可知性”

灰色系统

  • 典型例子:GDP就是灰色系统
  • 特点:介于黑色和白色之间,部分已知,部分未知,具有小样本数据的不确定系统
  • 我们有往年的数据和一定的理论基础(白色)
  • 但无法精确计算得出下一年的值(黑色)
  • 灰色无法“计算”,但并不是完全“不可知”,可以进行“预测”

二、适用赛题

数列预测

  • 特点:定时求量,已知xx年到xx年的数据,请预测下一年的数值
  • 常见GDP、人口数量、耕地面积、粮食产量等问题
  • 针对的问题往往短期波动小、可预测,但长期可能变化大、难以准确预测

灾变预测

  • 特点:定量求时,已知xx年到xx年的数据和某灾变的阈值,预测下一次灾变发生的时间
  • 常见洪涝灾害、虫灾等问题
  • 模型中需要把超出阈值的数据(异常数据)对应的时间组成新序列

拓扑预测

  • 特点:对数据波形进行预测,求的是多个模型构成的模型群,等于求解多个灾变预测
  • 与灾变预测类似,不过有较详细的分级,例如虫灾“轻微”“中度”“重度”

注意事项

  • 需要的数据量少,而且数据量太多了没意义,例如用近100年去预测下一年毫无意义
  • 只能短期预测,究竟多短没有严格限制

三、模型流程

四、流程分析

这里以一个例子贯穿流程分析

问题是预测下一年噪声数据

这个题目特点:数据少、看不出明显规律,适合用灰色预测

1.级比检验和平移变换

为了不让我们一顿操作猛如虎,一看预测不可靠,我们可以在开始之前对数据进行检验,确定原始数据GM(1, 1)模型的可行性。

这里

是原始数据的意思

如果在区间外,可尝试平移变换。也就是给每个数据都加上任意常数c后看是否在区间内,求解后再减去c。如果尝试多次平移变换后始终无法在区间内,说明题目不适合灰色预测。

2.累加数据

因为原始数据看不出什么规律,所以我们要进行操作制造规律,一般是累加数据

弱化其随机性,显现其规律性

3.构造方程

生成的新序列,看起来像一个指数曲线。因此可用一个指数曲线的表达式来逼近这个新序列,相应可构建一个一阶常微分方程来求解拟合指数曲线的函数表达式。

要预测下一年数值,就需要知道新序列的表达式,那就要解出微分方程。要解微分方程,就要先知道参数a和u

4.求参数

5.求解方程和预测值

拟合值与预测值

  • 因为第1到7年的噪声数据是已知的,那么通过微分方程的函数解求出的值就是拟合值
  • 拟合值与实际值的偏差,代表了模型的优劣
  • 偏差越小,模型越好。偏差过大说明有问题,所以下一步需要拟合值进行模型检验
6.检验

至此,预测完成。

注:笔者在CSDN上打不出那些变量符号,所以一些难打的符号都是以截图形式呈现

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/704217.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

大数据开发项目--音乐排行榜

环境:windows10,centos7.9,hadoop3.2、hbase2.5.3和zookeeper3.8完全分布式; 环境搭建具体操作请参考以下文章: CentOS7 Hadoop3.X完全分布式环境搭建 Hadoop3.x完全分布式环境搭建Zookeeper和Hbase 1. 集成MapReduce…

消息中间件之RocketMQ源码分析(十八)

Broker CommitLog索引机制中的构建过程 1.创建ConsumeQueue和IndexFile。 ConsumeQueue和IndexFile两个索引都是由ReputMessageService类创建的 RequestMessageService类图 ReputMessageService服务启动后的执行过程。 doReput()方法用于创建索引的入口,通常通过…

运用工具Postman快速导出python接口测试脚本

Postman的脚本可以导出多种语言的脚本,方便二次维护开发。 Python的requests库,支持python2和python3,用于发送http/https请求 使用unittest进行接口自动化测试 一、环境准备 1、安装python(使用python2或3都可以)…

【数据结构与算法】常用算法 前缀和

🎉🎉欢迎光临🎉🎉 🏅我是苏泽,一位对技术充满热情的探索者和分享者。🚀🚀 🌟特别推荐给大家我的最新专栏《数据结构与算法:初学者入门指南》📘&am…

离散数学——树思维导图

离散数学——树思维导图 文章目录 前言内容大纲参考 前言 这是当初学习离散数学时整理的笔记大纲,其中包含了自己对于一些知识点的体悟。现将其放在这里作为备份,也希望能够对你有所帮助。 当初记录这些笔记只是为了在复习时更快地找到对应的知识点。…

Python爬虫之极验滑动验证码的识别

极验滑动验证码的识别 上节我们了解了可以直接利用 tesserocr 来识别简单的图形验证码。近几年出现了一些新型验证码,其中比较有代表性的就是极验验证码,它需要拖动拼合滑块才可以完成验证,相对图形验证码来说识别难度上升了几个等级。本节将…

如何在Linux部署Portainer并结合内网穿透远程管理本地Docker容器

文章目录 前言1. 部署Portainer2. 本地访问Portainer3. Linux 安装cpolar4. 配置Portainer 公网访问地址5. 公网远程访问Portainer6. 固定Portainer公网地址 前言 Portainer 是一个轻量级的容器管理工具,可以通过 Web 界面对 Docker 容器进行管理和监控。它提供了可…

用c# 自己封装的Modbus工具类库源码

前言 Modbus通讯协议在工控行业的应用是很多的,并且也是上位机开发的基本技能之一。相关的类库也很多也很好用。以前只负责用,对其并没有深入学习和了解。前段时间有点空就在这块挖了挖。想做到知其然还要知其所以然。所以就有了自己封装的Modbus工具类库…

Mysql 常用数据类型

数值型(整数)的基本使用 如何定义一个无符号的整数 数值型(bit)的使用 数值型(小数)的基本使用 字符串的基本使用 字符串使用细节 日期类型的基本使用

Orange3数据预处理(列选择组件)数据角色及类型描述

在Orange3的文件组件中,datetime、categorical、numeric以及text代表不同种类的数据类型,具体如下: datetime:代表日期和时间类型的数据。通常用于时间序列分析、生存分析和其他需要考虑时间因素的机器学习任务中。例如&#xff0…

图像读取裁剪与人脸识别

图像读取 Image read ⇒ \Rightarrow ⇒ torchvision.datasets from torchvision import datasets dataset datasets.ImageFolder(data_dir, transformtransforms.Resize((512, 512)))Return value illustration dataset[0][0]是PIL.Image objects,这利用IPyth…

小红书关键词爬虫

标题 1 统计要收集的关键词,制作一个文件夹2 爬取每一页的内容3 爬取标题和内容4 如果内容可以被查看,爬取评论内容5 将结果进行汇总,并且每个帖子保存为一个json文件,具体内容6 总结1 统计要收集的关键词,制作一个文件夹 例如,我要收集旅游相关的,就收集: 旅游、旅行…

关系型数据库事务的四性ACID:原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)和持久性(Durability)

关系型数据库事务的四性ACID:原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)和持久性(Durability) 事务的四性通常指的是数据库事务的ACID属性,包括原子性&…

Python从入门到精通指南【第101篇—入门到精通】【文末送书-24】

文章目录 Python从入门到精通指南第一步:入门基础1.1 安装Python1.2 Hello World1.3 变量和数据类型1.4 控制流程 第二步:深入学习2.1 函数和模块2.2 列表、元组和字典2.3 文件操作 第三步:高级主题3.1 面向对象编程3.2 异常处理3.3 正则表达…

大型电商日志离线分析系统(一)

一、项目需求分析 某大型网站日志离线分析系统 1.1 概述 该部分的主要目标就是描述本次项目最终七个分析模块的页面展示。 1.2 工作流 在我们的demo展示中,我们使用jqueryecharts的方式调用程序后台提供的rest api接口,获取json数据,然后…

《极简C++学习专栏》之结束语

朋友们,经过这么长的时间,《极简C学习专栏》的文章创作就要结束了,感谢你们一路陪伴! 也希望你们能支持我接下来的其他专栏的创作! 专栏的初衷 《极简C学习》专栏的初衷源自于我个人的学习笔记,记录下自己…

网络安全与信创产业发展:构建数字时代的护城河

✨✨ 欢迎大家来访Srlua的博文(づ ̄3 ̄)づ╭❤~✨✨ 🌟🌟 欢迎各位亲爱的读者,感谢你们抽出宝贵的时间来阅读我的文章。 我是Srlua,在这里我会分享我的知识和经验。&#x…

数字人的未来:数字人对话系统 Linly-Talker + 克隆语音 GPT-SoVITS

🚀数字人的未来:数字人对话系统 Linly-Talker 克隆语音 GPT-SoVITS https://github.com/Kedreamix/Linly-Talker 2023.12 更新 📆 用户可以上传任意图片进行对话 2024.01 更新 📆 令人兴奋的消息!我现在已经将强…

Vue | (六)使用Vue脚手架(下)| 尚硅谷Vue2.0+Vue3.0全套教程

文章目录 📚Vue 中的自定义事件🐇使用方法🐇案例练习🐇TodoList案例优化 📚全局事件总线🐇使用方法🐇案例练习🐇TodoList案例优化 📚消息订阅与发布🐇使用方法…

嵌入式C语言(一)

最初我是golang出生,当时做项目的时候java、c、js、python都折腾过,但是关于c语言的接触,基本上都停留在大一的那个暑假。 后面一个项目需要写驱动,再到后门需要做DFX,再到我打开内核的源码,我一脸懵逼&am…