python計(jì)算導(dǎo)數(shù)并繪圖的實(shí)例
我就廢話不多說了,直接上代碼吧!
import math
import numpy as np
import matplotlib.pyplot as plt
from sympy import * #用于求導(dǎo)積分等科學(xué)計(jì)算
def dif(left,right,step):#求導(dǎo) 左右區(qū)間以及間隔
x,y = symbols('x y')#引入x y變量
expr = pow(x,5)#計(jì)算表達(dá)式
x_value = [] #save x value
y_value = [] #save x f(x) value
y_value_dif = [] #save x f(x)_dot value
y_value_dif2 = [] #save x f(x)_dot2 value
y_value_dif3 = [] #save x f(x)_dot3 value
y_value_dif4 = [] #save x f(x)_dot4 value
#print(expand(exp(I*x), complex=True))#將復(fù)指數(shù)展開成實(shí)部虛部形式
expr_dif = diff(expr,x,1)
expr_dif2 = diff(expr,x,2)
expr_dif3 = diff(expr,x,3)
expr_dif4 = diff(expr,x,4)
for i in np.arange(left,right,step):
x_value.append(i)
y_value.append(expr.subs('x',i))#將i值代入表達(dá)式
y_value_dif.append(expr_dif.subs('x',i))#將i值代入求導(dǎo)表達(dá)式
y_value_dif2.append(expr_dif2.subs('x',i))#將i值代入2階求導(dǎo)表達(dá)式
y_value_dif3.append(expr_dif3.subs('x',i))#將i值代入3階求導(dǎo)表達(dá)式
y_value_dif4.append(expr_dif4.subs('x',i))#將i值代入4階求導(dǎo)表達(dá)式
draw_plot_set()#設(shè)置畫圖格式
plt.plot(x_value,y_value,"b-",linewidth=1,label='f(x)='+str(expr)) #畫圖
plt.plot(x_value,y_value_dif,"r-",linewidth=1,label='f(x)_prim') #畫圖
plt.plot(x_value,y_value_dif2,"y-",linewidth=1,label='f(x)_prim2') #畫圖
plt.plot(x_value,y_value_dif3,"g-",linewidth=1,label='f(x)_prim3') #畫圖
plt.plot(x_value,y_value_dif4,"b-",linewidth=1,label='f(x)_prim4') #畫圖
plt.legend()#顯示圖例
plt.show()#顯示圖像
def draw_plot_set():#設(shè)置畫圖格式
plt.figure()
ax = plt.gca()
#改變坐標(biāo)軸位置
ax.spines['right'].set_color('none')#刪除原來軸
ax.spines['top'].set_color('none')#刪除原來軸
ax.xaxis.set_ticks_position('bottom')#在0點(diǎn)處增加軸
ax.spines['bottom'].set_position(('data',0))
ax.yaxis.set_ticks_position('left')#在0點(diǎn)處增加軸
ax.spines['left'].set_position(('data',0))
#設(shè)置坐標(biāo)名
plt.ylabel('f(x)')
plt.xlabel('x')
plt.grid(True)#打開網(wǎng)格
if __name__ == '__main__':
dif(-5,5,0.01)

