91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Python數據擬合實現最小二乘法的示例分析

發布時間:2021-10-20 18:53:52 來源:億速云 閱讀:195 作者:柒染 欄目:開發技術

今天就跟大家聊聊有關Python數據擬合實現最小二乘法的示例分析,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。

線性擬合

Python數據擬合實現最小二乘法的示例分析

Python數據擬合實現最小二乘法的示例分析

這個表達式還是非常簡單的。

對于有些情況,我們往往選取自然序列作為自變量,這個時候在求自變量的取值時可以用到一些初等數學的推論,對于 x ∈ [ m , n ] 的自然序列來說,有

Python數據擬合實現最小二乘法的示例分析

#文件名core.py
import numpy as np
def leastSquare(x,y):
    if len(x)==2:
    #此時x為自然序列
        sx = 0.5*(x[1]-x[0]+1)*(x[1]+x[0])
        ex = sx/(x[1]-x[0]+1)
        sx2 = ((x[1]*(x[1]+1)*(2*x[1]+1))
              -(x[0]*(x[0]-1)*(2*x[0]-1)))/6
        x = np.array(range(x[0],x[1]+1))
    else:
        sx = sum(x)
        ex = sx/len(x)
        sx2 = sum(x**2)    
    sxy = sum(x*y)
    ey = np.mean(y)
    a = (sxy-ey*sx)/(sx2-ex*sx)
    b = (ey*sx2-sxy*ex)/(sx2-ex*sx)
    return a,b

測試一下

>>> x = np.arange(25)
>>> y = x*15+20+np.random.randn(len(x))*5	#randn生成正態分布噪聲
>>> a,b = core.leastSquare(x,y)				
>>> plt.scatter(x,y)						#原始數據散點圖
<matplotlib.collections.PathCollection object at 0x00000218DEBBEDC8>
>>> plt.plot(x,a*x+b)						#擬合直線
[<matplotlib.lines.Line2D object at 0x00000218E0314FC8>]
>>> plt.show()

得到

Python數據擬合實現最小二乘法的示例分析

高階多項式

Python數據擬合實現最小二乘法的示例分析

和前面一樣,約定

Python數據擬合實現最小二乘法的示例分析

代碼如下

#傳入參數格式為np.array,n為階數
def leastSquareMulti(x,y,n):
    X = [np.sum(x**i) for i in range(2*n+1)]
    Y = np.array([[np.sum(y*x**i)] for i in range(n+1)])
    S = np.array([X[i:i+n+1] for i in range(n+1)])
    return np.linalg.solve(S,Y)		#

經測試結果如下:

>>> x = np.arange(25)
>>> y = x**3+3*x**2+2*x+12
>>> import core
>>> core.leastSquareMulti(x,y,3)
array([[12.],		#此為常數項
       [ 2.],
       [ 3.],
       [ 1.]])

多自變量

對于樣本

Python數據擬合實現最小二乘法的示例分析

則相應地其誤差方程組可表示為

Python數據擬合實現最小二乘法的示例分析

指數函數

Python數據擬合實現最小二乘法的示例分析

則其代碼為

def expFit(x,y):
    y0 = y[0:-3]
    y1 = y[1:-2]
    y2 = y[2:-1]
    B,C = leastSquare(y2/y0,y1/y0)
    b1 = np.log((B-np.sqrt(B**2+4*C))/2)
    b2 = np.log((B+np.sqrt(B**2+4*C))/2)
    X = np.exp(b1-b2)*x
    Y = y/np.exp(b2*x)
    a1,a2 = leastSquare(X,Y)
    return a1,a2,b1,b2


看完上述內容,你們對Python數據擬合實現最小二乘法的示例分析有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

山东省| 祁连县| 靖远县| 涞源县| 鄂伦春自治旗| 武宣县| 罗平县| 元朗区| 酒泉市| 错那县| 蒙阴县| 阳曲县| 石阡县| 托克托县| 米泉市| 温州市| 定边县| 集贤县| 罗定市| 昭觉县| 扶风县| 拉孜县| 宜兰县| 滦平县| 翁牛特旗| 天祝| 吉安县| 大关县| 诸城市| 社旗县| 蛟河市| 图木舒克市| 鄯善县| 湖南省| 普兰店市| 娱乐| 兴义市| 开化县| 象州县| 唐山市| 荣成市|