• 【Python】SymPy符号计算库学习


    SymPy符号整理

    • 定义变量(符号):symbols
    • 定义函数:Function

    SymPy函数整理

    积分与泰勒展开

    • 表达式展开expand()

    expand(,complex=True):表达式分为实数、虚数两部分

    • 泰勒展开series(函数表达式,自变量,0,余项次数)
    • 不定积分运算integrate(表达式,自变量)

    定积分运算integrate(表达式,(自变量,积分下界,积分上届))

    • 算式中x换成ysubs(x,y)

    IN:

    import numpy as np
    from sympy import *
    #将x定义为符号
    x=Symbol("x",real=True)
    #创建多个符号:x,y,r=symbols('x,y,r')
    #参数:positive=True,表示符号为正
    #var():快速创建变量和Symbol对象
    #泰勒展开
    tmp=series(exp(I*x),x,0,10)
    tmp
    #获得tmp实部
    re(tmp)
    #获得tmp虚部
    im(tmp)
    

    OUT:

    1 + I*x - x**2/2 - I*x**3/6 + x**4/24 + I*x**5/120 - x**6/720 - I*x**7/5040 + x**8/40320 + I*x**9/362880 + O(x**10)
    x**8/40320 - x**6/720 + x**4/24 - x**2/2 + re(O(x**10)) + 1
    

    表达式化简

    • 化简数学表达式:simplify()
    • 分母有理化:radsimp()
    • 通分:fraction()
    • 约分:trim()
    • 三角函数化简:trigsimp()

    deep=True:对所有子表达式化简

    recursive=True:递归进行最大程度化简

    • 乘法展开:mul()
    • 整数次幂展开:multinomial()
    • log展开:expand()
    • 合并同类项:collect()

    IN:

    var("a,b,x")
    #展开eq得到eq2
    eq=(1+a*x)**3+(1+b*x)**2
    eq2=expand(eq)
    eq2
    #合并同类项
    collect(eq2,x)
    #得到x的各次幂系数,如获得x的二次项系数
    p=collect(eq2,x,evaluate=False)
    p[x**2]
    

    OUT:

    a**3*x**3 + 3*a**2*x**2 + 3*a*x + b**2*x**2 + 2*b*x + 2
    a**3*x**3 + x**2*(3*a**2 + b**2) + x*(3*a + 2*b) + 2
    3*a**2 + b**2
    

    解方程

    • 解方程:solve()

    IN:

    var("a,b,c")
    #解一元二次方程
    solve(a*x**2+b*x+c,x)
    #解二元二次方程,结果每个元组表示方程的一组解
    solve((x**2+x*y+1,y**2+x*y+2),x,y)
    

    OUT:

    [(-b + sqrt(-4*a*c + b**2))/(2*a), -(b + sqrt(-4*a*c + b**2))/(2*a)]
    [(-sqrt(3)*I/3, -2*sqrt(3)*I/3), (sqrt(3)*I/3, 2*sqrt(3)*I/3)]
    

    微分

    • 得到导函数:t=Derivative(f(x),x)
    • 计算出导函数:t.doit()
    • 高阶导函数:Derivative(f(x),x,3)
    • 多个变量导函数:Derivative(f(x,y),x,2,y,3)
    • 微分方程符号求解:dsolve((Derivative(f(x),x)-f(x),f(x))

    hint=best,返回最简单的解,得到最简单的显函数表达式

    积分

    • 不定积分运算integrate(表达式,自变量)
    • 定积分运算integrate(表达式,(自变量,积分下界,积分上届))
    • 二重不定积分运算integrate(表达式,x,y)
    • 二重定积分运算integrate(表达式,(x,a,b),(y,c,d))
    • 计算出积分函数:doit()
    • 无法表示为初等函数的积分——数值计算:evalf()

    (不够精确,且不适合计算无穷积分)

    其他

    一些基础语句补充:

    • E:自然底数
    • I:虚数单位
    • pi:π
    • **:^
    • exp():e^x

    参考资料

    • 《Python科学计算》
  • 相关阅读:
    【Unity】第10章 Mecanim动画系统
    【Unity】9.3 粒子系统生成器详解
    只用一招,让你Maven依赖下载速度快如闪电
    原来实现项目多环境打包部署是如此的简单
    手写Maven的archetype项目脚手架
    通俗易懂详解Java代理及代码实战
    谈谈分布式版本管理工具Git
    拥抱了IDEA却发现再也回不去Eclipse...
    解决Redisson出现Failed to instantiate [org.redisson.api.RedissonClient]: Factory method 'create' threw exception; nested exception is java.lang.ArrayIndexOutOfBoundsException: 0的问题
    解决org.apache.shiro.session.UnknownSessionException: There is no session with id的问题
  • 原文地址:https://www.cnblogs.com/fighterkaka22/p/14044367.html
Copyright © 2020-2023  润新知