欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python數(shù)據(jù)擬合實(shí)現(xiàn)最小二乘法示例解析

 更新時(shí)間:2021年10月20日 15:38:12   作者:微小冷  
這篇文章主要為大家介紹了Python數(shù)據(jù)擬合實(shí)現(xiàn)最小二乘法的示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步

所謂最小二乘法,即通過(guò)對(duì)數(shù)據(jù)進(jìn)行擬合,使得擬合值與樣本值的方差最小。

線性擬合

在這里插入圖片描述

在這里插入圖片描述

這個(gè)表達(dá)式還是非常簡(jiǎn)單的。

對(duì)于有些情況,我們往往選取自然序列作為自變量,這個(gè)時(shí)候在求自變量的取值時(shí)可以用到一些初等數(shù)學(xué)的推論,對(duì)于 x ∈ [ m , n ] 的自然序列來(lái)說(shuō),有

在這里插入圖片描述

#文件名core.py
import numpy as np
def leastSquare(x,y):
    if len(x)==2:
    #此時(shí)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

測(cè)試一下

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

得到

在這里插入圖片描述

高階多項(xiàng)式

在這里插入圖片描述

和前面一樣,約定

在這里插入圖片描述

代碼如下

#傳入?yún)?shù)格式為np.array,n為階數(shù)
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)		#

經(jīng)測(cè)試結(jié)果如下:

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

多自變量

對(duì)于樣本

在這里插入圖片描述

則相應(yīng)地其誤差方程組可表示為

在這里插入圖片描述

指數(shù)函數(shù)

在這里插入圖片描述

則其代碼為

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數(shù)據(jù)擬合實(shí)現(xiàn)最小二乘法示例解析的詳細(xì)內(nèi)容,更多關(guān)于Python實(shí)現(xiàn)最小二乘法的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 對(duì)numpy數(shù)據(jù)寫(xiě)入文件的方法講解

    對(duì)numpy數(shù)據(jù)寫(xiě)入文件的方法講解

    今天小編就為大家分享一篇對(duì)numpy數(shù)據(jù)寫(xiě)入文件的方法講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-07-07
  • Django實(shí)現(xiàn)任意文件上傳(最簡(jiǎn)單的方法)

    Django實(shí)現(xiàn)任意文件上傳(最簡(jiǎn)單的方法)

    這篇文章主要介紹了Django實(shí)現(xiàn)任意文件上傳,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-06-06
  • Python詳解文字轉(zhuǎn)語(yǔ)音的實(shí)現(xiàn)

    Python詳解文字轉(zhuǎn)語(yǔ)音的實(shí)現(xiàn)

    在自然語(yǔ)言處理上,文字、音頻互轉(zhuǎn)是一個(gè)很關(guān)鍵的技術(shù)點(diǎn)。對(duì)于語(yǔ)音轉(zhuǎn)文字,個(gè)人實(shí)現(xiàn)較為困難,我們可以使用語(yǔ)音轉(zhuǎn)文字的軟件或借助各API(如科大訊飛等)進(jìn)行移植開(kāi)發(fā)。不過(guò)文字轉(zhuǎn)語(yǔ)音就相對(duì)而言容易實(shí)現(xiàn)很多了
    2022-02-02
  • Python自動(dòng)掃描出微信不是好友名單的方法

    Python自動(dòng)掃描出微信不是好友名單的方法

    很多人想要清楚已經(jīng)被刪除的好友名單。面對(duì)龐大的好友數(shù)量想要清除談何容易,本文主要介紹了Python自動(dòng)掃描出微信不是好友名單的方法,感興趣的可以了解一下
    2021-05-05
  • Python extract及contains方法代碼實(shí)例

    Python extract及contains方法代碼實(shí)例

    這篇文章主要介紹了Python extract及contains方法代碼實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-09-09
  • 如何正確理解python裝飾器

    如何正確理解python裝飾器

    裝飾器(Decorators)是 Python 的一個(gè)重要部分。簡(jiǎn)單地說(shuō):他們是修改其他函數(shù)的功能的函數(shù)。他們有助于讓我們的代碼更簡(jiǎn)短
    2021-06-06
  • Python實(shí)現(xiàn)不同樣式二維碼

    Python實(shí)現(xiàn)不同樣式二維碼

    作為一名合格的?Python?程序員,在工作中必然會(huì)用到二維碼相關(guān)操作,那如何快速的用?Python?實(shí)現(xiàn)呢?別著急,咱們這篇博客就為你解決
    2023-01-01
  • 簡(jiǎn)單了解python PEP的一些知識(shí)

    簡(jiǎn)單了解python PEP的一些知識(shí)

    這篇文章主要介紹了簡(jiǎn)單了解python PEP的一些知識(shí),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-07-07
  • Python設(shè)計(jì)模式之解釋器模式原理與用法實(shí)例分析

    Python設(shè)計(jì)模式之解釋器模式原理與用法實(shí)例分析

    這篇文章主要介紹了Python設(shè)計(jì)模式之解釋器模式原理與用法,結(jié)合具體實(shí)例形式分析了解釋器模式的概念、原理、定義及使用方法,需要的朋友可以參考下
    2019-01-01
  • Python實(shí)現(xiàn)Mysql數(shù)據(jù)統(tǒng)計(jì)及numpy統(tǒng)計(jì)函數(shù)

    Python實(shí)現(xiàn)Mysql數(shù)據(jù)統(tǒng)計(jì)及numpy統(tǒng)計(jì)函數(shù)

    這篇文章主要介紹了Python實(shí)現(xiàn)Mysql數(shù)據(jù)統(tǒng)計(jì)的實(shí)例代碼,給大家介紹了Python數(shù)據(jù)分析numpy統(tǒng)計(jì)函數(shù)的相關(guān)知識(shí),本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-07-07

最新評(píng)論