【大数据分析与挖掘模型】matlab实现——非线性回归预测模型

在这里插入图片描述

一、实验目的

掌握有关非线性回归的理论知识,通过变量代换把本来应该用非线性回归处理的问题近似转化为线性回归问题,并进行分析预测。

二、实验任务

对非线性回归实例进行编码计算,实例如下:

三、实验过程

1.运行非线性回归中的多项式预测模型,以参数m=5为例进行预测

2.对多项式预测模型进行统计检验

3.进行数据拟合,观察预测模型对原始数据的拟合结果

4.对表中客运量和旅客周转量、公路客运量和公路旅客周转量数据分别进行运算,得到非线性回归曲线方程表

四、实验结果

实现平台:Matlab 2022A

实验代码:

①多项式预测模型

% 年份和客运量的数据
years = 1987:2006;
passengers = [10091,10551,10389,10702,11078,10565,11063,25163,21697,23904,25003.7,29863,32962.2,33704,39984.4,38879.6,35156,38902,41079,43844];% 将年份和客运量数据进行多项式拟合
degree = 5; % 多项式的阶数
coefficients = polyfit(years, passengers, degree);
% 创建一个新的年份序列,用于预测
new_years = 1987:0.1:2007; % 以生成一个新的年份序列,注意:第三个值是你要预测的年份% 使用 polyval 函数计算预测的客运量
predicted_passengers = polyval(coefficients, new_years);% 绘制原始数据和预测结果
plot(years, passengers, 'o', new_years, predicted_passengers, '-');
xlabel('年份');
ylabel('客运量');
title('年份与客运量的多项式预测');
legend('原始数据', '预测结果');% 拟合优度检验
y_mean = mean(passengers);
SS_total = sum((passengers - y_mean).^2);
SS_residual = sum((passengers - polyval(coefficients, years)).^2);
R2 = 1 - SS_residual / SS_total;% F检验
n = length(passengers);
m = degree + 1; % 多项式阶数加上常数项
F = (SS_total - SS_residual) / (SS_residual / (n - m));
alpha = 0.05; % 显著性水平
F_critical = finv(1 - alpha, m, n - m); % 计算临界值% 打印结果
fprintf('拟合优度检验结果:\n');
fprintf('拟合优度(R^2)= %.4f\n', R2);fprintf('\nF检验结果:\n');
fprintf('F统计量 = %.4f\n', F);
if F > F_criticalfprintf('多项式拟合模型具有显著性\n');
elsefprintf('多项式拟合模型不具有显著性\n');
end% 打印预测模型
fprintf('预测模型:\n');
fprintf('客运量 = ');
for i = 1:degreefprintf('%.4f * 年份^%d + ', coefficients(i), degree+1-i);
end
fprintf('%.4f\n', coefficients(degree+1));

②幂函数预测模型

