电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

python計算導數并繪圖的實例

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

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

import mathimport numpy as npimport matplotlib.pyplot as pltfrom sympy import * #用于求導積分等科學計算 def dif(left,right,step):#求導 左右區間以及間隔 x,y = symbols(’x y’)#引入x y變量 expr = pow(x,5)#計算表達式 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))#將復指數展開成實部虛部形式 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值代入表達式 y_value_dif.append(expr_dif.subs(’x’,i))#將i值代入求導表達式 y_value_dif2.append(expr_dif2.subs(’x’,i))#將i值代入2階求導表達式 y_value_dif3.append(expr_dif3.subs(’x’,i))#將i值代入3階求導表達式 y_value_dif4.append(expr_dif4.subs(’x’,i))#將i值代入4階求導表達式 draw_plot_set()#設置畫圖格式 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():#設置畫圖格式 plt.figure() ax = plt.gca() #改變坐標軸位置 ax.spines[’right’].set_color(’none’)#刪除原來軸 ax.spines[’top’].set_color(’none’)#刪除原來軸 ax.xaxis.set_ticks_position(’bottom’)#在0點處增加軸 ax.spines[’bottom’].set_position((’data’,0)) ax.yaxis.set_ticks_position(’left’)#在0點處增加軸 ax.spines[’left’].set_position((’data’,0)) #設置坐標名 plt.ylabel(’f(x)’) plt.xlabel(’x’) plt.grid(True)#打開網格 if __name__ == ’__main__’: dif(-5,5,0.01)

python計算導數并繪圖的實例

補充拓展:python利用sympy庫對某個函數求導,numpy庫使用該求導結果計算的程序

在python數據處理過程中,我們經常會遇見這樣一種情況。需要對一個函數表達式求偏導,并將具體數值代入導數式。

而python中通??捎糜诤瘮登髮У暮瘮凳莝ympy庫中的diff()函數。

但他通常所求得的導數只是一個符號表達式。不能直接帶入數據使用。

如下例:

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

那么該如何解決這個問題呢?

對x,y使用evalf()函數分別賦值后,用float進行類型轉換后,才能利用numpy進行數值計算。

如下例:

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)

其輸出結果:

-2.61472768902227-0.16645873461885696

那如果我的x或y不是單一的值呢?而是一個數組。

我們可以利用一個循環來完成。

如下例:

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 = []#先定義一個用于存儲x偏導的空列表temp_y = []#先定義一個用于存儲y偏導的空列表for i in range(10): z_x = float(zx.evalf(subs={x:x_array[i],y:y_array[i]})) temp_x.append(z_x)#將計算得到的偏導值一一添加到列表中 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)#將列表轉換為數組zy_array = np.array(temp_y)print(zx_array)print(zy_array)

輸出結果為:

[-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]

由此便實現了由sympy得到求導結果,到numpy庫進行數值計算。

