python计算导数并绘图的实例

作者:福斯基 时间:2023-01-19 21:16:51 

我就废话不多说了,直接上代码吧!


import math
import numpy as np
import matplotlib.pyplot as plt
from 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中通常可用于函数求导的函数是sympy库中的diff()函数。

但他通常所求得的导数只是一个符号表达式。不能直接带入数据使用。

如下例:


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

那么该如何解决这个问题呢?

对x,y使用evalf()函数分别赋值后,用float进行类型转换后,才能利用numpy进行数值计算。

如下例:


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)

其输出结果:


-2.61472768902227
-0.16645873461885696

那如果我的x或y不是单一的值呢?而是一个数组。

我们可以利用一个循环来完成。

如下例:


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 = []#先定义一个用于存储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库进行数值计算。

来源:https://blog.csdn.net/cool_bot/article/details/90768063

标签:python,导数,绘图
0
投稿

猜你喜欢

  • 一文搞懂Python中的进程,线程和协程

    2023-06-13 17:26:41
  • 基于python元祖与字典与集合的粗浅认识

    2023-11-11 07:19:48
  • Python Numpy教程之排序,搜索和计数详解

    2021-10-31 05:30:21
  • 配置高可用性的MySQL服务器负载均衡群集

    2009-01-04 12:43:00
  • python通过移动端访问查看电脑界面

    2021-06-02 05:19:58
  • php下载文件源代码(强制任意文件格式下载)

    2023-10-10 07:53:20
  • Pytorch dataloader在加载最后一个batch时卡死的解决

    2022-09-15 06:50:34
  • 使用IDEA回滚某次提交的代码步骤

    2023-06-21 03:15:28
  • go语言Timer计时器的用法示例详解

    2024-04-27 15:39:38
  • 慎用UL列表

    2009-03-25 20:21:00
  • 修改vue+webpack run build的路径方法

    2024-04-28 10:54:08
  • js css 实现遮罩层覆盖其他页面元素附图

    2024-06-08 21:51:06
  • CSS元素类型

    2009-04-27 12:25:00
  • python实现自动重启本程序的方法

    2022-07-18 14:16:19
  • 巧用缓存提高ASP应用程序的性能

    2008-03-09 15:23:00
  • sqlserver数据库出现置疑的解决思路

    2024-01-13 20:11:34
  • ASP如何输出字符

    2007-09-22 18:41:00
  • Python如何发送与接收大型数组

    2022-07-26 06:54:54
  • Python猫眼电影最近上映的电影票房信息

    2023-07-02 18:05:01
  • Flask框架各种常见装饰器示例

    2023-08-25 01:07:45
  • asp之家 网络编程 m.aspxhome.com