% 输入数据
years = 1987:2006;
passengers = [10091,10551,10389,10702,11078,10565,11063,25163,21697,23904,25003.7,29863,32962.2,33704,39984.4,38879.6,35156,38902,41079,43844];% 拟合幂函数模型
f = fittype('a * x^b'); % 定义幂函数模型
model = fit(years.', passengers.', f); % 拟合模型% 显示拟合结果
disp(model);% 绘制拟合曲线
plot(model, years, passengers,'o');
hold on; % 保持图形,添加预测结果
xlabel('年份');
ylabel('客运量');
title('幂函数拟合结果');% 进行预测
future_years = 2007; % 要预测的未来年份
predicted_passengers = model(future_years); % 预测客运量% 显示预测结果
disp('未来年份的客运量预测:');
disp([future_years; predicted_passengers].');% 将预测结果画在图上
plot(future_years, predicted_passengers, 'ro', 'MarkerSize',5); % 使用红色圆点标记预测结果
legend('已知数据', '拟合曲线', '预测结果');
hold off; % 结束图形保持

实验结果:

1.运行非线性回归中的多项式预测模型,以参数m=5为例进行预测

2.对多项式预测模型进行统计检验

3.进行数据拟合,观察预测模型对原始数据的拟合结果

4.改用幂函数模型,再次进行预测

五、个人总结

1.对非线性回归预测模型的理解

在实际问题中,非常多的变量之间都是非线性关系,我们可以通过变量代换将本来是非线性关系的问题近似地转化成线性关系,再进行分析预测。在非线性回归模型中,因变量与自变量的关系可以是曲线、指数、对数等非线性形式,而不是线性形式。

2.对编码实现过程的回顾

这个代码的实现用到了许多matlab当中特有的数学函数,在编写代码的过程当中我查阅了很多资料,以下为一部分实现此实验用到的特殊函数:

①polyfit多项式曲线拟合函数

p = polyfit(x,y,n)返回次数为 n 的多项式 p(x) 的系数,该阶数是 y 中数据的最佳拟合(基于最小二乘指标)。p 中的系数按降幂排列,p 的长度为 n+1

②polyval多项式计算函数

y = polyval(p,x) 计算多项式 p 在 x 的每个点处的值。参数 p 是长度为 n+1 的向量,其元素是 n 次多项式的系数(降幂排序)

③fittype曲线和曲面拟合的拟合类型

这个函数有很多用法,详见matlab帮助中心,这里只列出我使用的一种

aFittype = fittype(linearModelTerms) 使用 linearModelTerms 中的表达式指定的项为自定义线性模型创建拟合类型

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

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

相关文章

AJAX—— jQuery 发送 AJAX 请求

1、get 请求 $.get(url,[ data ] , [ callback ] , [ type ]) url :请求的 URL 地址 data :请求携带的参数 callback :载入成功时回调函数 type :设置返回内容格式(xml&#xf…

duilib的应用 在双屏异分辨率的显示器上 运行显示不出来

背景:win11,duilib应用,双显示器,两台分辨率相同,分别设置不同的缩放以后,应用运行以后,程序闪一下消失或者程序还在,但是UI显示不出来。 原因 窗口风格设置不合理,所以…

什么是域名?什么是泛域名?

域名 定义 域名是互联网上用于识别和定位网站或网络服务的名称。它是由一串用点分隔的字符组成,例如 “baidu.com”。就像是现实生活中建筑物的地址,方便用户在互联网的海量信息中找到特定的网站。 结构 域名从右到左依次为顶级域名(TLD&…

【Python爬虫系列】_031.Scrapy_模拟登陆中间件

课 程 推 荐我 的 个 人 主 页:👉👉 失心疯的个人主页 👈👈入 门 教 程 推 荐 :👉👉 Python零基础入门教程合集 👈👈虚 拟 环 境 搭 建 :👉👉 Python项目虚拟环境(超详细讲解) 👈👈PyQt5 系 列 教 程:👉👉 Python GUI(PyQt5)教程合集 👈👈…

【ArcGIS微课1000例】0125:ArcGIS矢量化无法自动完成面解决方案

文章目录 一、坐标系统问题二、正确使用自动完成面工具一、坐标系统问题 1. 数据库坐标系 arcgis矢量化的过程中,无法自动完成面,可能是因为图层要素没有坐标系造成的。双击数据库打开数据库属性,可以查看当前数据框的坐标系。 2. 图层坐标系 双击图层,打开图层属性,切…

csa练习1

1、修改当前主机名为rhcsa,设置当前时区为Asia/Shanghai 2、在/home/和/root目录下面创建file1文件和dir1目录 3、在/home/file1文件里面写入内容hello,welcome to home 4、在/root/file1文件里面写入当前的时间并写入内容this is administrator 5、在/r…

Etcd 可观测最佳实践

简介 Etcd 是一个高可用的分布式键值存储系统,它提供了一个可靠的、强一致性的存储服务,用于配置管理和服务发现。它最初由 CoreOS 开发,现在由 Cloud Native Computing Foundation (CNCF) 维护。Etcd 使用 Raft 算法来实现数据的一致性&…

基于GPT的智能客服落地实践

📍前言 在日常生活中,「客服」这个角色几乎贯穿着我们生活的方方面面。比如,淘宝买东西时,需要客服帮你解答疑惑。快递丢失时,需要客服帮忙找回。报名参加培训课程时,需要客服帮忙解答更适合的课程…… 基…

fpga开发环境总结

这里使用Altera(阿尔特拉)Cyclone IV E系列的EP4CE10F17C8开发为例,参考正点原子开发板手册进行总结,。 一,Quartus II介绍。 1,Quartus II 是 Altera 公司的综合性 FPGA 开发软件,可以完成从设…

软件测试人员必问的十大面试题..

在软件测试职位面试中,准备并回答一些常见的必问面试题非常重要。这些问题涵盖了软件测试的关键概念、技术和实践,帮助面试官评估你的能力和经验。理解这些问题的重要性是为了在面试中展示你的专业知识和技能,以及你在软件测试领域的实际应用…

使用RabbitMQ实现延迟消息的完整指南

在分布式系统中,消息队列通常用于解耦服务,RabbitMQ是一个广泛使用的消息队列服务。延迟消息(也称为延时队列或TTL消息)是一种常见的场景应用,特别适合处理某些任务在一段时间后执行的需求,如订单超时处理、…

零基础Java第十期:类和对象(一)

目录 一、拜访对象村 1.1. 什么是面向对象 1.2. 面向对象与面向过程 二、类定义和使用 2.1. 类的定义格式 2.2. 类的定义练习 三、类的实例化 3.1. 什么是实例化 3.2. 类和对象的说明 四、this引用 4.1. 什么是this引用 4.2. this引用的特性 一、拜访对象村 在…

使用python代码绘制好看的统计图

代码功能 上述代码使用 matplotlib 和 seaborn 生成四种不同的统计图,具体如下: 玫瑰图:在极坐标上绘制柱状图,展示不同角度的数值分布。雷达图:绘制多维数据的雷达图,用于对比不同维度的数值。热力图&am…

<项目代码>YOLOv8煤矿输送带异物识别<目标检测>

YOLOv8是一种单阶段(one-stage)检测算法,它将目标检测问题转化为一个回归问题,能够在一次前向传播过程中同时完成目标的分类和定位任务。相较于两阶段检测算法(如Faster R-CNN),YOLOv8具有更高的…

java项目之基于web的智慧社区设计与实现(springboot)

风定落花生,歌声逐流水,大家好我是风歌,混迹在java圈的辛苦码农。今天要和大家聊的是一款基于springboot的基于web的智慧社区设计与实现。项目源码以及部署相关请联系风歌,文末附上联系信息 。 项目简介: 基于web的智…

【优先算法】双指针 --(结合例题讲解解题思路)(C++)

今日鸡汤: “无人负我青云志,我自踏雪至山巅。” -徐霞客《青云志》 释义:没有人能够帮助我实现我的理想,即使面对再大的困难,我也要踏着积雪,一步步,到达山巅。 目录 1.快乐数 2.盛最多的…

【Unity 安装教程】

Unity 中国官网地址链接 Unity - 实时内容开发平台 | 3D、2D、VR & AR可视化https://unity.cn/首先我们想要安装Unity之前,需要安装Unity Hub: Unity Hub 是 Unity Technologies 开发的一个集成软件,它为使用 Unity 引擎的开发者提供了一…

大一物联网要不要转专业,转不了该怎么办?

有幸在2014年,踩中了物联网的风口,坏消息,牛马的我,一口汤都没喝上。 依稀记得,当时市场部老大,带我去上海参加电子展会,印象最深的,一些物联网云平台,靠着一份精美PPT&a…

从汇编角度看C/C++函数指针与函数的调用差异

函数指针本质上是一个指针变量,只不过这个变量保存的地址是一个函数的地址,那么直接调用函数和通过函数指针调用有没有区别呢?答案是有的,下面的代码是一个直接调用函数和通过指针调用函数的例子,使用gdb反汇编main函数…

蓝桥杯题目理解

1. 一维差分 1.1. 小蓝的操作 1.1.1. 题目解析: 这道题提到了对于“区间”进行操作,而差分数列就是对于区间进行操作的好方法。 观察差分数列: 给定数列:1 3 5 2 7 1 差分数列:1 2 2 -3 5 6 题目要求把原数组全部…