Python實現多項式擬合正弦函數詳情
1. 實驗目的
掌握最小二乘法求解(無懲罰項的損失函數)、掌握加懲罰項(2 范數)的損失函數優化、梯度下降法、共軛梯度法、理解過擬合、克服過擬合的方法(如加懲罰項、增加樣本)
2. 實驗要求
生成數據,加入噪聲;
用高階多項式函數擬合曲線;
用解析解求解兩種 loss 的最優解(無正則項和有正則項)
優化方法求解最優解(梯度下降,共軛梯度);
用你得到的實驗數據,解釋過擬合。
用不同數據量,不同超參數,不同的多項式階數,比較實驗效果。
語言不限,可以用 matlab,python。求解解析解時可以利用現成的矩陣求逆。梯度下降,共軛梯度要求自己求梯度,迭代優化自己寫。不許用現成的平臺,例如 pytorch,tensorflow 的自動微分工具。
3. 實驗內容
3.1 算法原理
本實驗需要用多項式來擬合正弦函數。在 m 階多項式中,有 m+1 個待定系數,m+1 個系數(由低到高)組成的(列)向量記作 w。要確定 w,用最小二乘法。
設 E(w) = 1/2 * (Xw – Y)^T(Xw – Y),其中,X 為多項式中各個未知項代入觀測數據求得的矩陣,若記 Xi 為 X 的第 i 行的向量,則 Xi[j]為第 i 個觀測數據 xi 的 j 次方,記有 n 組觀測數據,多項式最高次為 m,易知 X 的維度為 n * (m+1)。Y 為觀測標簽向量。即 Y[j]為第 j 組觀測數據的標簽值(即 y 值)。從而問題轉化為:求向量 w,使得 E(w)最小。
- 若不加入正則項,令損失函數導數為零,求 w
- 若加入正則項,令損失函數導數為零,求 w
- 加入正則項,對損失函數用梯度下降,當損失函數收斂時,求 w
- 加入正則項,對損失函數用共軛梯度法,循環迭代 m+1 次,求 w 3.2 算法實現 生成數據,加入噪聲
用高階多項式函數擬合曲線;
用解析解求解兩種 loss 的最優解(無正則項和有正則項)
無正則項:
有正則項:
優化方法求解最優解(梯度下降,共軛梯度)
梯度下降法:
共軛梯度法:
用你得到的實驗數據,解釋過擬合。
多項式次數為 1 時:
多項式次數為 3 時:
當多項式次數為 5 時:
當多項式次數為 7 時:
當多項式次數為 9 時:
到此這篇關於Python實現多項式擬合正弦函數詳情的文章就介紹到這瞭,更多相關Python擬合正弦函數內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- 淺談tensorflow與pytorch的相互轉換
- PyTorch 可視化工具TensorBoard和Visdom
- Pytorch相關知識介紹與應用
- 解決python調用matlab時的一些常見問題
- M1 mac安裝PyTorch的實現步驟