補(bǔ)充拓展:python利用sympy庫(kù)對(duì)某個(gè)函數(shù)求導(dǎo),numpy庫(kù)使用該求導(dǎo)結(jié)果計(jì)算的程序
在python數(shù)據(jù)處理過程中,我們經(jīng)常會(huì)遇見這樣一種情況。需要對(duì)一個(gè)函數(shù)表達(dá)式求偏導(dǎo),并將具體數(shù)值代入導(dǎo)數(shù)式。
而python中通??捎糜诤瘮?shù)求導(dǎo)的函數(shù)是sympy庫(kù)中的diff()函數(shù)。
但他通常所求得的導(dǎo)數(shù)只是一個(gè)符號(hào)表達(dá)式。不能直接帶入數(shù)據(jù)使用。
如下例:
import sympy as sp
import numpy as np
x,y = sp.symbols('x y')
z = sp.sin(2*sp.pi*x+2*y/5)
zx = sp.diff(z,x)
zy = sp.diff(z,y)
print(zx)
print(zy)
其輸出為:
2*pi*cos(2*pi*x + 2*y/5) 2*cos(2*pi*x + 2*y/5)/5
那么該如何解決這個(gè)問題呢?
對(duì)x,y使用evalf()函數(shù)分別賦值后,用float進(jìn)行類型轉(zhuǎn)換后,才能利用numpy進(jìn)行數(shù)值計(jì)算。
如下例:
import sympy as sp
import numpy as np
x,y = sp.symbols('x y')
z = sp.sin(2*sp.pi*x+2*y/5)
zx = sp.diff(z,x)
zy = sp.diff(z,y)
x1 = 10
y1 = 5
z_x1 = float(zx.evalf(subs={x:x1,y:y1}))
z_y1 = float(zy.evalf(subs={x:x1,y:y1}))
print(z_x1)
print(z_y1)
其輸出結(jié)果:
-2.61472768902227 -0.16645873461885696
那如果我的x或y不是單一的值呢?而是一個(gè)數(shù)組。
我們可以利用一個(gè)循環(huán)來完成。
如下例:
import sympy as sp
import numpy as np
x,y = sp.symbols('x y')
z = sp.sin(2*sp.pi*x+2*y/5)
zx = sp.diff(z,x)
zy = sp.diff(z,y)
x_array = np.linspace(-5, 5, 10)
y_array = np.linspace(-5, 5, 10)
temp_x = []#先定義一個(gè)用于存儲(chǔ)x偏導(dǎo)的空列表
temp_y = []#先定義一個(gè)用于存儲(chǔ)y偏導(dǎo)的空列表
for i in range(10):
z_x = float(zx.evalf(subs={x:x_array[i],y:y_array[i]}))
temp_x.append(z_x)#將計(jì)算得到的偏導(dǎo)值一一添加到列表中
z_y = float(zy.evalf(subs={x:x_array[i],y:y_array[i]}))
temp_y.append(z_y)
zx_array = np.array(temp_x)#將列表轉(zhuǎn)換為數(shù)組
zy_array = np.array(temp_y)
print(zx_array)
print(zy_array)
輸出結(jié)果為:
[-2.61472769 4.11163864 6.02946289 0.89585862 -5.2854481 -5.2854481 0.89585862 6.02946289 4.11163864 -2.61472769] [-0.16645873 0.26175505 0.38384753 0.05703213 -0.33648208 -0.33648208 0.05703213 0.38384753 0.26175505 -0.16645873]
由此便實(shí)現(xiàn)了由sympy得到求導(dǎo)結(jié)果,到numpy庫(kù)進(jìn)行數(shù)值計(jì)算。
以上這篇python計(jì)算導(dǎo)數(shù)并繪圖的實(shí)例就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Python3非對(duì)稱加密算法RSA實(shí)例詳解
這篇文章主要介紹了Python3非對(duì)稱加密算法RSA,結(jié)合實(shí)例形式分析了Python3 RSA加密相關(guān)模塊安裝及使用操作技巧,需要的朋友可以參考下2018-12-12
Python內(nèi)置函數(shù)map()的具體使用
Python中的map()函數(shù)是一個(gè)高效的內(nèi)置函數(shù),用于將指定函數(shù)應(yīng)用于序列的每個(gè)元素,通過接收一個(gè)函數(shù)和一個(gè)或多個(gè)序列,本文就來詳細(xì)的介紹一下如何使用,感興趣的可以了解一下2024-09-09
Python使用pickle模塊報(bào)錯(cuò)EOFError Ran out of input的解決方法
這篇文章主要介紹了Python使用pickle模塊報(bào)錯(cuò)EOFError Ran out of input的解決方法,涉及Python異常捕獲操作處理相關(guān)使用技巧,需要的朋友可以參考下2018-08-08
python EasyOCR庫(kù)實(shí)例用法介紹
在本篇文章里小編給大家整理的是一篇關(guān)于python EasyOCR庫(kù)實(shí)例用法介紹,有需要的朋友們可以跟著學(xué)習(xí)下。2021-07-07

