c# 线性回归和多项式拟合

embedded/2024/10/19 18:16:31/

1. 线性回归

公式: 线性回归的目标是拟合一条直线,形式为: y=mx+by=mx+b 其中:

  • yy 是因变量(目标值)
  • xx 是自变量(特征值)
  • mm 是斜率(slope)
  • bb 是截距(intercept)

优点:

  • 简单易懂
  • 计算效率高

缺点:

  • 只能拟合线性关系
  • 对于非线性关系的适应能力差

C# 线性回归示例代码

using MathNet.Numerics;
using MathNet.Numerics.LinearRegression;class Program
{static void Main(){double[] x = { 1, 2, 3, 4, 5 };double[] y = { 2, 4, 6, 8, 10 };// 进行线性回归var (slope, intercept) = SimpleRegression.Fit(x, y);Console.WriteLine($"拟合方程: y = {intercept} + {slope}x");}
}

2. 多项式拟合

公式: 多项式拟合的目标是拟合一个多项式,形式为: y=anxn+an−1xn−1+...+a1x+a0y=an​xn+an−1​xn−1+...+a1​x+a0​ 其中:

  • an,an−1,...,a0an​,an−1​,...,a0​ 是多项式的系数
  • nn 是多项式的最高次数

优点:

  • 能拟合更复杂的非线性关系
  • 通过增加多项式的次数,可以提高拟合的灵活性

缺点:

  • 过拟合的风险较高(尤其是在高次多项式时)
  • 计算复杂度较高

C# 多项式拟合示例代码

using MathNet.Numerics;
using MathNet.Numerics.LinearRegression;class Program
{static void Main(){double[] x = { 1, 2, 3, 4, 5 };double[] y = { 2, 3, 5, 7, 11 }; // 一组非线性数据// 进行多项式拟合,设定次数为2double[] coefficients = Fit.Polynomial(x, y, degree: 2);Console.WriteLine("拟合方程:");for (int i = coefficients.Length - 1; i >= 0; i--){Console.WriteLine($"{coefficients[i]}x^{i}");}}
}

对比总结

特征线性回归多项式拟合
拟合形式直线 y=mx+by=mx+b多项式 y=anxn+...y=an​xn+...
优点简单、快速能拟合复杂非线性关系
缺点只能处理线性关系容易过拟合,计算复杂度高
适用场景数据呈线性关系时数据呈现非线性关系时


http://www.ppmy.cn/embedded/123659.html

相关文章

【PyCharm】Ubuntu20.04 卸载 PyCharm 并安装激活 Professional

【PyCharm】Ubuntu20.04 卸载 PyCharm 并安装激活 Professional 1 卸载2 安装激活 1 卸载 参考文档: Link 删除安装目录 删掉之前压缩包解压出来的目录,例如:我之前是放在家目录下 rm -rf ~/pycharm-community-2023.2.1删除配置文件 rm -rf ~/.config…

My_qsort() -自己写的 qsort 函数

2024 - 10 - 05 - 笔记 - 21 作者(Author):郑龙浩 / 仟濹(网名) My_qsort()- 自己写的qsort函数 My_qsort为自己写的qsort函数,但是采用的不是快速排序,而是冒泡排序,是为了模仿qsort函数而尝试写出来的函数。 思路&#xff1a…

基于SPI协议的Flash扇区擦除实验

当一块Flash芯片中的不同的扇区烧录了不同的程序,而我们只想擦除某个扇区的程序保留其他程序时,Flash的全擦除是不能满足要求的,这时候就需要扇区擦除来实现这一功能。扇区擦除可以对Flash芯片中的某一扇区进行擦除而不改变其他扇区中的存储数…

数学建模 第四讲 - 数学规划模型

在数学建模的学习过程中,第四章介绍了几种常见的数学规划模型,这些模型在实际问题中有着广泛的应用。以下是对这些模型的整理和总结。 4.1 奶制品的生产与销售 问题描述 考虑一个奶制品厂,需要根据外部需求和内部条件(如设备、…

【STM32单片机_(HAL库)】4-2-1【定时器TIM】定时器输出PWM实现呼吸灯实验

1.硬件 STM32单片机最小系统LED灯模块 2.软件 pwm驱动文件添加定时器HAL驱动层文件添加GPIO常用函数定时器输出PWM配置步骤main.c程序 #include "sys.h" #include "delay.h" #include "led.h" #include "pwm.h"int main(void) {HA…

服务保护sentinel

线程隔离 - 线程池隔离:给每个服务调用业务分配一个线程池,利用线程池本身实现隔离效果。 - 信号量隔离:不创建线程池,而是计数器模式,记录业务使用的线程数量,达到信号量上限时,禁止新的请求。…

如何使用ssm实现民族大学创新学分管理系统分析与设计+vue

TOC ssm763民族大学创新学分管理系统分析与设计vue 第1章 绪论 1.1 课题背景 二十一世纪互联网的出现,改变了几千年以来人们的生活,不仅仅是生活物资的丰富,还有精神层次的丰富。在互联网诞生之前,地域位置往往是人们思想上不…

H.264编解码工具 - x264

一、简介 x264是一个开源的H.264/AVC视频编码库,它可以将视频数据压缩成H.264格式,并且可以从H.264格式解码出原始视频数据。 x264是以C语言编写的,并且可以在多个平台上使用,包括Windows、Linux和Mac OS等操作系统。 x264具有很高的编码效率和视频质量,它支持多种编码…