首页
/
每日頭條
/
生活
/
最小二乘算法與二次拟合區别
最小二乘算法與二次拟合區别
更新时间:2024-10-21 05:28:16
  • 最小二乘法理論

最小二乘法(又稱最小平方法)是一種數學優化技術。它通過最小化誤差的平方和尋找數據的最佳函數匹配。利用最小二乘法可以簡便地求得未知的數據,并使得這些求得的數據與實際數據之間誤差的平方和為最小。是解決曲線拟合最常用的方法,其思路如下:

其中,是預選定的一組線性相關的函數,是待定系數,拟合準則是使與的距離的平方和最小,稱為最小二乘法準則

最小二乘算法與二次拟合區别(最小二乘法ordinaryleast)1

最小二乘準則進行最小二乘平差計算的一個基本原則

  • 代碼示例

import pandas as pd import numpy as np from sklearn.linear_model import LinearRegression import matplotlib.pyplot as plt from mpl_toolkits.mplot3d import Axes3D #---------------------------------------------------------------------------------------------------------------------- # Step1:創建需要被拟合的目标。三維空間中,定義4x4的網格,首先定義z值,而網格點上的z值不一樣,我們所要做的就是根據這個z值去拟 # 合這個面上所有點的值。 #---------------------------------------------------------------------------------------------------------------------- np.random.seed(0) dim = 4 Z = (np.ones((dim, dim)) * np.arange(1, dim 1, 1))**3 np.random.rand(dim, dim) * 200 x = np.arange(1, dim 1).reshape(-1, 1) y = np.arange(1, dim 1).reshape(1, -1) X, Y = np.meshgrid(x, y) #---------------------------------------------------------------------------------------------------------------------- # Step2:自定義一組線性相關的函數, 3階。 #---------------------------------------------------------------------------------------------------------------------- features = {} features['x^0*y^0'] = np.matmul(x**0, y**0).flatten() features['x*y'] = np.matmul(x, y).flatten() features['x*y^2'] = np.matmul(x, y**2).flatten() features['x^2*y^0'] = np.matmul(x**2, y**0).flatten() features['x^2*y'] = np.matmul(x**2, y).flatten() features['x^3*y^2'] = np.matmul(x**3, y**2).flatten() features['x^3*y'] = np.matmul(x**3, y).flatten() features['x^0*y^3'] = np.matmul(x**0, y**3).flatten() dataset = pd.DataFrame(features) #---------------------------------------------------------------------------------------------------------------------- # Step3:将選定函數與目标值帶入SkLearn包中的線性回歸拟合模塊,它可以使平方和最小,結果返回截距和斜率。 #---------------------------------------------------------------------------------------------------------------------- reg = LinearRegression().fit(dataset.values, Z.flatten()) # reg.intercept_為截距, reg.coef_為斜率 z_pred = reg.intercept_ np.matmul(dataset.values, reg.coef_.reshape(-1, 1)).reshape(dim, dim) #---------------------------------------------------------------------------------------------------------------------- # Step4:可視化。 #---------------------------------------------------------------------------------------------------------------------- fig = plt.figure(figsize=(5, 5)) ax = Axes3D(fig) ax.plot_surface(X, Y, z_pred, label='prediction', cmap=plt.get_cmap('rainbow')) ax.scatter(X, Y, Z, c='r', label='datapoints') plt.show()

結果如下:

最小二乘算法與二次拟合區别(最小二乘法ordinaryleast)2

圖1

上例定義的多項式階數為3,對于大多數問題已經足夠了,如果想定義更高階數,則可參考如下代碼:

