Open CASCADE学习|最小二乘法拟合直线

最小二乘法,又称最小平方法,起源于十八世纪的大航海探索时期,发展于天文领域和航海领域。其历史可以追溯到法国科学家马里·勒让德于1805年首次提出这一概念,而1809年,高斯在他的著作《天体运动论》中也提出了最小二乘法,并发表了应用该方法计算谷神星轨道的结果。奥地利天文学家海因里希·奥尔伯斯根据高斯计算出来的轨道重新发现了谷神星,这进一步验证了最小二乘法的有效性。此后,高斯在1829年证明了最小二乘法的优化效果强于其他方法,这被称为高斯-马尔可夫定理。

在发展过程中,最小二乘法逐渐形成了两类基本算法:传统的一次完成算法和最小二乘递推算法。前者具体方法视所用输入信号而定,常见的输入信号有随机序列、伪随机序列等。后者更易于在微机上实现,适用于参数在线辨识。

然而,最小二乘法在应用中并非完美无缺。由于它基于最小化误差平方和的原理,因此在处理含有随机特性的系统时,可能会引进偏差,且易受到噪声的干扰,导致精度不佳。只有在方程中只拥有白噪声误差时,其算法精度才能达到理想状态。

尽管存在这些挑战,但最小二乘法仍被广泛应用于误差估计、曲线拟合、参数辨识、预测、预报等领域。此外,随着技术的发展,最小二乘法也在不断地改进和优化,以适应更广泛和复杂的应用场景。​

利用最小二乘法拟合曲线的一般步骤是:

  1. 将实验数据显示出来,分析曲线的形式;

  2. 确定拟合曲线的形式。对于本文来说,曲线形式是直线,y=a+bx;

  3. 建立法方程组并对其进行求解;

#include <iostream>#include <gp_Lin2d.hxx>#include <gp_Pnt2d.hxx>#include <TColgp_Array1OfPnt2d.hxx>#include <math_Vector.hxx>#include <math_SVD.hxx>#include <math_Gauss.hxx>#include <math_GaussLeastSquare.hxx>#include <OSD_Chronometer.hxx>void fitLine(const TColgp_Array1OfPnt2d& thePoints,             const std::string& theFileName,             gp_Lin2d& theLine){    math_Vector aB(1, 2, 0.0);    math_Vector aX(1, 2, 0.0);    math_Matrix aM(1, 2, 1, 2);    Standard_Real aSxi = 0.0;    Standard_Real aSyi = 0.0;    Standard_Real aSxx = 0.0;    Standard_Real aSxy = 0.0;    std::ofstream aDrawFile(theFileName);    for (Standard_Integer i = thePoints.Lower(); i <= thePoints.Upper(); ++i)    {        const gp_Pnt2d& aPoint = thePoints.Value(i);        aSxi += aPoint.X();        aSyi += aPoint.Y();        aSxx += aPoint.X() * aPoint.X();        aSxy += aPoint.X() * aPoint.Y();        aDrawFile << "vpoint p" << i << " " <<                     aPoint.X() << " " << aPoint.Y() << " 0" << std::endl;    }    aM(1, 1) = thePoints.Size();    aM(1, 2) = aSxi;    aM(2, 1) = aSxi;    aM(2, 2) = aSxx;    aB(1) = aSyi;    aB(2) = aSxy;    OSD_Chronometer aChronometer;    aChronometer.Start();    math_Gauss aSolver(aM);    //math_GaussLeastSquare aSolver(aM);    //math_SVD aSolver(aM);    aSolver.Solve(aB, aX);    if (aSolver.IsDone())    {        Standard_Real aA = aX(1);        Standard_Real aB = aX(2);        gp_Pnt2d aP1(0.0, aA);        gp_Pnt2d aP2(-aA/aB, 0.0);        theLine.SetLocation(aP1);        theLine.SetDirection(gp_Vec2d(aP1, aP2).XY());        aDrawFile << "vaxis l "                  << aP1.X() << " " << aP1.Y() << " 0 "                  << aP2.X() << " " << aP2.Y() << " 0 " << std::endl;        std::cout << "===================" << std::endl;        aX.Dump(std::cout);    }    aChronometer.Stop();    aChronometer.Show();}int main(){    gp_Lin2d aLine;    // Test data 1    TColgp_Array1OfPnt2d aPoints1(1, 6);    aPoints1.SetValue(1, gp_Pnt2d(36.9, 181.0));    aPoints1.SetValue(2, gp_Pnt2d(46.7, 197.0));    aPoints1.SetValue(3, gp_Pnt2d(63.7, 235.0));    aPoints1.SetValue(4, gp_Pnt2d(77.8, 270.0));    aPoints1.SetValue(5, gp_Pnt2d(84.0, 283.0));    aPoints1.SetValue(6, gp_Pnt2d(87.5, 292.0));    fitLine(aPoints1, "fit1.tcl", aLine);    // Test data 2    TColgp_Array1OfPnt2d aPoints2(0, 7);    aPoints2.SetValue(0, gp_Pnt2d(0.0, 27.0));    aPoints2.SetValue(1, gp_Pnt2d(1.0, 26.8));    aPoints2.SetValue(2, gp_Pnt2d(2.0, 26.5));    aPoints2.SetValue(3, gp_Pnt2d(3.0, 26.3));    aPoints2.SetValue(4, gp_Pnt2d(4.0, 26.1));    aPoints2.SetValue(5, gp_Pnt2d(5.0, 25.7));    aPoints2.SetValue(6, gp_Pnt2d(6.0, 25.3));    aPoints2.SetValue(7, gp_Pnt2d(7.0, 24.8));    fitLine(aPoints2, "fit2.tcl", aLine);    return 0;}

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

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

