主頁 > 知識庫 > python機器學(xué)習(xí)高數(shù)篇之泰勒公式

python機器學(xué)習(xí)高數(shù)篇之泰勒公式

熱門標(biāo)簽:地圖標(biāo)注審核表 長沙高頻外呼系統(tǒng)原理是什么 外呼并發(fā)線路 ai電話機器人哪里好 ai電銷機器人源碼 百度地圖標(biāo)注沒有了 湛江智能外呼系統(tǒng)廠家 西藏房產(chǎn)智能外呼系統(tǒng)要多少錢 宿遷星美防封電銷卡

不少同學(xué)一提到泰勒公式,腦海里立馬浮現(xiàn)高大上的定義和長長的公式,令人望而生畏。

實際上,泰勒公式?jīng)]有那么可怕,它是用簡單的多項式來逼近一個光滑的函數(shù),從而近似替代不熟悉的函數(shù)。由于泰勒公式具有將復(fù)雜函數(shù)近似成多個冪函數(shù)疊加形式的性質(zhì),可以用它進(jìn)行比較、求極限、求導(dǎo)、解微分方程等。

我們先來看一下泰勒公式的發(fā)明者,布魯克·泰勒——

布魯克·泰勒(Brook Taylor,1685-1732),英國數(shù)學(xué)家,牛頓學(xué)派最優(yōu)秀的代表人物之一,他于1712年的一封信里首次敘述了泰勒公式。

再來看一下高數(shù)書上對泰勒公式的定義:

公式3-5就稱為f(x)在x0處的帶有拉格朗日余項的n階泰勒公式。

初看這個泰勒公式的定義,就覺得恢宏大氣,氣勢磅礴。不過光從泰勒公式的定義,很難直觀看出它是怎么用多項式逼近原函數(shù)的。接下來我們用圖像和圖表來感受一下——

這里我們先列舉出f(x) = cosx在原點的泰勒2階、4階、6階、8階、10階的多項式,并用圖像表示該函數(shù)及其泰勒n階多項式。

對應(yīng)圖像如下,其中黑色線條為原函數(shù)f(x),彩色線條為多項式g(x)??梢钥吹诫S著階數(shù)的增大,多項式在更大范圍內(nèi)越來越逼近原函數(shù)。

我們再用python實現(xiàn)函數(shù)y=cosx的泰勒n階多項式,并與y=cosx的實際值進(jìn)行比較,其中令n=40。

def f_cos(x):
    m = 20+1
    sum = 1.0
    for i in range(1,m): #range函數(shù)取值是左閉右開
        n = 2 * i 
        tmp1,tmp2,tmp3 = 1,1,1
        for j in range(1,i+1):
            tmp1 = -tmp1             
        for j in range(1,n+1):                    
            tmp2 = tmp2*x
            tmp3 = tmp3*j
        sum = sum + tmp1*tmp2/tmp3
    return sum
from numpy import *
for x in range(-20,21):
    print("x = " + str(x))
    print("f_cos(x) = " + str(f_cos(x)))
    print("cos(x) = " + str(cos(x)))

比較自定義的f_cos(x)和numpy庫的cosx的誤差:

x取值 自定義的f_cos(x) numpy庫的cosx 誤差(f_cos(x) - cos(x)) 分析
20 2577.3069 0.4081 2576.8988 誤差非常大
19 305.1701 0.9887 304.1814 誤差較大
18 32.5969 0.6603 31.9366 存在誤差
17 2.6676 -0.2752 2.9428 存在誤差
16 -0.7234 -0.9577 0.2343 存在0.1級誤差
15 -0.7439 -0.7597 0.0158 存在0.01級誤差
14 0.1376 0.1367 0.0009 存在0.0001級誤差
13 0.9075 0.9074 0.0000 精度范圍內(nèi)一致
12 0.8439 0.8439 0.0000 精度范圍內(nèi)一致
11 0.0044 0.0044 0.0000 精度范圍內(nèi)一致
10 -0.8391 -0.8391 0.0000 精度范圍內(nèi)一致
9 -0.9111 -0.9111 0.0000 精度范圍內(nèi)一致
8 -0.1455 -0.1455 0.0000 精度范圍內(nèi)一致
7 0.7539 0.7539 0.0000 精度范圍內(nèi)一致
6 0.9602 0.9602 0.0000 精度范圍內(nèi)一致
5 0.2837 0.2837 0.0000 精度范圍內(nèi)一致
4 -0.6536 -0.6536 0.0000 精度范圍內(nèi)一致
3 -0.9900 -0.9900 0.0000 精度范圍內(nèi)一致
2 -0.4161 -0.4161 0.0000 精度范圍內(nèi)一致
1 0.5403 0.5403 0.0000 精度范圍內(nèi)一致
0 1.0000 1.0000 0.0000 精度范圍內(nèi)一致