import itertools import numpy as np import matplotlib.pyplot as plt from mpl_toolkits.mplot3d import Axes3D #----------------------------------------------------------------------------------------------------------------------- # Step1: 創建線性相關的函數,階數自己定義,結果為拟合系數; #----------------------------------------------------------------------------------------------------------------------- def polyfit2d(x, y, z, order): ncols = (order 1)**2 G = np.zeros((x.size, ncols)) ij = itertools.product(range(order 1), range(order 1)) for k, (i, j) in enumerate(ij): G[:, k] = x**i * y**j m, _, _, _ = np.linalg.lstsq(G, z, rcond=-1) # lstsq的輸出包括四部分:回歸系數、殘差平方和、自變量X的秩、X的奇異值 return m #----------------------------------------------------------------------------------------------------------------------- # Step2: 創建拟合函數,将欲拟合值和拟合系數待入,返回預測值; #----------------------------------------------------------------------------------------------------------------------- def polyval2d(x, y, m): order = int(np.sqrt(len(m))) - 1 # 根據多項式的列數反算階數 ij = itertools.product(range(order 1), range(order 1)) z = np.zeros_like(x) for a, (i, j) in zip(m, ij): z = a * x**i * y**j return z #----------------------------------------------------------------------------------------------------------------------- # Step3: 示例; #----------------------------------------------------------------------------------------------------------------------- x = np.array([4, 5, 5, 4]) y = np.array([2, 3, 4, 5]) z = np.array([2, 3, 4, 7]) N_ORDER = 4 m = polyfit2d(x, y, z, N_ORDER) N_MESH = 10 xx, yy = np.meshgrid( np.linspace(x.min(), x.max(), N_MESH), np.linspace(y.min(), y.max(), N_MESH)) zz = polyval2d(xx, yy, m) #----------------------------------------------------------------------------------------------------------------------- # Step4: 可視化; #----------------------------------------------------------------------------------------------------------------------- fig = plt.figure(figsize=(5, 5)) ax = Axes3D(fig) ax.plot_surface(xx, yy, zz, label='prediction', cmap=plt.get_cmap('rainbow')) ax.scatter(x, y, z, c='r', label='datapoints') plt.show()

結果如下:

最小二乘算法與二次拟合區别(最小二乘法ordinaryleast)3

最小二乘法很基本也很常用,其本質是插值,但是我發現在當數值非常大時它的效果卻不是很好,這時候就需要用到一些其他的方法,比如克裡金法等。

聲明:僅供參考

,
Comments
Welcome to tft每日頭條 comments! Please keep conversations courteous and on-topic. To fosterproductive and respectful conversations, you may see comments from our Community Managers.
Sign up to post
Sort by
Show More Comments
推荐阅读
地膜哪種顔色适合種地瓜
地膜哪種顔色适合種地瓜
1、地膜黑色适合種地瓜。2、在減少野草數量上,黑色薄膜其實是有一定優勢的,因為黑色薄膜的透光性是很差的,這樣便會讓紅薯壟上的野草不能完成光合作用,從而抑制它們的生長發育,将土地的營養最大程度的留給紅薯。3、由于黑色的薄膜吸收熱量的能力最好,因此使用黑色薄膜可最大程度的将對于熱量隔絕在外,有效的降低紅...
2024-10-21
養花如何正确澆水
養花如何正确澆水
1、水質。澆花用水最好自然水,像雨雪水等是接近中性的水,适于花卉生長。還可以選擇河水或池塘水。如用使用自來水最好先放置1~2天,讓水中的氯氣散失。不能使用含有肥皂或洗潔精的洗碗水較好,會把花澆死的。2、水溫。水溫與土溫要掌握接近原則,溫差不能超過5℃。一般使用20℃~25℃的溫水澆花,可提高土壤溫度...
2024-10-21
怎麼做可愛紙巾盒
怎麼做可愛紙巾盒
1、準備一個小紙箱,側邊一面不用封口,把頂端一面作為紙巾盒的正面,用鉛筆畫一個橢圓,然後用剪刀裁剪出...
2024-10-21
檀木梳子怎麼保養
檀木梳子怎麼保養
1、檀木梳子地比較硬,手感圓潤,而且還淡淡的香味,其保養也很有講究。2、天然材質的檀木梳子皆順纖維制作,忌摔、忌拉、忌用力、忌折、忌高溫;避免硬物碰撞磨擦或劃傷。3、請勿将檀木梳子放置在溫度超過40℃的環境中;若受氣溫影響檀木梳變形,勿用手用力扳,請将梳子放入水中浸泡後晾幹自然恢複。4、保持梳子的清...
2024-10-21
怎樣培養孩子的動手能力
怎樣培養孩子的動手能力
第一、培養孩子的動手能力有助于提高孩子的智商,可以讓孩子養成獨立自主的性格,這需要我們從小開始培養。第二、可以先從小事上培養孩子的動手能力,比如自己洗臉刷牙,幫父母收拾餐桌等等,不要讓孩子成為溫室裡的花朵。第三、還可以給孩子買一些拼圖,積木之類的玩具,父母可以和孩子一起動手操作,不僅培養了孩子的動手...
2024-10-21
Copyright 2023-2024 - www.tftnews.com All Rights Reserved