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

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 }; // 一组非线性数据

        // 进行多项式拟合,设定次数为2
        double[] 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+...
优点 简单、快速 能拟合复杂非线性关系
缺点 只能处理线性关系 容易过拟合,计算复杂度高
适用场景 数据呈线性关系时 数据呈现非线性关系时
相关推荐
天乐敲代码2 小时前
JAVASE入门九脚-集合框架ArrayList,LinkedList,HashSet,TreeSet,迭代
java·开发语言·算法
十年一梦实验室2 小时前
【Eigen教程】矩阵、数组和向量类(二)
线性代数·算法·矩阵
Kent_J_Truman2 小时前
【子矩阵——优先队列】
算法
快手技术3 小时前
KwaiCoder-23BA4-v1:以 1/30 的成本训练全尺寸 SOTA 代码续写大模型
算法·机器学习·开源
一只码代码的章鱼4 小时前
粒子群算法 笔记 数学建模
笔记·算法·数学建模·逻辑回归
小小小小关同学4 小时前
【JVM】垃圾收集器详解
java·jvm·算法
圆圆滚滚小企鹅。4 小时前
刷题笔记 贪心算法-1 贪心算法理论基础
笔记·算法·leetcode·贪心算法
Kacey Huang4 小时前
YOLOv1、YOLOv2、YOLOv3目标检测算法原理与实战第十三天|YOLOv3实战、安装Typora
人工智能·算法·yolo·目标检测·计算机视觉
eguid_14 小时前
JavaScript图像处理,常用图像边缘检测算法简单介绍说明
javascript·图像处理·算法·计算机视觉
带多刺的玫瑰5 小时前
Leecode刷题C语言之收集所有金币可获得的最大积分
算法·深度优先