Python --- Taylor展式的应用

Taylor展式的应用

前言:按照教材Coding了一份代码,运行出来感觉挺有成就感的!嘎嘎

代码:
import math
import numpy as np
import matplotlib as mpl
import matplotlib.pyplot as plt

def calc_e_small(x):
    n = 10
    f = np.arange(1, n+1).cumprod()
    b = np.array([x]*n).cumprod()
    return np.sum(b / f) + 1

def calc_e(x):
    reverse = False
    if x < 0:                           #处理负数
        x = -x
        reverse = True
    ln2 = 0.69314718055994530941723212145818
    c = x / ln2
    a = int(c + 0.5)
    b = x - a * ln2
    y = (2 ** a) * calc_e_small(b)
    if reverse:
        return 1 / y
    return y

if __name__ == "__main__":
    t1 = np.linspace(-2, 0, 10, endpoint= False)
    t2 = np.linspace(0, 2, 20)
    t = np.concatenate((t1, t2))
    print(t)                             #横轴数据
    y = np.empty_like(t)
    for i, x in enumerate(t):
        y[i] = calc_e(x)
        print( 'e^', x, '=', y[i], '(近似值)\t', math.exp(x))
        # print '误差' , y[i] - math.exp(x)

    mpl.rcParams['font.sans-serif'] = [u'SimHei']
    mpl.rcParams['axes.unicode_minus'] = False
    plt.plot(t, y, 'r-', t, y, 'go', linewidth = 2)
    plt.title(u'Taylor展式的应用', fontsize = 18)
    plt.xlabel('x', fontsize = 15)
    plt.ylabel('exp(x)', fontsize = 15)
    plt.grid(True)
    plt.show()

运行结果:

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值