python機器學習高數(shù)篇之函數(shù)極限與導數(shù)
不知道大家有沒有類似的經(jīng)歷,斗志滿滿地翻開厚厚的機器學習書,很快被一個個公式炸蒙了。
想要學習機器學習算法,卻很難看的懂里面的數(shù)學公式,實際應用只會調(diào)用庫里的函數(shù),無法優(yōu)化算法。
學好機器學習,沒有數(shù)學知識是不行的。數(shù)學知識的積累是一個漫長的過程,羅馬也不是一夜建成的。
如果想要入門機器學習,數(shù)學基礎比較薄弱,想打牢相關數(shù)學基礎,可以關注筆者,一起學習(數(shù)學大佬也可以來掃一眼python代碼)~
接下來我們以高數(shù)(同濟第七版)課后習題為例,使用python語言來求解函數(shù)和導數(shù)的習題。
這樣大家做課后練習的時候,也可以用python驗證一下做的對不對。
這里用到兩個常見的Python庫,sympy和numpy,學習的時候可以參考官方文檔。
sympy 是Python語言編寫的符號計算庫,這里用于處理數(shù)學對象的計算稱為符號計算。
官方在線文檔:https://docs.sympy.org/dev/index.html
numpy是一個Python庫,支持大量的多維數(shù)組及矩陣運算,提供用于數(shù)組快速操作的各種API。
官方在線文檔:https://www.numpy.org.cn/reference/
函數(shù)極限
我們來看一下高數(shù)課本(同濟第七版)對函數(shù)極限的定義:

當時上課的時候就覺得這段函數(shù)定義太反人類了啊,瞬間打擊學習高數(shù)的興趣。
為什么函數(shù)極限的定義會這么難以理解呢?
這里需要插入數(shù)學史的內(nèi)容了,這個問題要追溯到幾百年前…
古希臘的數(shù)學家在處理無窮小和極限問題時,使用窮竭法等方法非常的繁瑣。
到了牛頓時代,微積分還不成熟,也就是說牛頓當時也沒把無窮小和極限的問題弄明白。
后面一個個大牛都試圖把相關的漏洞補齊,我們看到的這個ε-δ定義的極限,是由維爾斯特拉斯總結了前面各個大牛的經(jīng)驗,最終提出來的。
所以最終這個定義我們看不懂也正常,這個概念的形成大約經(jīng)歷了幾百年,就算拿給當時的牛頓看也是蒙的呢。
不過這個定義,也是公認的非常嚴謹、接近本質(zhì)的函數(shù)極限定義了。
光說概念太沒意思了,學數(shù)學嘛,肯定要做題。我們來看幾道高數(shù)題吧——
函數(shù)極限練習題.1
證明:

python版證明:
import sympy
from sympy import oo
import numpy as np
x = sympy.Symbol('x')
f = (x ** 2 - 4)/(x + 2)
sympy.limit(f,x,-2)
輸出:-4
函數(shù)極限練習題.2
證明:

python版證明:
import sympy #導入sympy符號計算庫
from sympy import oo#oo為無窮大符號
import numpy as np
x = sympy.Symbol('x')
f = sympy.sin(x)/sympy.sqrt(x)
sympy.limit(f,x,oo) #求極限
輸出:0
關于limit的用法,我們來查看官方文檔:

導數(shù)
導數(shù)定義:

理解了概念,來做幾道導數(shù)題吧——
導數(shù)練習題一(高數(shù) 總習題二 第8題(1)):
求下列導數(shù):

python版求導:
import sympy from sympy import * from sympy.abc import x,y diff(asin(sin(x)))
輸出:cos(x)/sqrt(-sin(x)**2 + 1)
python求導數(shù)的三種寫法
python中求導數(shù)主要有三種方法,我們用練習題來演示:
導數(shù)練習題:
求下列導數(shù):

方法一
使用sympy的diff函數(shù)。
diff版求導:
import sympy from sympy import * from sympy.abc import x,y diff(5*x**4 + 4*x**3 +2*x**2 + x + 666)
輸出:20*x**3 + 12*x**2 + 4*x + 1
方法二
使用numpy庫里的poly1d函數(shù)
在官方文檔里,查看一下poly1d的用法:

poly1d版求導:
import numpy as np p = np.poly1d([5,4, 0 ,2 ,1]) #構造多項式,每項是多項式前的系數(shù),冪次由高到低,沒有該冪次該項為0 print(np.polyder(p,1)) #求一階導數(shù) print(p.deriv(1)) #另一種方法求一階導數(shù)
輸出:
3 2
20 x + 12 x + 2
方法三
使用scipy.misc模塊下的derivative函數(shù)
在官方文檔里,查看一下derivative的用法:

derivative版求導:
import numpy as npfrom scipy.misc import derivative def f(x): return (5*x**4 + 4*x**3 +2*x**2 + x + 666) print (derivative(f,3,dx=1e-6)) #求x=3時的導數(shù)
輸出:
661.0000001501248
到此這篇關于python機器學習高數(shù)篇之函數(shù)極限與導數(shù)的文章就介紹到這了,更多相關python極限與導數(shù)內(nèi)容請搜索本站以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持本站!
版權聲明:本站文章來源標注為YINGSOO的內(nèi)容版權均為本站所有,歡迎引用、轉(zhuǎn)載,請保持原文完整并注明來源及原文鏈接。禁止復制或仿造本網(wǎng)站,禁止在非maisonbaluchon.cn所屬的服務器上建立鏡像,否則將依法追究法律責任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學習參考,不代表本站立場,如有內(nèi)容涉嫌侵權,請聯(lián)系alex-e#qq.com處理。
關注官方微信