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)

相关推荐

  • Redis中的bitmap是什么

    技术Redis中的bitmap是什么本篇内容主要讲解“Redis中的bitmap是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Redis中的bitmap是什么”吧!Re

    攻略 2021年12月3日
  • apachesuperset权限控制(apachesuperset使用方法)

    技术如何进行Apache Superset远程代码执行漏洞如何进行Apache Superset远程代码执行漏洞,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,

    攻略 2021年12月21日
  • GET和POST两种基本请求方法的区别有哪些

    技术GET和POST两种基本请求方法的区别有哪些本篇内容主要讲解“GET和POST两种基本请求方法的区别有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“GET和POST两

    攻略 2021年10月27日
  • Oracle数据用户密码过期处理方法是什么

    技术Oracle数据用户密码过期处理方法是什么这篇文章主要讲解了“Oracle数据用户密码过期处理方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Oracle数据

    攻略 2021年11月5日
  • mysql如何实现用户创建、修改、删除及授权操作

    技术mysql如何实现用户创建、修改、删除及授权操作这篇文章主要介绍了mysql如何实现用户创建、修改、删除及授权操作,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起

    攻略 2021年10月30日
  • JDK7与JDK8中HashMap的实现是怎样的

    技术JDK7与JDK8中HashMap的实现是怎样的本篇文章为大家展示了JDK7与JDK8中HashMap的实现是怎样的,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。JDK7中的

    攻略 2021年11月16日