美文网首页
绘制Taylor展式的应用

绘制Taylor展式的应用

作者: b485c88ab697 | 来源:发表于2017-09-10 20:01 被阅读16次

练习:Taylor展式的应用

#!/usr/bin/python
#  -*- coding:utf-8 -*-

import numpy as np
import math
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, 4, 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)
    plt.figure(facecolor='w')
    mpl.rcParams['font.sans-serif'] = ['SimHei']
    mpl.rcParams['axes.unicode_minus'] = False
    plt.plot(t, y, 'r-', t, y, 'go', linewidth=2)
    plt.title('Taylor展式的应用 - 指数函数', fontsize=18)
    plt.xlabel('X', fontsize=15)
    plt.ylabel('exp(X)', fontsize=15)
    plt.grid(True, ls=':')
    plt.show()

#!/usr/bin/python
#  -*- coding:utf-8 -*-

import numpy as np
import math
import matplotlib as mpl
import matplotlib.pyplot as plt


def calc_sin_small(x):
    x2 = -x ** 2
    t = x
    f = 1
    sum = 0
    for i in range(10):
        sum += t / f
        t *= x2
        f *= ((2*i+2)*(2*i+3))
    return sum


def calc_sin(x):
    a = x / (2*np.pi)
    k = np.floor(a)
    a = x - k*2*np.pi
    return calc_sin_small(a)


if __name__ == "__main__":
    t = np.linspace(-2*np.pi, 2*np.pi, 100, endpoint=False)
    print(t)     # 横轴数据
    y = np.empty_like(t)
    for i, x in enumerate(t):
        y[i] = calc_sin(x)
        print('sin(', x, ') = ', y[i], '(近似值)\t', math.sin(x), '(真实值)')
        print('误差:', y[i] - math.sin(x))
    mpl.rcParams['font.sans-serif'] = ['SimHei']
    mpl.rcParams['axes.unicode_minus'] = False
    plt.figure(facecolor='w')
    plt.plot(t, y, 'r-', t, y, 'go', linewidth=2)
    plt.title('Taylor展式的应用 - 正弦函数', fontsize=18)
    plt.xlabel('X', fontsize=15)
    plt.ylabel('sin(X)', fontsize=15)
    plt.xlim((-7, 7))
    plt.ylim((-1.1, 1.1))
    plt.grid(True)
    plt.show()

相关文章

  • 绘制Taylor展式的应用

    练习:Taylor展式的应用

  • 数学分析 SVD 常数e 导数/梯度 随机梯度下降 Taylor展式的落地应用 gini系数 凸函数 Jensen...

  • 66. Python基础-数学库(1)

    主要内容 机器学习、深度学习与相关实例概述 机器学习的角度看数学 数学分析: 导数与梯度、Taylor展式的应用 ...

  • 使用 Matplotlib 绘图

    使用 Matplotlib 绘图 绘制多项式函数 绘制多项式函数及其导函数 分别绘制多项式函数及其导数 K 线图 ...

  • 2017-04-25 canvas 学习笔记

    canvas 绘制线条 嵌入式不建议使用,会导致内部图片拉伸 绘制表格背景 绘制表格 绘制矩形 绘制画板 绘制弧线...

  • 动画

    隐式动画 CABaseAnimation 坐标绘制 绘制工具: Paint Code CAKeyFrameAnim...

  • iOS核心动画高级技巧十二(图像IO)

    目录 隐式绘制离屏渲染混合和过度绘制减少图层数量总结 本章将着重图层树本身,以发掘最好的性能。 一 隐式绘制 寄宿...

  • 浅析应用架构演进

    应用架构经过不同阶段,逐渐由单一发展至分布式,由功能化发展至服务化,主要的几类架构如下: 单一应用架构(ORM)-...

  • 《国家地理》自然摄影大赛作品欣赏

    原文|Alan Taylor (Alan Taylor is a senior editor at The Atl...

  • Spring MVC、Spring Boot和Spring Cl

    一、SpringSpring是分层的javaSE/EE应用一站式的轻量级开源框架,以IOC和AOP为内核,提供了展...

网友评论

      本文标题:绘制Taylor展式的应用

      本文链接:https://www.haomeiwen.com/subject/efutsxtx.html