相关文章

xilinx FPGA 除法器ip核(divider)的学习和仿真(Vivado)

在设计中&#xff0c;经常出现除法运算&#xff0c;实现方法&#xff1a; 1、移位操作 2、取模取余 3、调用除法器IP核 4、查找表 简单学习除法器IP。 网上很多IP翻译文档&#xff0c;不详细介绍&#xff0c;记录几个重要的点&#xff1a; 1、三种算法模式(不同模式所消耗的资…

【Linux 进程概念】

【Linux 进程概念】 冯诺依曼体系结构冯诺依曼结构简要解释&#xff1a;你用QQ和朋友聊天时数据的流动过程 操作系统(OperatorSystem)概念设计OS的目的定位操作系统的上下层都分别是什么如何理解“管理"总结 进程基本概念描述进程-PCBtask_ struct内容 组织进程查看进程通…

大模型围剿战:Kimi如何在免费与盈利之间找到平衡?

文 | 大力财经 在近期的互联网科技领域&#xff0c;一款名为Kimi的国产大型AI模型引起了广泛关注。随着Kimi的火爆&#xff0c;国内的大型科技公司纷纷开始关注并投入到长文本处理技术的竞争中。 阿里巴巴、360等知名企业纷纷宣布了他们的长文本处理能力&#xff0c;分别达到…

网络——套接字编程UDP

目录 端口号 源端口号和目的端口号 认识TCP协议和UDP协议 网络字节序 socket编程接口 socket常见接口 sockaddr结构 UDP socket bind recvfrom sendto 编写客户端 绑定INADDR_ANY 实现聊天功能 端口号 在这之前我们已经说过源IP地址和目的IP地址&#xff0c;还有…

微信小程序的页面制作---常用组件及其属性2

一、标签栏taBar 在全局配置文件app.json中添加taBar配置&#xff0c;可实现标签栏配置。标签栏最少2个&#xff0c;最多5个 &#xff08;1&#xff09;如何配置标签栏&#xff1f; 1》先建多个文件&#xff0c;&#xff08;以我的index&#xff0c;list&#xff0c;myform文…

最近很火的游戏,人渣/SCUM(更新V0.9.517.81845)

包含DLC • SCUM Deluxe • SCUM Deluxe 2 • SCUM Danny Trejo • SCUM Hair Deluxe 1 • SCUM Luis Moncada • SCUM Charms 1 • SCUM Weapon Skins 1 中文设置 OPTIONS-LANGUAGE-中文(简体) 特别提示 • 通过“\SCUM\Binaries\Win64\SCUM.exe”启动游戏 • 如果…

Microsoft Excel 快捷键 (keyboard shortcut - hotkey)

Microsoft Excel 快捷键 [keyboard shortcut - hotkey] References 表格内部换行快捷键 Alt Enter 快速将光标移到表末 Ctrl End 快速将光标移到表首 Ctrl Home References [1] Yongqiang Cheng, https://yongqiang.blog.csdn.net/

人工智能(Educoder)-- 搜索技术 -- 盲目式搜索

第1关&#xff1a;盲目搜索之宽度优先搜索算法 任务描述 本关任务&#xff1a;给定迷宫地图以及在迷宫中的起始位置&#xff0c;利用宽度优先搜索算法求解走出迷宫的最短路径长度&#xff0c;走出迷宫意味着达到迷宫地图的边界&#xff08;所有位置下标0开始&#xff09;。 …

水电站泄洪预警广播系统方案

