MATLAB线性函数拟合并预测

news2024/11/20 10:41:18

线性函数拟合,由线性函数很好描述的一个数集,也就是说如果我们所考虑的数据是以y=(x)的形式给出,并且其中f(x)满足:

y=mx+b

要求得 m 和b的值,我们可以使用一个称为 polyii(x,y,n)的 MATLAB 函数,其中n是我们要 MATLAB 求出的多项式的次数,对于y= mx+b 形式的方程,我们把n设为等于 1,因此调用的语句将是 polyfit(x,y,1)。polyfit函数采用最小二乘法计算。

示例:

首先输入数据:

H=[6:2:24];
A=[3.94,3.8,4.1,3.87,4.45,4.33,4.12,4.43,4.6,4.5];
x=H
y=A

接着调用 pobyit 让 MATLAB 计算拟合数据的多项式的系数。

p=polyfit(x,y,1)

m=p(1)
b=p(2)
y=m*x+b

 画出拟合图形:

x=[1:0.1:24];
y=m*x+b
plot(H,A,'o',x,y),xlabel('差点'),ylabel('平均成绩')

运行结果如下:

看看本例中由拟合直线对特定的差点所预计的成绩值的情况

w=H*m+b
% 3.8616    3.9399    4.0182    4.0965    4.1748    4.2532    4.3315    4.4098    4.4881    4.5664

 计算r平方程序如下所示:

Mean=mean(A)
S=sum((A-Mean).^2);
A1=sum((A-w).^2);
r2=1-A1/S
%0.6899

r平方为0.6899,说明拟合效果一般。

往前预测三步,并且画出95%的置信区间代码如下(完整版):

clc;
clear;
% 导入数据
H = [6:2:24];
A = [3.94, 3.8, 4.1, 3.87, 4.45, 4.33, 4.12, 4.43, 4.6, 4.5];
x = H;
y = A;
a = [x; y];
a1 = a(1, :);
[a1, pos] = sort(a1);
a2 = a(2, pos);
% 多项式拟合
[p, s] = polyfit(a1, a2, 2);
fprintf("拟合系数分别为:%f %f\n", p(1), p(2));
y1 = polyval(p, a1);
% 95% 预测区间计算:
[yfit, dy1] = polyconf(p, x, s);
% 95% 置信区间计算:
[yfit, dy] = polyconf(p, a1, s, 'predopt', 'curve');
% 往前预测三个数
x_pred = [26, 28, 30];
[y_pred, delta] = polyval(p, x_pred, s);
% 绘制图表
figure;
hold on;
plot(a1, y1 + dy, 'r--', a1, y1 - dy, 'r--', a1, y1 + dy1, 'y--', a1, y1 - dy1, 'y--', 'LineWidth', 1.5);
plot(a1, y1, 'k', 'LineWidth', 1.5);
scatter(x, y, 'k', 'filled'); % 原始数据点
scatter(x_pred, y_pred, 'r', 'filled'); % 往前预测的数据点标红
plot(x_pred, y_pred + delta, 'r--'); % 预测区间上界
plot(x_pred, y_pred - delta, 'r--'); % 预测区间下界
xlabel('H');
ylabel('A');
title('多项式拟合结果及预测');
grid on;
% 计算 R^2
A1=sum((y1 - a2).^2);
S=sum((a2 - mean(a2)).^2);
r2 = 1-A1/S;
fprintf("R^2 值为:%f\n", r2);

运行结果如下:

 

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

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

相关文章

ubuntu18.04系统编译openwrt21.02.3

搭建ubuntu18.04环境 使用虚拟机安装ubuntu环境网上教程很多,这里不做赘述,主要是安装一些我们在编译openwrt时可能会用到的一些工具环境 sudo apt-get update sudo apt instll libncurses-dev gawk sudo apt-get install build-essential libncurses5…

InternLM2-lesson5

目录 大模型部署挑战常用大模型部署方式模型剪枝(Pruning)知识蒸馏量化 LMDeploy核心功能性能表现支持部署的模型 作业配置 LMDeploy 运行环境以命令行方式与 InternLM2-Chat-1.8B 模型对话 大模型部署 大模型部署就是将大模型在特定的环境种运行!可以部署到服务器…

The Clock and the Pizza [NeurIPS 2023 oral]

本篇文章发表于NeurIPS 2023 (oral),作者来自于MIT。 文章链接:https://arxiv.org/abs/2306.17844 一、概述 目前,多模态大语言模型的出现为人工智能带来新一轮发展,相关理论也逐渐从纸面走向现实,影响着人们日常生活…

VPP 源码学习总结

当我们在VPP/plugins目录下注册了自己的node后, 肯定有一个node.func(), 那这个函数是如何执行到的呢: 1. 首先我们要看一下这个插件注册的时候做了什么, 假设node 如下: 编译成功后, 我们可以从函数vlib_plugin_earl…

ubuntu20.04开机运行java的sh脚本

用到了 rc.local 1、修改 /usr/lib/systemd/system/rc-local.service 在最下面添加 [Install] WantedBymulti-user.target 2、 系统没有 rc.local,需要手动创建 cd /etc vi rc.local在里面写入 /opt/start.sh chmod x /etc/rc.local # 添加可执行权限 chmod x…

三分钟设计自己的工厂!基于昇腾AI处理器昇思MindSpore打造的智能化工大模型为化工研发效率带来10+倍提升

