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)

相关推荐

  • 字段、复制字段、动态字段怎么使用

    技术Field、CopyField、DynamicField怎么使用这篇文章主要介绍“Field、CopyField、DynamicField怎么使用”,在日常操作中,相信很多人在Field、CopyField、Dyna

    攻略 2021年12月22日
  • 狗狗感冒了会自己好吗,狗狗感冒了,吃感冒冲剂能好吗

    技术狗狗感冒了会自己好吗,狗狗感冒了,吃感冒冲剂能好吗狗狗感冒在天气忽冷忽热的时候比较多见,如果狗狗不小心着凉感冒,特别是在天气忽冷忽热的时候,或者是比较冷的天气里总是趴在冰冷的地板上,一着凉感冒就会出现打喷嚏、流鼻涕等

    2021年10月20日
  • 十大名木手串,全球十大最名贵木材有哪些

    技术十大名木手串,全球十大最名贵木材有哪些感谢推荐十大名木手串!我个人是很喜欢盘玩木材的,尤其是小叶紫檀。最近迷上了桃木,因为桃木那独有的纹理是非常吸引我的。如下这些就是最世界珍贵的十种木材。一、乌木乌木(阴沉木)兼备木

    生活 2021年11月1日
  • 国际象棋怎么玩,磁石国际象棋磁性折叠怎么玩儿

    技术国际象棋怎么玩,磁石国际象棋磁性折叠怎么玩儿棋子和棋盘国际象棋由黑白两棋组成国际象棋怎么玩,执白先行,国际象棋的对局目的是把对方的国王将死。以下三点如果全行不通,国王就算将死:
    1.挡住“将军”的局势
    2.离开“将军

    生活 2021年10月23日
  • C++11的array容器怎么使用

    技术C++11的array容器怎么使用本篇内容介绍了“C++11的array容器怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,

    攻略 2021年11月24日
  • Linux内核Device Tree怎么创建

    技术Linux内核Device Tree怎么创建这篇文章主要讲解了“Linux内核Device Tree怎么创建”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Linux内

    攻略 2021年11月23日