一、行业背景 近年来由于危险河道管理措施不到位&#xff0c;调峰电站泄水风险长期存在&#xff0c;信息通报制度缺失以及民众安全警觉性不高等因素导致的水电站在泄洪时冲走下游河道游客以及人民财产的事故频发。 我司通过物联网、云计算、大数据、人工智能等技术手段&#x…

不能从所选图层建立3d模型--模大狮模型网

在Revit中&#xff0c;从所选图层直接创建3D模型并不是一个常规的操作方式。通常情况下&#xff0c;你需要手动创建文字或者图形&#xff0c;然后将其转换为3D模型。 如果你有一个平面上的文字或图形&#xff0c;想要将其转换为3D模型&#xff0c;你可以使用以下步骤&#xff1…

什么是虚拟线程?

1、典型回答 Java 中的虚拟线程&#xff0c;也叫做协程或“轻量级线程”&#xff0c;它诞生于JDK 19(预览 API)&#xff0c;正式发布于 JDK 21&#xff0c;它是一种在 Java 虚拟机(JVM)层面实现的逻辑线程&#xff0c;不直接和操作系统的物理线程一一对应&#xff0c;因此它可…

文献速递:基于SAM的医学图像分割---SAM-Med2D

Title 题目 SAM-Med2D 01 文献速递介绍 医学图像分割在通过识别和勾画各种组织、器官或感兴趣区域来分析医学图像中发挥着至关重要的作用。准确的分割可以帮助医生精确识别和定位病理区域&#xff0c;从而实现更准确的诊断和治疗。此外&#xff0c;对医学图像进行定量和定性…

Node.js之沙盒专题

​ Node.js一直是薄弱项&#xff0c;今天特意整理一下&#xff0c;基本上是各个大佬写的大杂烩&#xff0c;仅用于学习记录~~~ 1. child_process 首先介绍一下nodejs中用来执行系统命令的模块child_process。Nodejs通过使用child_process模块来生成多个子进程来处理其他事物…

简化业务流程,AppLink连接一定签

APPlink是什么 APPlink是RestCloud打造的一款简单易用的零代码自动化集成平台&#xff0c;为业务流程提供自动化的解决方案&#xff0c;将企业内部的核心系统以及第三方应用程序和云服务等进行集成。无论是开发人员还是业务人员&#xff0c;都可以使用APPlink轻松构建出高效、…

【触想智能】工业触摸一体机九大常见故障检测方法分享

工业触摸一体机目前在社会生产中应用非常广泛&#xff0c;比如智能化的生产车间、城市智慧安防监控中心都经常用到工业触摸一体机。 电子产品在使用中难免会出现一些故障&#xff0c;工业触摸一体机也不例外。那么我们在使用工业触摸一体机的时遇到问题怎么办呢?下面小编给大家…

第十九章 linux部署scrapyd

文章目录 1. linux部署python环境1. 部署python源文件环境2. 下载python3. 解压安装包4. 安装5. 配置环境变量6. 检查是否安装成功7. 准备python使用的包8. 安装scrapyd9. 配置scrapyd10. 开放6800端口 2. 部署gerapy1. 本机下载包2. 初始化3. 进入gerapy同步数据库4. 创建用户…

nginx启停操作

一、nginx启动 方式一&#xff1a; /usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf方式二&#xff1a; systemctl start nginx 查看进程启动状态 ps -ef | grep nginx 上图表示nginx进程启动成功&#xff0c;进程号为30034为主进程(负责链接操作)&am…

2024/3/24--爬虫库

1.常用的爬虫库 (1)在setting的project里面点击Python Interpreter (2&#xff09;常用的爬虫库有 import requests //用途&#xff1a;用于发送HTTP请求。from bs4 import BeautifulSoup //用于从HTML或XML文档中提取数据。import scrapy //一个功能强大的爬虫框架&#xf…

基于 C++ STL 的图书管理系统213行

定制魏&#xff1a;QTWZPW&#xff0c;获取更多源码等 目录 一、实践项目名称 二、实践目的 三、实践要求 四、实践内容 五、代码框架参考 六、代码效果展示 七、完整代码主函数展示 一、实践项目名称 基于 C STL 的图书管理系统 二、实践目的 通过设计和实现一个基于…

AI之Suno:Suno V3的简介、安装和使用方法、案例应用之详细攻略

AI之Suno&#xff1a;Suno V3的简介、安装和使用方法、案例应用之详细攻略 目录 Suno AI的简介 1、特点与改进&#xff1a; Suno AI的安装和使用方法 1、第一步&#xff0c;让国产大模型—ChatGLM4帮我写一个提示词 2、第二步&#xff0c;将提示词交给Suno v3&#xff0c;…