前言:华为与大连化物所深度合作,联合推出智能化工大模型,AI赋能化工领域,拥抱科学创新,提供了数据驱动化工研发的新范式。 2024年3月22日,在北京国家会议中心召开的昇思人工智能框架峰会上发布了由华为AI4…

mysql的约束和表关系

根据查询的结果,复制出一个新表 create table newTable AS select * from oldTable; create table newPeople AS select * from day2_test.people; 约束 引入:如果某一列如id列,有重复的数据,无法准确定位,有的列有空…

【JVM】java内存区域

目录 一、运行时数据区域 1、方法区 2、堆 3、虚拟机栈 4、本地方法栈 5、程序计数器 6、运行时常量池 二、HotSpot虚拟机的对象 1、对象的创建 指针碰撞: 空闲列表: 2、对象的内存布局 对象头 实例数据 对齐填充 3、对象的访问定位 句…

SNETCracker--超级弱口令检查工具简介

一、简介 SNETCracker 超级弱口令检查工具是一款Windows平台的弱口令审计工具,支持批量多线程检查,可快速发现弱密码、弱口令账号,密码支持和用户名结合进行检查,大大提高成功率,支持自定义服务端口和字典。 二、SNE…

C++认知

如何成为一名合格的C/C开发者 C/C 的当前应用领域 C 的应用领域目前有三大类,第一类就是我们目前见到的各种桌面应用软件,尤其 Windows 桌面软件,如 QQ、安全类杀毒类软件(如金山的安全卫士,已开源,其代码…

点燃营销力量!利用淘宝商品关键词搜索电商API接口引爆销售

随着电子商务的快速发展,利用API接口引爆销售已成为许多企业的关键策略。淘宝作为中国最大的电商平台,其商品关键词搜索API接口极具潜力。联讯数据将详细介绍淘宝商品关键词搜索电商API接口的功能与应用,并探讨如何通过该接口点燃营销力量&am…

队列的实现(c语言实现)

队列的定义 队列(Queue)是一种特殊的线性数据结构,它遵循先进先出(FIFO,First In First Out)的原则。这意味着最早被添加到队列中的元素将是最先被移除的元素。队列的主要操作包括入队(enqueue…

openGauss学习笔记-271 openGauss性能调优-TPCC性能调优测试指导-测试MOT-TPCC性能

文章目录 openGauss学习笔记-271 openGauss性能调优-TPCC性能调优测试指导-测试MOT-TPCC性能271.1 TPC-C简介271.2 系统级优化271.3 BenchmarkSQL:开源TPC-C工具271.4 运行基准271.5 结果报告 openGauss学习笔记-271 openGauss性能调优-TPCC性能调优测试指导-测试MO…

Apifox接口调试工具

1、Apifox简介 Apifox 是集 API 文档、API 调试、API Mock、API 自动化测试多项实用功能为一体的 API 管理平台,定位为 Postman Swagger Mock JMeter。旨在通过一套系统、一份数据,解决多个工具之间的数据同步问题。只需在 Apifox 中定义 API 文档&a…

【题解】牛客挑战赛 71 - A 和的期望

原题链接 https://ac.nowcoder.com/acm/problem/264714 思路分析 快速幂求逆元 费马小定理: a MOD − 1 ≡ 1 ( m o d M O D ) a^{\text{MOD}-1} \equiv 1 \pmod{MOD} aMOD−1≡1(modMOD),可以转换为 a ⋅ a MOD − 2 ≡ 1 ( m o d M O D ) ① a \cd…

部署zabbix代理服务器

一、准备环境 1.1 关闭防火墙 二、代理服务器 2.1 设置zabbix下载源 2.2 编辑resolv配置文件,加入本机IP 2.3 安装zabbix数据库 2.4 开机自启服务,mysql重定义 2.5 添加数据库用户以及zabbix数据库信息 2.6 导入数据库 2.7 编辑zabbix配置文件 vim /etc/…

【文章转载】Lance Martin的关于RAG的笔记

转载自微博黄建同学 从头开始学习 RAG,看Lance Martin的这篇笔记就行了,包含了十几篇论文和开源实现! —— 这是一组简短的(5-10 分钟视频)和笔记,解释了我最喜欢的十几篇 RAG 论文。我自己尝试实现每个想…

开源协议与商业许可:选择与遵循

文章目录 开源协议MIT许可证(MIT License)BSD许可证(BSD License)Apache许可证 2.0(Apache License 2.0)GNU宽松通用公共许可证(GNU Lesser General Public License,LGPL&#xff09…

线上论坛自动化测试

文章目录 前言一、测试用例设计二、自动化测试1.登录功能2.注册功能3.发布帖子4.删除帖子5.修改帖子6.帖子详情7.个人中心8.通过suite套件总测试 前言 对论坛项目进行测试用例编写,通过 Selenium JUnit 单元测试框架对项目的功能进行自动化测试。 论坛项目的部分…

Hive主要介绍

Hive介绍 hive是基于 Hadoop平台操作 HDFS 文件的插件工具 可以将结构化的数据文件映射为一张数据库表 可以将 HQL 语句转换为 MapReduce 程序 1.hive 是由驱动器组成,驱动器主要由4个组件组成(解析器、编译器、优化器、执行器) 2.hive本身不…