开发者

C#最小二乘法拟合曲线成直线的实例

开发者 https://www.devze.com 2023-02-27 10:42 出处:网络 作者: yangzm996
目录最小二乘法拟合曲线成直线效js果总结最小二乘法拟合曲线成直线 效果 拟合前
目录
  • 最小二乘法拟合曲线成直线
    • js
  • 总结

    最小二乘法拟合曲线成直线

    效果

    • 拟合前

    C#最小二乘法拟合曲线成直线的实例

    • 拟合后

    C#最小二乘法拟合曲线成直线的实例

    传入X轴和Y轴的数据,得到新的Y轴数据。

    将X值数据和拟合后的Y轴数据绑带即可。

     /// <summary>
            /// 最小二乘法/线性回归,得到新的点
            /// </summary>
            /// <param name="Points"></param>
            /// <param name="err"></param>
            /// <returns></returns>
            private List<douphpble> 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++)
                {
                    Averajavascriptgex += 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 +=irmsp (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 Re开发者_JAV培训sult;
            }
    

    总结

    以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

    0

    精彩评论

    暂无评论...
    验证码 换一张
    取 消