Python实现之导数

本文转载自微信公众号「python与大数据分析」,作者一只小小鸟鸟 。转载本文请联系python与大数据分析公众号。

导数(Derivative),也叫导函数值。又名微商,是微积分中的重要基础概念。当函数y=f(x)的自变量x在一点x0上产生一个增量Δx时,函数输出值的增量Δy与自变量增量Δx的比值在Δx趋于0时的极限a如果存在,a即为在x0处的导数,记作f'(x0)或df(x0)/dx。

不是所有的函数都有导数,一个函数也不一定在所有的点上都有导数。若某函数在某一点导数存在,则称其在这一点可导,否则称为不可导。然而,可导的函数一定连续;不连续的函数一定不可导。

切线指的是一条刚好触碰到曲线上某一点的直线。更准确地说,当切线经过曲线上的某点(即切点)时,切线的方向与曲线上该点的方向是相同的。平面几何中,将和圆只有一个公共交点的直线叫做圆的切线。

法线(normal line),是指始终垂直于某平面的直线。在几何学中,法线指平面上垂直于曲线在某点的切线的一条线。法线也应用于光学的平面镜反射上。

 
 
 
 
  1. #!/usr/bin/env python 
  2. # -*- coding: UTF-8 -*- 
  3. #                     _ooOoo_ 
  4. #                   o8888888o 
  5. #                    88" . "88 
  6. #                 ( | -  _  - | ) 
  7. #                     O\ = /O 
  8. #                 ____/`---'\____ 
  9. #                  .' \\| |// `. 
  10. #                 / \\|||:|||// \ 
  11. #               / _|||||-:- |||||- \ 
  12. #                | | \\\ - /// | | 
  13. #              | \_| ''\---/'' | _/ | 
  14. #               \ .-\__ `-` ___/-. / 
  15. #            ___`. .' /--.--\ `. . __ 
  16. #         ."" '< `.___\_<|>_/___.' >'"". 
  17. #       | | : `- \`.;`\  _ /`;.`/ - ` : | | 
  18. #          \ \ `-. \_ __\ /__ _/ .-` / / 
  19. #      ==`-.____`-.___\_____/___.-`____.-'== 
  20. #                     `=---=' 
  21. ''' 
  22. @Project :pythonalgorithms  
  23. @File :derivatives.py 
  24. @Author :不胜人生一场醉@Date :2021/8/1 0:17  
  25. ''' 
  26. import matplotlib.pyplot as plt 
  27. import numpy as np 
  28. import math 
  29. import sympy 
  30. import mpl_toolkits.axisartist as axisartist  # 导入坐标轴加工模块 
  31.  
  32. if __name__ == '__main__': 
  33.     quadraticderivativeplot() 
  34.     exponentialderivativeplot() 
  35.     arccscderivativeplot() 
 
 
 
 
  1. # 导数(Derivative),也叫导函数值。又名微商,是微积分中的重要基础概念。 
  2. # 当函数y=f(x)的自变量x在一点x0上产生一个增量Δx时,函数输出值的增量Δy与自变量增量Δx的比值在Δx趋于0时的极限a如果存在,a即为在x0处的导数,记作f'(x0)或df(x0)/dx。 
  3. # 不是所有的函数都有导数,一个函数也不一定在所有的点上都有导数。 
  4. # 若某函数在某一点导数存在,则称其在这一点可导,否则称为不可导。然而,可导的函数一定连续;不连续的函数一定不可导。 
  5. def quadraticderivativeplot(): 
  6.     plt.figure(figsize=(5, 12)) 
  7.     ax = plt.gca()  # 通过gca:get current axis得到当前轴 
  8.     plt.rcParams['font.sans-serif'] = ['SimHei']  # 绘图中文 
  9.     plt.rcParams['axes.unicode_minus'] = False  # 绘图负号 
  10.     x = np.linspace(-2, 2, 200) 
  11.  
  12.     y = x ** 2 
  13.     label = '函数=x**2的曲线' 
  14.     plt.plot(x, y, label=label) 
  15.     yd = 2 * x 
  16.     label = '导数线=2*x的曲线' 
  17.     plt.plot(x, yd, label=label) 
  18.     a = 1 
  19.     ad = a ** 2 
  20.     plt.plot(a, ad, 'og', label='x=1的某个点') 
  21.     # y=ax+b,已知a=2,x=1,y=1,求b 
  22.     b = ad - 2 * a 
  23.     # 准备画切线的数据 
  24.     al = np.linspace(-2, 2, 200) 
  25.     yl = 2 * al + b 
  26.     label = 'x=1的切线' 
  27.     plt.plot(al, yl, label=label) 
  28.     # 准备画法线的数据,切线斜率=法线斜率的负数 
  29.     b = ad + 2 * a 
  30.     al = np.linspace(-2, 2, 200) 
  31.     yl = -2 * al + b 
  32.     label = 'x=1的法线' 
  33.     plt.plot(al, yl, label=label) 
  34.     # 求导函数 
  35.     x = sympy.Symbol('x') 
  36.     f1 = x ** 2 
  37.     # 参数是函数与变量 
  38.     f1_ = sympy.diff(f1, x) 
  39.     print(f1_) 
  40.  
  41.     # 设置图片的右边框和上边框为不显示 
  42.     ax.spines['right'].set_color('none') 
  43.     ax.spines['top'].set_color('none') 
  44.  
  45.     # 挪动x,y轴的位置,也就是图片下边框和左边框的位置 
  46.     # data表示通过值来设置x轴的位置,将x轴绑定在y=0的位置 
  47.     ax.spines['bottom'].set_position(('data', 0)) 
  48.     # axes表示以百分比的形式设置轴的位置,即将y轴绑定在x轴50%的位置 
  49.     # ax.spines['left'].set_position(('axes', 0.5)) 
  50.     ax.spines['left'].set_position(('data', 0)) 
  51.     plt.title("二次函数、导数曲线及某点的法线、切线") 
  52.     plt.legend(loc='upper right') 
  53.     plt.show() 

 
 
 
 
  1. # 指数函数的导数 
  2. # 指数函数 y=a**x 
  3. # 指数函数的导数为 y=a**x*ln(a) 
  4. def exponentialderivativeplot(): 
  5.     plt.figure(figsize=(5, 12)) 
  6.     ax = plt.gca()  # 通过gca:get current axis得到当前轴 
  7.     plt.rcParams['font.sans-serif'] = ['SimHei']  # 绘图中文 
  8.     plt.rcParams['axes.unicode_minus'] = False  # 绘图负号 
  9.     a = 2 
  10.     x = np.linspace(-2, 2, 200) 
  11.     y = np.power(a, x) 
  12.     yd = np.power(a, x) * np.log(a) 
  13.     label = '函数=a**x的曲线' 
  14.     plt.plot(x, y, label=label) 
  15.     label = '导数线=a**x的曲线' 
  16.     plt.plot(x, yd, label=label) 
  17.  
  18.     xpoint = 1 
  19.     ypoint = np.power(a, xpoint) 
  20.     plt.plot(xpoint, ypoint, 'og', label='x=1的某个点') 
  21.     # 斜率slope=导数,求截距intercept 
  22.     slope = math.pow(a, xpoint) * math.log(a, np.e) 
  23.     # y=ax+b,已知a,x,y,求b 
  24.     intercept = ypoint - slope * xpoint 
  25.     # 准备画切线的数据 
  26.     yl = x * slope + intercept 
  27.     # print(slope,intercept,yl) 
  28.     label = 'x=1的切线' 
  29.     plt.plot(x, yl, label=label) 
  30.     # 准备画法线的数据,切线斜率=法线斜率的负数 
  31.     # y=ax+b,已知x,y,-a,求b 
  32.     intercept = ypoint + slope * xpoint 
  33.     yl = -x * slope + intercept 
  34.     label = 'x=1的法线' 
  35.     plt.plot(x, yl, label=label) 
  36.     # # 求导函数 
  37.     # x = sympy.Symbol('x') 
  38.     # f1 = x**2 
  39.     # # 参数是函数与变量 
  40.     # f1_ = sympy.diff(f1, x) 
  41.     # print(f1_) 
  42.     # 设置图片的右边框和上边框为不显示 
  43.     ax.spines['right'].set_color('none') 
  44.     ax.spines['top'].set_color('none') 
  45.  
  46.     # 挪动x,y轴的位置,也就是图片下边框和左边框的位置 
  47.     # data表示通过值来设置x轴的位置,将x轴绑定在y=0的位置 
  48.     ax.spines['bottom'].set_position(('data', 0)) 
  49.     # axes表示以百分比的形式设置轴的位置,即将y轴绑定在x轴50%的位置 
  50.     # ax.spines['left'].set_position(('axes', 0.5)) 
  51.     ax.spines['left'].set_position(('data', 0)) 
  52.     plt.title("指数函数、导数曲线及某点的法线、切线") 
  53.     plt.legend(loc='upper right') 
  54.     plt.show() 

 
 
 
 
  1. # 常用导数公式表如下:# 
  2. # c'=0(c为常数) 
  3. # (x^a)'=ax^(a-1),a为常数且a≠0 
  4. # (a^x)'=a^xlna 
  5. # (e^x)'=e^x# 
  6. # (logax)'=1/(xlna),a>0且 a≠1 
  7. # (lnx)'=1/x 
  8. # (sinx)'=cosx 
  9. # (cosx)'=-sinx 
  10. # (tanx)'=(secx)^2 
  11. # (secx)'=secxtanx 
  12. # (cotx)'=-(cscx)^2 
  13. # (cscx)'=-csxcotx 
  14. # (arcsinx)'=1/√(1-x^2) 
  15. # (arccosx)'=-1/√(1-x^2) 
  16. # (arctanx)'=1/(1+x^2) 
  17. # (arccotx)'=-1/(1+x^2) 
  18. # arcsinx函数的导数 
  19. # arcsinx函数 
  20. # arcsinx函数的导数为 1/√(1-x^2) 
  21. def arccscderivativeplot(): 
  22.     plt.figure(figsize=(10, 5)) 
  23.     ax = plt.gca()  # 通过gca:get current axis得到当前轴 
  24.     plt.rcParams['font.sans-serif'] = ['SimHei']  # 绘图中文 
  25.     plt.rcParams['axes.unicode_minus'] = False  # 绘图负号 
  26.     x = np.append(np.linspace(0.01, np.pi / 2 - 0.01, 120), 
  27.                   np.linspace(np.pi / 2 + 0.01, np.pi - 0.01, 120)) 
  28.     y = 1 / np.cos(x) 
  29.     # 正割函数 sec(x)=1/cos(x) 
  30.     # 反正割函数 颠倒x,y值即可 
  31.     label = '函数为np.arcsecx(x)的曲线' 
  32.     plt.plot(y, x, label=label) 
  33.     x = np.linspace(-0.99, 0.99, 120) 
  34.     yd = 1 / np.sqrt(1 - np.power(x, 2)) 
  35.     label = '导数线为np.arcsecx(x)的曲线' 
  36.     plt.plot(x, yd, label=label) 
  37.     # 设置图片的右边框和上边框为不显示 
  38.     ax.spines['right'].set_color('none') 
  39.     ax.spines['top'].set_color('none') 
  40.  
  41.     # 挪动x,y轴的位置,也就是图片下边框和左边框的位置 
  42.     # data表示通过值来设置x轴的位置,将x轴绑定在y=0的位置 
  43.     ax.spines['bottom'].set_position(('data', 0)) 
  44.     # axes表示以百分比的形式设置轴的位置,即将y轴绑定在x轴50%的位置 
  45.     # ax.spines['left'].set_position(('axes', 0.5)) 
  46.     ax.spines['left'].set_position(('data', 0)) 
  47.     plt.title("arcsin函数、导数曲线") 
  48.     plt.legend(loc='upper right') 
  49.     plt.show() 

分享标题:Python实现之导数
文章出自:http://www.csdahua.cn/qtweb/news49/336749.html

网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网