C#最小二乘法擬合曲線成直線的實例
更新時間:2023年02月26日 14:35:46 作者:yangzm996
這篇文章主要介紹了C#最小二乘法擬合曲線成直線的實例,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
最小二乘法擬合曲線成直線
效果
- 擬合前

- 擬合后

傳入X軸和Y軸的數(shù)據(jù),得到新的Y軸數(shù)據(jù)。
將X值數(shù)據(jù)和擬合后的Y軸數(shù)據(jù)綁帶即可。
/// <summary>
/// 最小二乘法/線性回歸,得到新的點
/// </summary>
/// <param name="Points"></param>
/// <param name="err"></param>
/// <returns></returns>
private List<double> LinearRegression(List<double> PointsX, List<double> PointsY)
{
List<double> Result = null;
if (PointsX.Count < 2 || PointsY.Count < 2 || PointsX.Count != PointsY.Count)
{
return Result;
}
double Averagex = 0, Averagey = 0;
for (int i = 0; i < PointsX.Count; i++)
{
Averagex += PointsX[i];
Averagey += PointsY[i];
}
Averagex /= PointsX.Count;
Averagey /= PointsX.Count;
double Numerator = 0, Denominator = 0;
for (int i = 0; i < PointsX.Count; i++)
{
Numerator += (PointsX[i] - Averagex) * (PointsY[i] - Averagey);
Denominator += (PointsX[i] - Averagex) * (PointsX[i] - Averagex);
}
double K = Numerator / Denominator;
double B = Averagey - K * Averagex;
List<double> temp = new List<double>();
foreach (var item in PointsX)
{
temp.Add(K * item + B);
}
Result = temp.ToList();
return Result;
}
總結
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
RegexOptions.IgnoreCase正則表達式替換,忽略大小寫
RegexOptions.IgnoreCase正則表達式替換,忽略大小寫,需要的朋友可以參考一下2013-03-03
C#實現(xiàn)DataSet內(nèi)數(shù)據(jù)轉化為Excel和Word文件的通用類完整實例
這篇文章主要介紹了C#實現(xiàn)DataSet內(nèi)數(shù)據(jù)轉化為Excel和Word文件的通用類,涉及C#中DataSet控件的使用及Excel和Word文件的相關操作技巧,需要的朋友可以參考下2016-06-06
C#和vb.net實現(xiàn)PDF 添加可視化和不可見數(shù)字簽名
本文通過C#程序代碼展示如何給PDF文檔添加可視化數(shù)字簽名和不可見數(shù)字簽名。文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-08-08