由于f(x) = cosx函數(shù)關(guān)于y軸對稱,這里只列舉出了x軸右半部分[0,20]的范圍,x軸左半部分的結(jié)果與右半部分結(jié)果相同。

在[0,20]范圍內(nèi),當(dāng)x=20時,二者的誤差非常大。隨著x的減小,二者的誤差也在逐漸減小。在[0,13]范圍內(nèi),二者在精度范圍內(nèi)完全一致,幾乎零誤差。

大家可以嘗試一下,把n的值調(diào)大,這個精度一致的范圍會變大。例如此例若n=30,即y=cosx的泰勒30階多項式,則在[-20,20]范圍內(nèi),二者精度都完全一致。感興趣的同學(xué)可以運用同樣的方法,分析一下其他函數(shù)。

再試著寫出函數(shù)y=sinx的泰勒n階多項式的python程序,其中n=19。

def f_sin(x):
    m = 10+1
    sum = 0.0
    for i in range(1,m):
        n = 2 * i - 1     
        tmp1,tmp2,tmp3 = 1,1,1
        for j in range(1,i):
            tmp1 = -tmp1  
        for j in range(1,n+1):          
            tmp2 = tmp2*x
            tmp3 = tmp3*j
        sum = sum + tmp1*tmp2/tmp3 
    return sum
from numpy import *
for x in range(-20,21):
    print("x = " + str(x))
    print("f_sin(x) = " + str(f_sin(x)))
    print("sin(x) = " + str(sin(x)))

后續(xù)會繼續(xù)增加一些函數(shù)的泰勒n階多項式python程序(可能會偷懶)。

最后推薦一個比較好用的在線畫函數(shù)的工具Desmos:

https://www.desmos.com/calculator?lang=zh-CN

簡易教程:

https://www.ravenxrz.ink/archives/27d14722.html

還可以用著名的心形線畫個愛心哦:

到此這篇關(guān)于python機器學(xué)習(xí)高數(shù)篇之泰勒公式的文章就介紹到這了,更多相關(guān)python泰勒公式內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • python機器學(xué)習(xí)高數(shù)篇之函數(shù)極限與導(dǎo)數(shù)
  • Python機器學(xué)習(xí)入門(一)序章
  • Python機器學(xué)習(xí)入門(二)之Python數(shù)據(jù)理解
  • Python機器學(xué)習(xí)入門(三)之Python數(shù)據(jù)準(zhǔn)備
  • Python機器學(xué)習(xí)入門(四)之Python選擇模型
  • Python機器學(xué)習(xí)入門(五)之Python算法審查
  • Python機器學(xué)習(xí)入門(六)之Python優(yōu)化模型

標(biāo)簽:南平 大同 普洱 漯河 寧夏 林芝 盤錦 海南

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《python機器學(xué)習(xí)高數(shù)篇之泰勒公式》,本文關(guān)鍵詞  python,機器,學(xué)習(xí),高數(shù)篇,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《python機器學(xué)習(xí)高數(shù)篇之泰勒公式》相關(guān)的同類信息!
  • 本頁收集關(guān)于python機器學(xué)習(xí)高數(shù)篇之泰勒公式的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章