C#使用MathNet库来对进行曲线拟合

技术C#使用MathNet库来对进行曲线拟合 C#使用MathNet库来对进行曲线拟合下面是用来求取一条直线和一条拟合曲线交点的代码/// summary/// 拟合曲线所筛选的点的个数/// /sum

C#使用MathNet库来对进行曲线拟合

下面是用来求取一条直线和一条拟合曲线交点的代码

///摘要

///拟合曲线所筛选的点的个数

////摘要

const int曲线数=10

///摘要

///拟合曲线的阶数

////摘要

public int m=2;

///摘要

///取直线上的点的个数

////摘要

const int XNums=50

///摘要

///最小二乘法拟合曲线

////摘要

///参数名='X'X轴数组/param

///参数名='是'轴数组/param

///参数名='m '阶数/param

///返回返回曲线方程的各阶系数(由高阶到低阶,一般m=2)/返回

公共双[]拟合曲线(双[]X,双[] Y,int m=2)

{

///https://博客。csdn。net/QQ _ 23062949/文章/详情/119700640 SPM=1001。2101 .3001 .6650 .3 UTM _中等=分布式。PC _相对。无-任务-博客-2 ~默认~ ctrl列表~默认-3。no _ search _ link depth _ 1-UTM _ source=distribute。PC _相对。无-任务-博客-2 ~默认~ ctrl列表~默认-1

double[] res=新的双[m^ 1];

如果(十长度米Y长度米)

{

分辨率=适合.多项式(X,Y,m);

}

返回表示留数

}

///摘要

///计算直线方程

////摘要

///参数名='起点'直线起点/param

///参数名='角度'直线的角度/param

///返回返回k,b的数组/returns

公共双[]计算线(点起点,双角度)

{

双k=数学。谭(角度/180 *数学. PI);

双b=起点.Y - k *起点x;

返回新的double[] { k,b };

}

///摘要

///计算交点

////摘要

///param name='LineResult '直线的k,b/参数

///param name='CurveResult '拟合曲线的系数数组/param

///param名称='LineX '直线上的点的X坐标/param

///参数名='m '阶数/param

///返回/返回

public EPoint计算interpoint(double[]行结果,double[] CurveResult,double[] LineX,int m)

{

EPoint InterPoint=new EPoint();

if (LineResult .长度==2曲线结果。长度==(^ 1号)

{

double k=行结果[0];

double b=行结果[1];

for(int I=0;我是LineX .count();(一)

{

double x=LineX[I];

双y _ Line=k * x b;

双y _ Curve=0;

for(int n=0;n=m;n)

{

y_Curve=曲线结果[n] *数学.幂(x,n);

}

bool IsSuccessFind=false

for(int t=1;t=50t)

{

如果(数学Abs(y)线表示“有…的”曲线)5)

{

InterPoint=new EPoint((int)x,(int)y _ Line);

IsSuccessFind=true

打破;//跳出内循环

}

}

if(issuessfind)

{

打破;//跳出外循环

}

}

}

返回InPut

}

///摘要

///计算R^2,R^2这个值越接近1,说明拟合出来的曲线跟原曲线就越接近

////摘要

///参数名='是'实际的y/参数

///参数名='Ytest '代入拟合曲线方程得到的y/参数

///返回返回R^2/returns

公共双精度计算平方(双[]是,双[] Ytest)

{

double RSquared=GoodnessOfFit .RSquared(Y,Ytest);

返回RSquared

}

4556

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/155871.html

(0)

相关推荐

  • C++ 调试问题:对象包含与成员函数不兼容的类型限定符

    技术C++ 调试问题:对象包含与成员函数不兼容的类型限定符 C++ 调试问题:对象包含与成员函数不兼容的类型限定符今天调试C++自定义String代码的时候,碰到一个问题,编译期报错:对象包含与成员函数

    礼包 2021年11月13日
  • 网站切换到香港服务器的合适时机

    技术网站切换到香港服务器的合适时机随着网站的规模不断扩展,很多时候利用传统的VPS很难满足网站的性能需求,因此不少用户会选择将网站迁移到物理服务器上,而在选择香港服务器之前您需要了解的是,什么时候是从VPS切换到香港服务

    礼包 2021年12月9日
  • 诛心之论,“诛心之论”是什么意思

    技术诛心之论,“诛心之论”是什么意思所谓“诛心之论”,指在批评对方之时,不针对对方的行为、语言谈问题,而是绕过行为、语言去指责对方此行为、语言的目的、动机诛心之论。所以“诛心之论”又曰“动机说”。据说该成语出自于《后汉书

    生活 2021年10月31日
  • 手机文件夹怎么弄,手机空白文件夹怎么创建

    技术手机文件夹怎么弄,手机空白文件夹怎么创建一手机文件夹怎么弄、在手机桌面上创建文件夹的方法:
    1、按住一个应用图标,移动到另一个应用图标上松开即可自动形成文件夹。
    2、在手机桌面双指捏合进入编辑模式,点击桌面整理,然后

    生活 2021年10月23日
  • css如何设置链接点击后的颜色

    技术css如何设置链接点击后的颜色这篇文章主要为大家展示了“css如何设置链接点击后的颜色”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“css如何设置链接点击后的颜色”这篇文

    攻略 2021年12月10日
  • C语言const用法概述

    技术C语言const用法概述 C语言const用法概述const概念
    有时候我们希望定义这样一种变量,它的值不能被改变,在整个作用域中都保持固定。例如,用一个变量来表示班级的最大人数,或者表示缓冲区的大

    礼包 2021年12月6日