av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

python計(jì)算導(dǎo)數(shù)并繪圖的實(shí)例

瀏覽:33日期:2022-08-05 09:51:48

我就廢話不多說(shuō)了,直接上代碼吧!

import mathimport numpy as npimport matplotlib.pyplot as pltfrom 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ù)展開(kāi)成實(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è)置畫(huà)圖格式 plt.plot(x_value,y_value,'b-',linewidth=1,label=’f(x)=’+str(expr)) #畫(huà)圖 plt.plot(x_value,y_value_dif,'r-',linewidth=1,label=’f(x)_prim’) #畫(huà)圖 plt.plot(x_value,y_value_dif2,'y-',linewidth=1,label=’f(x)_prim2’) #畫(huà)圖 plt.plot(x_value,y_value_dif3,'g-',linewidth=1,label=’f(x)_prim3’) #畫(huà)圖 plt.plot(x_value,y_value_dif4,'b-',linewidth=1,label=’f(x)_prim4’) #畫(huà)圖 plt.legend()#顯示圖例 plt.show()#顯示圖像 def draw_plot_set():#設(shè)置畫(huà)圖格式 plt.figure() ax = plt.gca() #改變坐標(biāo)軸位置 ax.spines[’right’].set_color(’none’)#刪除原來(lái)軸 ax.spines[’top’].set_color(’none’)#刪除原來(lái)軸 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)#打開(kāi)網(wǎng)格 if __name__ == ’__main__’: dif(-5,5,0.01)

python計(jì)算導(dǎo)數(shù)并繪圖的實(shí)例

補(bǔ)充拓展:python利用sympy庫(kù)對(duì)某個(gè)函數(shù)求導(dǎo),numpy庫(kù)使用該求導(dǎo)結(jié)果計(jì)算的程序

在python數(shù)據(jù)處理過(guò)程中,我們經(jīng)常會(huì)遇見(jiàn)這樣一種情況。需要對(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 spimport numpy as npx,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è)問(wèn)題呢?

對(duì)x,y使用evalf()函數(shù)分別賦值后,用float進(jìn)行類型轉(zhuǎn)換后,才能利用numpy進(jìn)行數(shù)值計(jì)算。

如下例:

import sympy as spimport numpy as npx,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 = 10y1 = 5z_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)來(lái)完成。

如下例:

import sympy as spimport numpy as npx,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è)參考,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 91麻豆精品国产91久久久更新资源速度超快 | 国产成人精品免费视频大全最热 | 亚洲一区二区三区免费视频 | 亚洲精品免费视频 | 欧美在线视频一区二区 | 亚洲视频在线观看免费 | 丝袜美腿一区二区三区 | 高清国产午夜精品久久久久久 | 久草热线 | 久久精品国产一区老色匹 | 欧美一区二区在线 | 日韩成人在线一区 | 两性午夜视频 | 国产精品一二三区 | 一区二区在线 | 国产1区2区在线观看 | 懂色av一区二区三区在线播放 | 青春草91| 免费视频一区二区 | 在线观看日韩av | av一区二区三区四区 | 欧美在线高清 | 亚洲一区二区精品视频在线观看 | 中文字幕精品一区久久久久 | 欧美一区二区三区精品 | 亚洲福利一区 | 国产精品综合视频 | 免费精品 | 国产高清久久 | 人人鲁人人莫人人爱精品 | 黄色毛片在线看 | 免费成人高清在线视频 | se婷婷| 能看的av | 久久成人国产精品 | 成人久久18免费网站图片 | 中文字幕精品一区二区三区精品 | 国产精品一区二区三区免费观看 | 亚洲国产精品久久久 | 国产精品久久久久免费 | www.黄色网 |