• Leastsq 最小二乘法拟合一次函数简单入门例子


    ###最小二乘法试验###
    #error是自定义计算误差的函数,k,b也就是p0是计算初始化值,args是error其余的参数,该函数返回2个值,第一个是k,b的值
    import numpy as np
    from scipy.optimize import leastsq
    
    ###采样点(Xi,Yi)###
    Xi=np.array([8.19,2.72,6.39,8.71,4.7,2.66,3.78])
    Yi=np.array([7.01,2.78,6.47,6.71,4.1,4.23,4.05])
    
    ###需要拟合的函数func及误差error###
    def func(p,x):
        k,b=p
        return k*x+b
    
    def error(p,x,y,s):
        print (s)
        return func(p,x)-y #x、y都是列表,故返回值也是个列表
    
    #TEST
    p0=[100,2]
    #print( error(p0,Xi,Yi) )
    
    ###主函数从此开始###
    s="Test the number of iteration" #试验最小二乘法函数leastsq得调用几次error函数才能找到使得均方误差之和最小的k、b
    Para=leastsq(error,p0,args=(Xi,Yi,s)) #把error函数中除了p以外的参数打包到args中
    k,b=Para[0]
    print("k=",k,'
    ',"b=",b)
    
    ###绘图,看拟合效果###
    import matplotlib.pyplot as plt
    
    plt.figure(figsize=(8,6))
    plt.scatter(Xi,Yi,color="red",label="Sample Point",linewidth=3) #画样本点
    x=np.linspace(0,10,1000)
    y=k*x+b
    plt.plot(x,y,color="orange",label="Fitting Line",linewidth=2) #画拟合直线
    plt.legend()
    plt.show()

     主函数可优化为下:

    ###需要拟合的函数func及误差error###
    def error(theta,x,y,s):
        k,b = theta
        y_hat = (k*x+b)
        print (s)
        return y-y_hat #x、y都是列表,故返回值也是个列表
    
    ###主函数从此开始###
    p0 = [20, 2] s="Test the number of iteration" #试验最小二乘法函数leastsq得调用几次error函数才能找到使得均方误差之和最小的k、b Para=leastsq(error, p0, args=(Xi,Yi,s)) #把error函数中除了p以外的参数打包到args中 k,b=Para[0] print("k=",k,' ',"b=",b)

    1、p0里放的是k、b的初始值,这个值可以随意指定。往后随着迭代次数增加,k、b将会不断变化,使得error函数的值越来越小。

    2、func函数里指出了待拟合函数的函数形状。

    3、error函数为误差函数,我们的目标就是不断调整k和b使得error不断减小。这里的error函数和神经网络中常说的cost函数实际上是一回事,只不过这里更简单些而已。

    4、必须注意一点,传入leastsq函数的参数可以有多个,但必须把参数的初始值p0和其它参数分开放。其它参数应打包到args中。

    5、leastsq的返回值是一个tuple,它里面有两个元素,第一个元素是k、b的求解结果,第二个元素我暂时也不知道是什么意思。

    6、二次函数时就更换下目标函数,多添加一个变量,其它不变。

  • 相关阅读:
    VS 2010下一次性配置opencv(32位和64位相同)
    模拟鼠标事件
    Main函数参数argc,argv说明
    Visual Studio 2010 LINK : fatal error LNK1123: 转换到 COFF 期间失败: 文件无效或损坏解决方案
    常量指针和指针常量
    strlen函数实现的几种方法
    杀死指定的进程名
    typedef和typename关键字
    如何理解dart的mixin
    c# 通过dllimport 调用c 动态链接库
  • 原文地址:https://www.cnblogs.com/wynlfd/p/8684057.html
Copyright © 2020-2023  润新知