您好,登錄后才能下訂單哦!
這篇文章主要介紹了怎么使用C#最小二乘法擬合曲線成直線的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇怎么使用C#最小二乘法擬合曲線成直線文章都會有所收獲,下面我們一起來看看吧。
擬合前
擬合后
傳入X軸和Y軸的數據,得到新的Y軸數據。
將X值數據和擬合后的Y軸數據綁帶即可。
/// <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; }
關于“怎么使用C#最小二乘法擬合曲線成直線”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“怎么使用C#最小二乘法擬合曲線成直線”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。