热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

二维直线回归(拟合)算法(一)

一、最小二乘法(LeastSquares):假设样本集单个样本的线性函数为:为解二元一次方程中的a,b,给上式两边乘以xi得到(也可以两边乘yi):方程组: 解样本集方程组: 矩阵

一、最小二乘法(Least Squares):

假设样本集单个样本的线性函数为:

二维直线回归(拟合)算法(一)

为解二元一次方程中的a,b,给上式两边乘以xi得到(也可以两边乘yi):

二维直线回归(拟合)算法(一)

方程组:

 二维直线回归(拟合)算法(一)

解样本集方程组:

二维直线回归(拟合)算法(一)

 

矩阵形式: 

二维直线回归(拟合)算法(一)

 

对矩阵二维直线回归(拟合)算法(一) 求逆:

 二维直线回归(拟合)算法(一) 

 则:

二维直线回归(拟合)算法(一)

二维直线回归(拟合)算法(一)

二维直线回归(拟合)算法(一) 

 1        public static void LeastSquare(List points, out double a, out double b)
 2         {
 3             int N = points.Count;
 4             if (N <2)
 5             {
 6                 a = 0;
 7                 b = 0;
 8                 return;
 9             }
10             double X1 = 0, Y1 = 0, X2 = 0, X1Y1 = 0;
11             for (int i = 0; i i)
12             {
13                 X2 += points[i].X * points[i].X;
14                 X1 += points[i].X;
15                 X1Y1 += points[i].X * points[i].Y;
16                 Y1 += points[i].Y;
17             }
18             a = (X1Y1 * N - X1 * Y1) / (X2 * N - X1 * X1);
19             b = (X2 * Y1 - X1 * X1Y1) / (X2 * N - X1 * X1);
20         }
View Code
推荐阅读
  • 本文详细探讨了JDBC(Java数据库连接)的内部机制,重点分析其作为服务提供者接口(SPI)框架的应用。通过类图和代码示例,展示了JDBC如何注册驱动程序、建立数据库连接以及执行SQL查询的过程。 ... [详细]
  • 本文详细介绍了如何在Ubuntu系统中下载适用于Intel处理器的64位版本,涵盖了不同Linux发行版对64位架构的不同命名方式,并提供了具体的下载链接和步骤。 ... [详细]
  • 根据最新发布的《互联网人才趋势报告》,尽管大量IT从业者已转向Python开发,但随着人工智能和大数据领域的迅猛发展,仍存在巨大的人才缺口。本文将详细介绍如何使用Python编写一个简单的爬虫程序,并提供完整的代码示例。 ... [详细]
  • 汇编语言等号伪指令解析:探究其陡峭的学习曲线
    汇编语言以其独特的特性和复杂的语法结构,一直被认为是编程领域中学习难度较高的语言之一。本文将探讨汇编语言中的等号伪指令及其对初学者带来的挑战,并结合社区反馈分析其学习曲线。 ... [详细]
  • 并发编程:深入理解设计原理与优化
    本文探讨了并发编程中的关键设计原则,特别是Java内存模型(JMM)的happens-before规则及其对多线程编程的影响。文章详细介绍了DCL双重检查锁定模式的问题及解决方案,并总结了不同处理器和内存模型之间的关系,旨在为程序员提供更深入的理解和最佳实践。 ... [详细]
  • 本文探讨了《魔兽世界》中红蓝两方阵营在备战阶段的策略与实现方法,通过代码展示了双方如何根据资源和兵种特性进行战士生产。 ... [详细]
  • 深入理解Java泛型:JDK 5的新特性
    本文详细介绍了Java泛型的概念及其在JDK 5中的应用,通过具体代码示例解释了泛型的引入、作用和优势。同时,探讨了泛型类、泛型方法和泛型接口的实现,并深入讲解了通配符的使用。 ... [详细]
  • 本文介绍如何使用Python进行文本处理,包括分词和生成词云图。通过整合多个文本文件、去除停用词并生成词云图,展示文本数据的可视化分析方法。 ... [详细]
  • 本文介绍了如何通过扩展 UnityGUI 创建自定义和复合控件,以满足特定的用户界面需求。内容涵盖简单和静态复合控件的实现,并展示了如何创建复杂的 RGB 滑块。 ... [详细]
  • 本文详细介绍了 MySQL 中 LAST_INSERT_ID() 函数的使用方法及其工作原理,包括如何获取最后一个插入记录的自增 ID、多行插入时的行为以及在不同客户端环境下的表现。 ... [详细]
  • 本文详细介绍了中央电视台电影频道的节目预告,并通过专业工具分析了其加载方式,确保用户能够获取最准确的电视节目信息。 ... [详细]
  • 本文提供了使用Java实现Bellman-Ford算法解决POJ 3259问题的代码示例,详细解释了如何通过该算法检测负权环来判断时间旅行的可能性。 ... [详细]
  • MySQL索引详解与优化
    本文深入探讨了MySQL中的索引机制,包括索引的基本概念、优势与劣势、分类及其实现原理,并详细介绍了索引的使用场景和优化技巧。通过具体示例,帮助读者更好地理解和应用索引以提升数据库性能。 ... [详细]
  • 使用GDI的一些AIP函数我们可以轻易的绘制出简 ... [详细]
  • 本文介绍了如何利用npm脚本和concurrently工具,实现本地开发环境中多个监听服务的同时启动,包括HTTP服务、自动刷新、Sass和ES6支持。 ... [详细]
author-avatar
谁是我在寻找
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有