成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Python實現之導數

開發 后端
導數(Derivative),也叫導函數值。又名微商,是微積分中的重要基礎概念。當函數y=f(x)的自變量x在一點x0上產生一個增量Δx時,函數輸出值的增量Δy與自變量增量Δx的比值在Δx趨于0時的極限a如果存在,a即為在x0處的導數,記作f'(x0)或df(x0)/dx。

[[414928]]

本文轉載自微信公眾號「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與大數據分析
相關推薦

2021-08-03 23:05:31

Python導數實現

2021-08-11 07:02:04

Python激活函數

2021-04-14 20:10:50

Netfileter Iptables 源碼

2022-04-05 20:54:21

OpenCVPython人臉檢測

2021-07-30 05:00:04

Python初等函數

2009-06-08 13:37:00

IBM數據中心虛擬化

2010-01-21 11:19:44

TCP Socketlinux

2023-07-13 00:12:50

OPA代碼

2022-01-26 00:02:00

PythonGUI界面

2010-05-28 17:32:11

MySQL命令導數據

2011-07-20 15:20:14

IPhone AVAudioRec

2012-02-01 11:20:23

Java線程

2020-05-27 20:45:31

Redis底層數據

2021-05-08 07:57:17

ServletFilter設計模式

2013-03-15 10:57:13

AJAXDotNet

2022-12-13 15:41:41

測試軟件開發

2010-01-26 11:12:27

2017-01-04 13:42:35

MINIFILTER文件重定向源碼

2018-03-14 14:28:20

Python數據分析可視化

2022-03-06 23:04:17

CDO首席信息官數字化轉型
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 午夜在线免费观看 | 日本久久网站 | h网站在线观看 | 国产亚洲网站 | 日韩中文字幕在线视频观看 | 免费看91| 日本精品免费在线观看 | 在线观看亚洲专区 | 国产自产c区 | 国产一区亚洲二区三区 | 天天操 夜夜操 | 日韩a在线观看 | 国产欧美在线视频 | 色婷婷av久久久久久久 | 亚洲综合在线视频 | 欧一区二区 | 国产高清在线视频 | 男女又爽又黄视频 | 激情五月婷婷综合 | 亚洲精品免费视频 | 免费特黄视频 | 中国免费黄色片 | 人人干视频在线 | 涩涩99| 久久精品免费一区二区 | 91视视频在线观看入口直接观看 | 亚洲成人av一区二区 | 在线中文视频 | 精品综合 | 久久精品男人的天堂 | 日韩视频中文字幕 | 久久精品亚洲欧美日韩久久 | 精品在线一区 | 神马九九 | 亚洲精品视频在线看 | 97伦理电影| 久久狠狠 | av一级久久 | 国产精品精品 | 亚洲一区免费 | 天天干狠狠 |