python机器学习高数篇之泰勒公式

作者:水龙吟唱 时间:2022-09-08 18:38:48 

不少同学一提到泰勒公式,脑海里立马浮现高大上的定义和长长的公式,令人望而生畏。

实际上,泰勒公式没有那么可怕,它是用简单的多项式来逼近一个光滑的函数,从而近似替代不熟悉的函数。由于泰勒公式具有将复杂函数近似成多个幂函数叠加形式的性质,可以用它进行比较、求极限、求导、解微分方程等。

我们先来看一下泰勒公式的发明者,布鲁克·泰勒——

python机器学习高数篇之泰勒公式

布鲁克·泰勒(Brook Taylor,1685-1732),英国数学家,牛顿学派最优秀的代表人物之一,他于1712年的一封信里首次叙述了泰勒公式。

再来看一下高数书上对泰勒公式的定义:

python机器学习高数篇之泰勒公式

公式3-5就称为f(x)在x0处的带有拉格朗日余项的n阶泰勒公式。

初看这个泰勒公式的定义,就觉得恢宏大气,气势磅礴。不过光从泰勒公式的定义,很难直观看出它是怎么用多项式逼近原函数的。接下来我们用图像和图表来感受一下——

这里我们先列举出f(x) = cosx在原点的泰勒2阶、4阶、6阶、8阶、10阶的多项式,并用图像表示该函数及其泰勒n阶多项式。

python机器学习高数篇之泰勒公式

对应图像如下,其中黑色线条为原函数f(x),彩色线条为多项式g(x)。可以看到随着阶数的增大,多项式在更大范围内越来越逼近原函数。

python机器学习高数篇之泰勒公式

我们再用python实现函数y=cosx的泰勒n阶多项式,并与y=cosx的实际值进行比较,其中令n=40。


def f_cos(x):
   m = 20+1
   sum = 1.0
   for i in range(1,m): #range函数取值是左闭右开
       n = 2 * i
       tmp1,tmp2,tmp3 = 1,1,1
       for j in range(1,i+1):
           tmp1 = -tmp1            
       for j in range(1,n+1):                    
           tmp2 = tmp2*x
           tmp3 = tmp3*j
       sum = sum + tmp1*tmp2/tmp3
   return sum

from numpy import *
for x in range(-20,21):
   print("x = " + str(x))
   print("f_cos(x) = " + str(f_cos(x)))
   print("cos(x) = " + str(cos(x)))

比较自定义的f_cos(x)和numpy库的cosx的误差:

x取值自定义的f_cos(x)numpy库的cosx误差(f_cos(x) - cos(x))分析
202577.30690.40812576.8988误差非常大
19305.17010.9887304.1814误差较大
1832.59690.660331.9366存在误差
172.6676-0.27522.9428存在误差
16-0.7234-0.95770.2343存在0.1级误差
15-0.7439-0.75970.0158存在0.01级误差
140.13760.13670.0009存在0.0001级误差
130.90750.90740.0000精度范围内一致
120.84390.84390.0000精度范围内一致
110.00440.00440.0000精度范围内一致
10-0.8391-0.83910.0000精度范围内一致
9-0.9111-0.91110.0000精度范围内一致
8-0.1455-0.14550.0000精度范围内一致
70.75390.75390.0000精度范围内一致
60.96020.96020.0000精度范围内一致
50.28370.28370.0000精度范围内一致
4-0.6536-0.65360.0000精度范围内一致
3-0.9900-0.99000.0000精度范围内一致
2-0.4161-0.41610.0000精度范围内一致
10.54030.54030.0000精度范围内一致
01.00001.00000.0000精度范围内一致

由于f(x) = cosx函数关于y轴对称,这里只列举出了x轴右半部分[0,20]的范围,x轴左半部分的结果与右半部分结果相同。

在[0,20]范围内,当x=20时,二者的误差非常大。随着x的减小,二者的误差也在逐渐减小。在[0,13]范围内,二者在精度范围内完全一致,几乎零误差。

大家可以尝试一下,把n的值调大,这个精度一致的范围会变大。例如此例若n=30,即y=cosx的泰勒30阶多项式,则在[-20,20]范围内,二者精度都完全一致。感兴趣的同学可以运用同样的方法,分析一下其他函数。

再试着写出函数y=sinx的泰勒n阶多项式的python程序,其中n=19。


def f_sin(x):
   m = 10+1
   sum = 0.0
   for i in range(1,m):
       n = 2 * i - 1    
       tmp1,tmp2,tmp3 = 1,1,1
       for j in range(1,i):
           tmp1 = -tmp1  
       for j in range(1,n+1):          
           tmp2 = tmp2*x
           tmp3 = tmp3*j
       sum = sum + tmp1*tmp2/tmp3
   return sum

from numpy import *
for x in range(-20,21):
   print("x = " + str(x))
   print("f_sin(x) = " + str(f_sin(x)))
   print("sin(x) = " + str(sin(x)))

后续会继续增加一些函数的泰勒n阶多项式python程序(可能会偷懒)。

最后推荐一个比较好用的在线画函数的工具Desmos:

https://www.desmos.com/calculator?lang=zh-CN

简易教程:

https://www.ravenxrz.ink/archives/27d14722.html

还可以用著名的心形线画个爱心哦:

python机器学习高数篇之泰勒公式

来源:https://blog.csdn.net/mint1993/article/details/119953238

标签:python,泰勒公式,机器学习
0
投稿

猜你喜欢

  • javascript面向对象编程(二)

    2008-03-07 12:59:00
  • Python玩转PDF的各种骚操作

    2023-07-07 17:51:59
  • python pillow库的基础使用教程

    2023-05-21 19:19:29
  • python利用socket实现客户端和服务端之间进行通信

    2022-04-23 07:34:59
  • 数据库备份过程中经常遇到的九种情况

    2008-12-26 16:38:00
  • JSONObject.toString

    2008-03-09 19:12:00
  • Python与人工神经网络:使用神经网络识别手写图像介绍

    2022-05-23 03:11:36
  • js控制多图左右滚动切换效果代码分享

    2023-08-28 00:14:32
  • thinkphp6如何使用中间件记录行为日志

    2023-06-13 14:43:44
  • 只有mdf文件的数据库附加失败的修复方法分享(置疑、只读)

    2012-02-12 15:55:17
  • asp 在线备份与恢复sql server数据库的代码

    2010-07-31 18:52:00
  • 不用script仅用css编写无限级弹出菜单

    2008-04-24 14:03:00
  • 表格梳理解析python内置时间模块看完就懂

    2023-10-21 08:10:27
  • PHP制作3D扇形统计图以及对图片进行缩放操作实例

    2023-11-17 19:31:47
  • Javascript调试之console对象——你不知道的一些小技巧

    2023-08-07 19:24:14
  • python二分法查找算法实现方法【递归与非递归】

    2023-04-17 08:13:47
  • pytest使用parametrize将参数化变量传递到fixture

    2022-03-28 23:30:18
  • Python 调用 C++ 传递numpy 数据详情

    2021-05-12 20:00:39
  • php中session_unset与session_destroy的区别分析

    2023-07-17 21:34:56
  • asp如何显示自定义随机信息?

    2010-06-08 09:39:00
  • asp之家 网络编程 m.aspxhome.com