数学建模之灰色预测
灰色预测(Grey Forecasting)是一种用于时间序列数据分析和预测的方法,通常用于处理具有较少历史数据的情况或者数据不够充分的情况。它是一种非常简单但有效的方法,基于灰色系统理论,用来估计未来的趋势。
以下是灰色预测的基本思想和步骤:
-
建立灰色模型:首先,需要建立一个灰色模型,通常使用一些已知的历史数据。灰色模型可以是一阶、二阶等,具体的模型选择取决于数据的性质和趋势。最常用的是一阶指数灰色模型(GM(1,1))。
-
数据预处理:对原始数据进行累加运算,将原始数据序列转化为累加生成数据序列。
-
建立灰色微分方程:使用累加生成数据序列,建立灰色微分方程,然后求解微分方程的参数。
-
模型检验:对模型进行检验,检查模型拟合的程度以及预测精度。可以使用残差分析等方法来检验模型。
-
预测未来:使用建立的模型来进行未来的预测。
灰色预测方法的优点是不需要大量的历史数据,适用于小样本数据和短期预测。然而,它也有一些限制,如对数据质量要求较高,无法处理非线性关系等。
灰色预测是一种在某些情况下非常有用的时间序列分析方法,特别是在数据有限或者数据质量较差的情况下,可以作为一种可选的预测工具。
灰色预测的示例代码如下。这里使用一阶指数灰色模型(GM(1,1))来对一组示例数据进行预测。
#include <iostream>
#include <vector>
#include <cmath>// 灰色预测的一阶指数灰色模型
void greyPrediction(const std::vector<double>& data, double& a, double& b) {int n = data.size();// 累加生成序列std::vector<double> sumData(n, 0.0);for (int i = 0; i < n; ++i) {for (int j = 0; j <= i; ++j) {sumData[i] += data[j];}}// 计算累加生成数据的一次差分序列std::vector<double> diffData(n - 1, 0.0);for (int i = 0; i < n - 1; ++i) {diffData[i] = sumData[i] + sumData[i + 1] / 2.0;}// 建立灰色微分方程double X0 = data[0];double B = 0.0;for (int i = 0; i < n - 1; ++i) {B += -2 * (X0 + B / 2.0 - diffData[i]) / (n - 1);}// 计算参数 a 和 ba = X0;b = B;
}int main() {// 示例数据std::vector<double> data = {45, 55, 67, 80, 92, 103};// 预测未来两个时间点的值double a, b;greyPrediction(data, a, b);double nextValue = a + b;double nextNextValue = a + 2 * b;std::cout << "Predicted next value: " << nextValue << std::endl;std::cout << "Predicted value after that: " << nextNextValue << std::endl;return 0;
}
在这个示例中,我们使用了一组示例数据 data
,然后通过 greyPrediction
函数建立了一阶指数灰色模型,预测了未来两个时间点的值。这个示例只是一个简单的演示,实际应用中,您需要根据具体问题和数据来调整模型和参数。请注意,灰色预测方法通常需要更多的数据点来获得更准确的预测结果。
以下是使用 Python 进行灰色预测的示例代码。在这个示例中,我们将使用一阶指数灰色模型(GM(1,1))来对一组示例数据进行预测。
import numpy as np# 灰色预测的一阶指数灰色模型
def greyPrediction(data):n = len(data)# 累加生成序列sumData = np.cumsum(data)# 计算累加生成数据的一次差分序列diffData = np.zeros(n-1)for i in range(n-1):diffData[i] = sumData[i] + sumData[i+1] / 2.0# 建立灰色微分方程X0 = data[0]B = 0.0for i in range(n-1):B += -2 * (X0 + B / 2.0 - diffData[i]) / (n - 1)# 计算参数 a 和 ba = X0b = Breturn a, b# 示例数据
data = [45, 55, 67, 80, 92, 103]# 预测未来两个时间点的值
a, b = greyPrediction(data)
nextValue = a + b
nextNextValue = a + 2 * bprint("Predicted next value:", nextValue)
print("Predicted value after that:", nextNextValue)
在这个 Python 示例中,我们使用 NumPy 库来进行数组运算。首先,我们定义了 greyPrediction
函数来建立一阶指数灰色模型并预测未来两个时间点的值。然后,我们提供了示例数据 data
,并打印出预测的结果。
相关文章:
数学建模之灰色预测
灰色预测(Grey Forecasting)是一种用于时间序列数据分析和预测的方法,通常用于处理具有较少历史数据的情况或者数据不够充分的情况。它是一种非常简单但有效的方法,基于灰色系统理论,用来估计未来的趋势。 以下是灰色…...
03_nodejd_npm install报错
npm install报错 npm ERR! code ERESOLVE npm ERR! ERESOLVE unable to resolve dependency tree npm ERR! npm ERR! While resolving: 5kcrm11.0.0 npm ERR! Found: vue2.5.17 npm ERR! node_modules/vue npm ERR! vue"2.5.17" from the root project npm ERR! np…...
three.js(二):webpack + three.js + ts
用webpackts 开发 three.js 项目 webpack 依旧是主流的模块打包工具;ts和three.js 是绝配,three.js本身就是用ts写的,ts可以为three 项目提前做好规则约束,使项目的开发更加顺畅。 1.创建一个目录,初始化 npm mkdir demo cd de…...
最小二乘法处理线性回归
最小二乘法是一种数学优化技术,用于查找最适合一组数据点的函数。 该方法主要用于线性回归分析,当然,也可用于非线性问题。 开始之前,我们先理解一下什么是回归。 回归:回归是一种监督学习算法,用于建模和…...
ModbusCRC16校验 示例代码
作者: Herman Ye Galbot Auromix 测试环境: Ubuntu20.04 更新日期: 2023/08/30 注1: Auromix 是一个机器人爱好者开源组织。 注2: 本文在更新日期经过测试,确认有效。 笔者出于学习交流目的, 给…...
一不留神就掉坑
乘除顺序问题 在据卡特兰数[1]公式,解决leetcode-96 不同的二叉搜索树[2]时,遇到一个非常诡异的问题, package mainimport "fmt"func main() { for i : 0; i < 40; i { fmt.Printf("第%d个卡特兰数为:%d\n", i, numTrees(i)) }}func numTrees(n int) i…...
Redis数据类型(list\set\zset)
"maybe its why" List类型 列表类型是⽤来存储多个有序的字符串,列表中的每个字符串称为元素(element),⼀个列表最多可以存储个2^32 - 1个元素。在Redis中,可以对列表两端插⼊(push)…...
TongWeb安装以及集成
TongWeb 安装步骤 静默安装 获取linux可执行安装包 如: Install_TWx.x.x.x_Enterprise_Linux.bin 创建安装所需配置文件 install.properties 内容如下 [root@node5 tongweb]# cat install.properties INSTALL_UI=silent USER_INSTALL_DIR=/home/tongweb SILENT_JDK_HOME=/jd…...
ScreenToGif-动图制作软件实用操作
ScreenToGif官网:ScreenToGif ⭕第一步:启动页面 ⭕第二步:选项 🥝录像机-捕获频率选择手动-播放延迟1000ms(可以任意) ⭕第三步:录像机开始录屏 🥝我们调整录屏的大小后,打开画图,…...
sqlibs安装及复现
sqlibs安装 安装phpstudy后,到github上获取sqlibs源码 sqli-labs项目地址—Github获取:GitHub - Audi-1/sqli-labs: SQLI labs to test error based, Blind boolean based, Time based. 在phpstudy本地文件中的Apache目录中解压上方下载的源码。 将sq…...
OpenAI 创始人 Sam Altman 博客有一篇 10 年前的文章
OpenAI 创始人 Sam Altman 博客有一篇 10 年前的文章《Advice for ambitious 19 year olds》,给 19 岁年轻人的建议,从 #参考答案 看到,非常适合我们🤣年轻人,顺便用 GPT4 重新翻译了下全文。 太长不读纯摘要版本如下&…...
写的一款简易的热点词汇记录工具
项目需要对用户提交的附件、文章、搜索框内容等做热词分析。如下图: 公司有大数据团队。本着不麻烦别人就不麻烦别人的原则,写了一款简易的记录工具,原理也简单,手工在业务插入锚点,用分词器分好词,排掉字…...
算法通关村——滑动窗口高频问题
1. 无重复字符的最长子串 给定一个字符串 s ,请你找出其中不含有重复字符的 最长子串 的长度。 示例 1: 输入: s “abcabcbb” 输出: 3 解释: 因为无重复字符的最长子串是 “abc”,所以其长度为 3。 1.1 滑动窗口 找到最长字串需要找到字串的首尾位置…...
mybatis源码学习-2-项目结构
写在前面,这里会有很多借鉴的内容,有以下三个原因 本博客只是作为本人学习记录并用以分享,并不是专业的技术型博客笔者是位刚刚开始尝试阅读源码的人,对源码的阅读流程乃至整体架构并不熟悉,观看他人博客可以帮助我快速入门如果只是笔者自己观看,难免会有很多弄不懂乃至理解错误…...
selenium 自动化测试——环境搭建
安装python,并且使用pip命令安装 selenium pip3 install selenium 然后尝试第一次使用selenium 完成一个简单的测试自动化脚本 from selenium import webdriver from selenium.webdriver.common.by import By import timedriver webdriver.Chrome() driver.get(…...
得物一面,场景题问得有点多!
题目来源:https://www.nowcoder.com/discuss/525371909735792640 前文 本期是【捞捞面经】系列文章的第 1 期,持续更新中…。 《捞捞面经》系列正式开始连载啦,据说看了这个系列的朋友都拿到了大厂offer~ 欢迎星标订阅,持续更新…...
Prompt Tuning 和instruct tuning
Prompt Tuning 是啥? prompt的思想是,把下游任务的输入转化为预训练模型的原始任务。 以bert作为举例,假设任务是文本分类。“今天天气很好。”我们想判断一下这句话的情感是正面还是负面 fine-tune的方法是在bert之后接一个head࿰…...
springboot 与异步任务,定时任务,邮件任务
异步任务 在Java应用中,绝大多数情况下都是通过同步的方式来实现交互处理的;但是在处理与第三方系统交互的时候,容易造成响应迟缓的情况,之前大部分都是使用多线程来完成此类任务,其实,在Spring 3.x之后&a…...
2022年06月 C/C++(六级)真题解析#中国电子学会#全国青少年软件编程等级考试
C/C++编程(1~8级)全部真题・点这里 第1题:小白鼠再排队2 N只小白鼠(1 < N < 100),每只鼠头上戴着一顶有颜色的帽子。现在称出每只白鼠的重量,要求按照白鼠重量从小到大的顺序输出它们头上帽子的颜色。帽子的颜色用 “red”,“blue”等字符串来表示。不同的小白鼠可…...
【C++】C++11新特性(下)
上篇文章(C11的新特性(上))我们讲述了C11中的部分重要特性。本篇接着上篇文章进行讲解。本篇文章主要进行讲解:完美转发、新类的功能、可变参数模板、lambda 表达式、包装器。希望本篇文章会对你有所帮助。 文章目录 一…...
python内网环境安装第三方包
文章目录 一、问题二、解决方法三、代码实现 一、问题 内网安装第三方包的应用场景,一般是一些需要在没网的环境下进行开发的情况。这些环境一般仅支持本地局域网访问,所以只能在不下载任何第三方包的情况下艰难开发。 二、解决方法 将当前应用依赖的第…...
javaScipt
javaScipt 一、JavaScript简介二、javaScript基础1、输入输出语法2、变量3、常量4、数据类型4.1、数字型 number4.2、字符串类型 string4.3、布尔类型 boolean4.4、未定义类型 undefined4.5、null 空类型4.6、typeof 检测变量数据类型 5、数据类型转换5.1、隐式转换5.2、显示转…...
Linux(实操篇三)
Linux实操篇 Linux(实操篇三)1. 常用基本命令1.7 搜索查找类1.7.1 find查找文件或目录1.7.2 locate快速定位文件路径1.7.3 grep过滤查找及"|"管道符 1.8 压缩和解压类1.8.1 gzip/gunzip压缩1.8.2 zip/unzip压缩1.8.3 tar打包 1.9 磁盘查看和分区类1.9.1 du查看文件和…...
数学之美 — 1
为什么你会想和他人共享那些美丽的事物呢?因为这会让他(她)感到愉悦,也能让你在分享的过程中重新欣赏一次事物的美。 ——David Blackwell 1、感官之美,对于那些有规律的事物,你可以利用自己的视觉、触觉、…...
python中的global关键字
在Python中,global关键字用于在函数内部声明一个全局变量。默认情况下,函数内部的变量是局部变量,只能在函数内部访问。使用global关键字可以在函数内部创建或修改全局变量,使其在函数外部也可见和修改。 以下是使用global关键字…...
Matlab图像处理-幂次变换
幂次变换 如下图所示的幂次变换函数曲线图: 当γ <1时,效果和对数变换相似,放大暗处细节,压缩亮处细节,随着数值减少,效果越强。 当γ >1时,放大亮处细节,压缩暗处细节&…...
浏览器输入 URL 地址,访问主页的过程
分析&回答 浏览器解析域名;TCP建立连接;浏览器向服务器发送HTTP请求;服务器解析请求并返回HTTP报文;浏览器解析并渲染页面;断开连接。 反思&扩展 域名解析的流程 查找浏览器缓存——我们日常浏览网站时&am…...
每日一学————基本配置和管理
一、交换机的基本配置 配置enable口令、密码和主机名 Switch> (用户执行模式提示符) Switch>enable (进入特权模式) Switch# …...
解决 filezilla 连接服务器失败问题
问题描述: 开始一直用的 XFTP 后来,它变成收费软件了,所以使用filezilla 代替 XFTP 之前用的还好好的,今天突然就报错了:按要求输入相关字段,连接 连接失败!!!o(╥﹏╥…...
如何使用Java进行机器学习?
在Java中进行机器学习,可以使用各种开源机器学习库和框架来实现。以下是一些常用的Java机器学习库: Weka:Weka 是一个非常流行的机器学习库,提供了大量的算法和工具,以及用于数据预处理、特征选择和可视化的功能。 De…...
钢管网站建设/最新百度快速收录技术
FOB价格是当货物越过船舷,卖方即完成交货。FOB价格术语仅适用于海运或内河运输。在国际贸易中,FOB价格是比较常用的一种,FOB价格作为众多贸易中的一种需要外贸人员熟悉掌握。FOB价格是当货物越过船舷,卖方即完成交货。FOB价格术语…...
怎么注册网站个人/百度推广运营这个工作好做吗
市调机构TrendForce指出三季度全球电视面板价格已上涨三成,预期四季度供给紧张的局面不会缓解,液晶面板价格将会进一步上涨,这意味着已执液晶面板牛耳的中国面板企业可望取得业绩的大幅增长。TrendForce认为由于韩国两大液晶面板企业三星已放…...
凯里网站设计公司/网络营销案例分析论文
关于节点的兼容性: 1:获取元素的子节点 a: childNodes:获取元素的子节点,空文本,非空文本,注释,获取的比较全面, 如果只是想获取元素的子节点,请用…...
韶关市网站建设公司/江阴百度推广公司
您可能经常需要访问远程服务器来进行管理,管理和故障排除,并且有几种方法可以执行此操作。您可以使用telnet登录到远程服务器。 FTP允许在不同服务器之间传输文件。但是,这些程序不够安全,无法连接到关键服务器。 SSH,…...
影楼网站设计/新疆今日头条新闻
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼这几天老大让我弄一个发送短信验证码的功能,使用的是大汉云通讯的短信平台接口,调用短信平台提供的接口(遵循短信平台的接口规范即可)。具体看代码:import java.util.HashMap;import java.util.M…...
网站图片切换效果/郑州网站设计
下面是新版(v6版)一些操作的相关提示,主要是跟旧版不一样的地方一. 数据同步老用户(以前用过v5版并用邮箱注册过的用户)只能用邮箱登录,邮箱登录跟用QQ、微博、豆瓣登录是完全不同的账号,数据不互通。升级成功后,老用户登录请用邮…...