以上這篇python計算導數并繪圖的實例就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 304不锈钢无缝管_不锈钢管厂家 - 隆达钢业集团有限公司 | 山东商品混凝土搅拌楼-环保型搅拌站-拌合站-分体仓-搅拌机厂家-天宇 | 钢格栅板_钢格板网_格栅板-做专业的热镀锌钢格栅板厂家-安平县迎瑞丝网制造有限公司 | 数显恒温油浴-电砂浴-高温油浴振荡器-常州迈科诺仪器有限公司 | 康明斯发电机,上柴柴油发电机,玉柴柴油发电机组_海南重康电力官网 | 中国玩具展_玩具展|幼教用品展|幼教展|幼教装备展 | 塑料熔指仪-塑料熔融指数仪-熔体流动速率试验机-广东宏拓仪器科技有限公司 | TPE_TPE热塑性弹性体_TPE原料价格_TPE材料厂家-惠州市中塑王塑胶制品公司- 中塑王塑胶制品有限公司 | 河北码上网络科技|邯郸小程序开发|邯郸微信开发|邯郸网站建设 | 杭州画室_十大画室_白墙画室_杭州美术培训_国美附中培训_附中考前培训_升学率高的画室_美术中考集训美术高考集训基地 | 螺纹三通快插接头-弯通快插接头-宁波舜驰气动科技有限公司 | 天空彩票天下彩,天空彩天空彩票免费资料,天空彩票与你同行开奖,天下彩正版资料大全 | 不发火防静电金属骨料_无机磨石_水泥自流平_修补砂浆厂家「圣威特」 | 博莱特空压机|博莱特-阿特拉斯独资空压机品牌核心代理商 | 右手官网|右手工业设计|外观设计公司|工业设计公司|产品创新设计|医疗产品结构设计|EMC产品结构设计 | 步入式高低温测试箱|海向仪器 | 大白菜官网,大白菜winpe,大白菜U盘装系统, u盘启动盘制作工具 | 智慧食堂_食堂管理系统_食堂订餐_食堂消费系统—客易捷 | 右手官网|右手工业设计|外观设计公司|工业设计公司|产品创新设计|医疗产品结构设计|EMC产品结构设计 | 大_小鼠elisa试剂盒-植物_人Elisa试剂盒-PCR荧光定量试剂盒-上海一研生物科技有限公司 | 杭州高温泵_热水泵_高温油泵|昆山奥兰克泵业制造有限公司 | 中空玻璃生产线,玻璃加工设备,全自动封胶线,铝条折弯机,双组份打胶机,丁基胶/卧式/立式全自动涂布机,玻璃设备-山东昌盛数控设备有限公司 | 不锈钢螺丝 - 六角螺丝厂家 - 不锈钢紧固件 - 万千紧固件--紧固件一站式采购 | 河南mpp电力管_mpp电力管生产厂家_mpp电力电缆保护管价格 - 河南晨翀实业 | 烟台条码打印机_烟台条码扫描器_烟台碳带_烟台数据采集终端_烟台斑马打印机-金鹏电子-金鹏电子 | 钢绞线万能材料试验机-全自动恒应力两用机-混凝土恒应力压力试验机-北京科达京威科技发展有限公司 | cnc精密加工_数控机械加工_非标平键定制生产厂家_扬州沃佳机械有限公司 | 天津货架厂_穿梭车货架_重型仓储货架_阁楼货架定制-天津钢力仓储货架生产厂家_天津钢力智能仓储装备 | 东莞动力锂电池保护板_BMS智能软件保护板_锂电池主动均衡保护板-东莞市倡芯电子科技有限公司 | 亮点云建站-网站建设制作平台 | 无硅导热垫片-碳纤维导热垫片-导热相变材料厂家-东莞市盛元新材料科技有限公司 | 斗式提升机_链式斗提机_带式斗提机厂家无锡市鸿诚输送机械有限公司 | 定做大型恒温循环水浴槽-工业用不锈钢恒温水箱-大容量低温恒温水槽-常州精达仪器 | 罗茨真空机组,立式无油往复真空泵,2BV水环真空泵-力侨真空科技 | 行星搅拌机,双行星搅拌机,动力混合机,无锡米克斯行星搅拌机生产厂家 | 重庆LED显示屏_显示屏安装公司_重庆LED显示屏批发-彩光科技公司 重庆钣金加工厂家首页-专业定做监控电视墙_操作台 | 鲸鱼视觉 -数字展厅多媒体互动展示制作公司 | 德州网站开发定制-小程序开发制作-APP软件开发-「两山开发」 | 知名电动蝶阀,电动球阀,气动蝶阀,气动球阀生产厂家|价格透明-【固菲阀门官网】 | 科普仪器菏泽市教育教学仪器总厂 | SOUNDWELL 编码器|电位器|旋转编码器|可调电位器|编码开关厂家-广东升威电子制品有限公司 |