11-20:課程小結(jié)--多項(xiàng)式擬合

import numpy as np
import matplotlib.pyplot as plt


x = np.arange(10)*0.1
fx = np.array([0.97,0.83,0.65,0.54,0.46,0.36,0.29,0.25,0.21,0.17])

p = 1
N = 6  # 階數(shù)

def Neiji(p,a,b):
    '''
    加權(quán)內(nèi)積,p為加權(quán)值
    '''
    return p*np.dot(a,b)

def Nihe(x,fx,p,N):
    '''
    多項(xiàng)式擬合函數(shù)
    (x,fx):給定的需要擬合的點(diǎn)
    p:加權(quán)內(nèi)積的權(quán)重值
    N:多項(xiàng)式階數(shù)
    '''
    A = np.zeros((N,N))
    b = np.zeros((N,1))
    for i in range(N):
        for j in range(N):
            A[i,j] = Neiji(p,x**i,x**j)
        b[i,0] = Neiji(p,fx,x**i)
    an = np.linalg.solve(A,b)             # 多項(xiàng)式擬合模型系數(shù)
    return an
    
an = Nihe(x,fx,p,N) 
xx = np.arange(min(x),max(x),0.01)       # 做圖橫坐標(biāo)
result = np.sum([an[i]*(xx**i) for i in range(N)],axis=0)  # 擬合結(jié)果曲線
 
plt.scatter(x,fx,c='r')
plt.plot(xx,result)
plt.show()
6階多項(xiàng)式擬合.png
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容