5.3Python数据处理篇之Sympy系列(三)---简化操作
5.3简化操作
目录
前言
既然sympy是对于符号的运算,那么它对于符号表达式的简化与展开一定很强大。
今天我们学习的是符号表达式的简化与展开。
本章节对应官网的Simplification
(一)有理数与多项式的简化
1.最简化-simplify()
(1)说明:
simplify()是尽可能的让表达式最简化,其最简化的形式是不定的。
(2)源代码:
from sympy import *
x = Symbol('x')
expr1 = cos(x)**2+sin(x)**2
expr2 = (x**3 + x**2 - x - 1)/(x**2 + 2*x + 1)
# 简化表达式
r1 = simplify(expr1)
r2 = simplify(expr2)
print(r1)
print(r2)
(3)输出:
\(cos(x)^2+sin(x)^2\)-->1
\((x^3 + x^2 - x - 1)/(x^2 + 2x + 1)\)-->\(x-1\)
2.展开-expand()
(1)说明:
expand()是对括号里的多项式进行展开。
(2)源代码:
from sympy import *
x = Symbol('x')
expr1 = (x+1)**2
expr2 = ((x + 1)*(x - 2) - (x - 1)*x)
# 展开
r1 = expand(expr1)
r2 = expand(expr2)
print(r1)
print(r2)
(3)输出:
\((x+1)^2\)-->\(x^2+2x+1\)
\((x + 1)(x - 2) - (x - 1)x\)-->-2
3.提公因式-factor()
(1)说明:
factor()是对展开的多项式进行提公因式
(2)源代码:
from sympy import *
x = Symbol('x')
expr1 = (x ** 3 - x ** 2 + x - 1)
# 提公因数
r1 = factor(expr1)
print(r1)
print(latex(expr1))
print(latex(r1))
(3)输出:
\(x^{3} - x^{2} + x - 1\)-->\(\left(x - 1\right) \left(x^{2} + 1\right)\)
4.合并同类项-ceiling()
(1)说明:
对于多项式进行合并同类项
(2)源代码:
from sympy import *
x = Symbol('x')
y = Symbol('y')
z = Symbol('z')
expr1 = x*y + x - 3 + 2*x**2 - z*x**2 + x**3
expr2 = x**3+x*2-3*x**2+x**3-x**2+x*4-5
# 合并同类项
r1 = ceiling(expr1)
r2 = ceiling(expr2)
print(r1)
print(r2)
print(latex(r1))
print(latex(r2))
(3)输出:
\(xy + x - 3 + 2x^2 - zx^2 + x^3\) --> \(\lceil{x^{3} - x^{2} z + 2 x^{2} + x y + x}\rceil - 3\)
\(x^3+x2-3x^2+x^3-x^2+x4-5\) --> \(\lceil{2 x^{3} - 4 x^{2} + 6 x}\rceil - 5\)
5.简化分式-cancel()
(1)说明:
cancle既有约分又有简化的作用
(2)源代码:
from sympy import *
x = Symbol('x')
expr1 = (x**2 + 2*x + 1)/(x**2 + x)
expr2 = 1/x + (3*x/2 - 2)/(x - 4)
# 约分消去分式的公因数
r1 = cancel(expr1)
# 简化分式
r2 = cancel(expr2)
# 结果
print("结果:r1", r1)
print("结果:r2", r2)
# r1的表达式与结果
print("r1的表达式与结果:")
print(latex((x**2 + 2*x + 1)/(x**2 + x)))
print(latex(r1))
# r2的表达式与结果
print("\nr2的表达式与结果:")
print(latex(1/x + (3*x/2 - 2)/(x - 4)))
print(latex(r2))
(3)输出:
\(\frac{x^{2} + 2 x + 1}{x^{2} + x}\) --》 \(\frac{x + 1}{x}\)
\(\frac{\frac{3 x}{2} - 2}{x - 4} + \frac{1}{x}\) --》 \(\frac{3 x^{2} - 2 x - 8}{2 x^{2} - 8 x}\)
6.分式展开-apart()
(1)说明:
原本只有一项的分式表达式,展开为多项的分式表达式。
(2)源代码:
from sympy import *
x = Symbol('x')
expr1 = (4*x**3 + 21*x**2 + 10*x + 12)/(x**4 + 5*x**3 + 5*x**2 + 4*x)
# 对于分式进行展开
r1 = apart(expr1)
print(r1)
print(latex(r1))
print(latex(expr1))
(3)输出:
\]
---》
\]
(二)三角函数的简化
1.三角形的简化-trigsimp()
(1)说明:
使用trigsimp()可以简化三角函数,反三角函数也可以。
(2)源代码:
from sympy import *
x = Symbol('x')
expr1 = sin(x)**2+cos(x)**2
expr2 = sin(x)**4 - 2*cos(x)**2*sin(x)**2 + cos(x)**4
# 进行三角形简化
r1 = trigsimp(expr1)
r2 = trigsimp(expr2)
print("r1:", r1)
print("r2:", r2)
# r1的latex
print("="*20)
print("expr1-latex:", latex(expr1))
print("r1-latex:", latex(r1))
# r2的latex
print("="*20)
print("expr2-latex:", latex(expr2))
print("r2-latex:", latex(r2))
(3)输出:
\(\sin^{2}{\left (x \right )} + \cos^{2}{\left (x \right )}\) --> \(1\)
\(\sin^{4}{\left (x \right )} - 2 \sin^{2}{\left (x \right )} \cos^{2}{\left (x \right )} + \cos^{4}{\left (x \right )}\) --> \(\frac{\cos{\left (4 x \right )}}{2} + \frac{1}{2}\)
2.三角形的展开-expand_trig()
(1)说明:
使用expand_trig()可以展开三角函数,同样反三角函数也可以。
(2)源代码:
from sympy import *
x = Symbol('x')
y = Symbol('y')
expr1 = sin(x+y)
expr2 = tan(2*x)
# 三角形的展开
r1 = expand_trig(expr1)
r2 = expand_trig(expr2)
print("===========r1==========")
print(r1)
print(latex(expr1))
print(latex(r1))
print("===========r2==========")
print(r2)
print(latex(expr2))
print(latex(r2))
(3)输出:
\(\sin{\left (x + y \right )}\) --> \(\sin{\left (x \right )} \cos{\left (y \right )} + \sin{\left (y \right )} \cos{\left (x \right )}\)
\(\tan{\left (2 x \right )}\) --> \(\frac{2 \tan{\left (x \right )}}{- \tan^{2}{\left (x \right )} + 1}\)
(三)指数函数的简化
1.指数的合并一-powsimp()
(1)说明:
powsimp()主要用于同底数或者同指数
(2)源代码:
from sympy import *
# 假设 x与y 是正值, a 是真实的值
x = Symbol('x', positive=True)
y = Symbol('y', positive=True)
a = Symbol('a', real=True)
expr1 = x**2*x**3
expr2 = x**a*y**a
# 进行指数的合并,如果不符合,则不进行简化
r1 = powsimp(expr1)
r2 = powsimp(expr2)
print("===========r1==========")
print(r1)
print(latex(expr1))
print(latex(r1))
print("===========r2==========")
print(r2)
print(latex(expr2))
print(latex(r2))
(3)输出:
\(x^2x^3\) --> \(x^5\)
\(x^ay^b\) --> \(\left(x y\right)^{a}\)
2.指数的合并二-powdenest()
(1)说明:
powdenest()主要用于只有一个底数的不同指数。
(2)源代码:
from sympy import *
# 假设 x与y 是正值, a 是真实的值
x = Symbol('x', positive=True)
y = Symbol('y', positive=True)
a = Symbol('a', real=True)
b = Symbol('b', real=True)
expr1 = (x**a)**b
expr2 = (((x**2)**a)**b)
# 进行指数的合并,如果不符合,则不进行简化
r1 = powdenest(expr1)
r2 = powdenest(expr2)
print("===========r1==========")
print(r1)
print(latex(expr1))
print(latex(r1))
print("===========r2==========")
print(r2)
print(latex(expr2))
print(latex(r2))
(3)输出:
\((x^a)^b\) --> \(x^{ab}\)
\({{x^2}^a}^b\) --> \(x^{2ab}\)
3.指数的展开:-expand_power_exp\expand_power_base
(1)说明:
- expand_power_exp()用于同底数的展开
- expand_power_base()用于同指数的展开
(2)源代码:
from sympy import *
# 假设 x与y 是正值, a 是真实的值
x = Symbol('x', positive=True)
y = Symbol('y', positive=True)
a = Symbol('a', real=True)
b = Symbol('b', real=True)
expr1 = x**(a+b)
expr2 = (x*y)**a
# 进行指数的展开
# 底数相同展开
r1 = expand_power_exp(expr1)
# 指数相同展开
r2 = expand_power_base(expr2)
print("===========r1==========")
print(r1)
print(latex(expr1))
print(latex(r1))
print("===========r2==========")
print(r2)
print(latex(expr2))
print(latex(r2))
(3)输出:
\(x^{a+b}\) --> \(x^{a} x^{b}\)
\(\left(x y\right)^{a}\) --> \(x^{a} y^{a}\)
(四)对数函数的简化
1.对数的简化-logcombine()
(1)说明:
logcombine()用于合并对数。
(2)源代码:
from sympy import *
# 假设 x与y 是正值, a 是真实的值
x = Symbol('x', positive=True)
y = Symbol('y', positive=True)
n = Symbol('n', real=True)
expr1 = log(x) + log(y)
expr2 = log(x) - log(y)
expr3 = n*log(x)
# 对于对数的展开
r1 = logcombine(expr1)
r2 = logcombine(expr2)
r3 = logcombine(expr3)
print(r1)
print(r2)
print(r3)
(3)输出:
\(log(x) + log(y)\) --> \(log(xy)\)
\(log(x)-log(y)\) --> \(\log(xy)\)
\(n\log(x)\) --> \(log(x^n)\)
2.对数的展开-expand_log()
(1)说明:
expand_log()用于对数的展开。
(2)源代码:
from sympy import *
# 假设 x与y 是正值, a 是真实的值
x = Symbol('x', positive=True)
y = Symbol('y', positive=True)
n = Symbol('n', real=True)
expr1 = log(x*y)
expr2 = log(x/y)
expr3 = log(x**n)
# 对于对数的展开
r1 = expand_log(expr1)
r2 = expand_log(expr2)
r3 = expand_log(expr3)
print(r1)
print(r2)
print(r3)
(3)输出:
\(log(xy)\) --> \(log(x)+log(y)\)
\(log(x/y)\) --> \(log(x)-\log(y)\)
\(log(x^n)\) --> \(n\log(x)\)
(五)其他函数的简化
1.阶乘与排列组合-factorial()\binomial()
(1)说明:
- factorial()用于求阶乘
- binomial()用于求排列组合
(2)源代码:
from sympy import *
n = Symbol("n")
# 求阶乘
r1 = factorial(3)
r2 = factorial(n)
print(r1)
print(r2)
# 排列组合
print(binomial(4, 2))
(3)输出:
作者:Mark
日期:2019/03/16 周六
5.3Python数据处理篇之Sympy系列(三)---简化操作的更多相关文章
- 4.3Python数据处理篇之Matplotlib系列(三)---plt.plot()折线图
目录 前言 (一)plt.plot()函数的本质 ==1.说明== ==2.源代码== ==3.展示效果== (二)plt.plot()函数缺省x时 ==1.说明== ==2.源代码== ==3.展示 ...
- 3.3Python数据处理篇之Numpy系列(三)---数组的索引与切片
目录 (一)数组的索引与切片 1.说明: 2.实例: (二)多维数组的索引与切片 1.说明: 2.实例: 目录: 1.一维数组的索引与切片 2.多维数组的索引与切片 (一)数组的索引与切片 1.说明: ...
- 5.6Python数据处理篇之Sympy系列(六)---矩阵的操作
目录 目录 前言 (一)矩阵的创建-Matrix() 1.说明: 2.源代码: 3.输出: (二)常用的构造矩阵 1.说明: 2.源代码: 3.输出: (三)基本操作 1.说明: 2.源代码: 3.输 ...
- 5.5Python数据处理篇之Sympy系列(五)---解方程
目录 目录 前言 (一)求解多元一次方程-solve() 1.说明: 2.源代码: 3.输出: (二)解线性方程组-linsolve() 1.说明: 2.源代码: 3.输出: (三)解非线性方程组-n ...
- 5.4Python数据处理篇之Sympy系列(四)---微积分
目录 目录 前言 (一)求导数-diff() 1.一阶求导-diff() 2.多阶求导-diff() 3.求偏导数-diff() (二)求积分-integrate() (三)求极限-limit() ( ...
- 5.2Python数据处理篇之Sympy系列(二)---Sympy的基本操作
目录 目录 前言 (一)符号的初始化与输出设置-symbol() symbols() latex() 1.作用: 2.操作: (二)替换符号-subs(old,new) 1.说明: 2.源代码: 3. ...
- 5.1Python数据处理篇之Sympy系列(一)---Sympy的大体认识
目录 目录 前言 目录 前言 sympy是python一个强大的数学符号运算第三方库,具体的功能请看下面操作 官网教程: https://docs.sympy.org/latest/tutorial/ ...
- 3.6Python数据处理篇之Numpy系列(六)---Numpy随机函数
目录 目录 前言 (一)基础的随机函数 (二)轴的随机函数 (三)概率的随机函数 目录 前言 前一段日子学了numpy,觉得无趣,没有学完,不过后来看了看matplotlib,sympy等库时,频频用 ...
- 4.13Python数据处理篇之Matplotlib系列(十三)---轴的设置
目录 目录 前言 (一)设置轴的范围 1.同时对于x,y轴设置 2.分别对与x,y轴的设置 (二)设置刻度的大小 1.普通的刻度设置 2.添加文本的刻度设置 3.主副刻度的设置 (三)设置轴的数据 1 ...
随机推荐
- java中子类继承父类程序执行顺序问题
Java中,new一个类的对象,类里面的静态代码块.非静态代码.无参构造方法.有参构造方法.类的一般方法等部分,它们的执行顺序相对来说比较简单,用程序也很容易验证.比如新建一个测试父类. public ...
- python编译、运行、反编译pyc文件
为了加密 .py 文件,以前一般使用打包成 exe ,但是最近发现可以将其编译成二进制文件 pyc ,虽然反编译难度不大,但是也需要一些水平 编译生成 pyc: 单个文件 代码: import py_ ...
- java集合框架整理
一.总体框架 Java集合是java提供的工具包,包含了常用的数据结构:集合.链表.队列.栈.数组.映射等.Java集合工具包位置是java.util.* .Java集合主要可以划分为4个部分:Lis ...
- JVM基础系列第11讲:JVM参数之堆栈空间配置
JVM 中最重要的一部分就是堆空间了,基本上大多数的线上 JVM 问题都是因为堆空间造成的 OutOfMemoryError.因此掌握 JVM 关于堆空间的参数配置对于排查线上问题非常重要. tips ...
- WebSocket(4)---实现定时推送比特币交易信息
实现定时推送比特币交易信息 实现功能:跟虚拟币交易所一样,时时更新当前比特币的价格,最高价,最低价,买一价等等...... 提示:(1)本篇博客是在上一遍基础上搭建,上一篇博客地址:[WebSocke ...
- 使用Spring Cloud搭建高可用服务注册中心
我们需要的,不仅仅是一个服务注册中心而已,而是一个高可用服务注册中心. 上篇博客[使用Spring Cloud搭建服务注册中心]中我们介绍了如何使用Spring Cloud搭建一个服务注册中心,但是搭 ...
- 【深度学习系列】卷积神经网络CNN原理详解(一)——基本原理
上篇文章我们给出了用paddlepaddle来做手写数字识别的示例,并对网络结构进行到了调整,提高了识别的精度.有的同学表示不是很理解原理,为什么传统的机器学习算法,简单的神经网络(如多层感知机)都可 ...
- tomcat 大并发报错 Maximum number of threads (200) created for connector with address null and port 80
1.INFO: Maximum number of threads (200) created for connector with address null and port 80 说明:最大线程数 ...
- aspx 页面中 js 引用与页面后台的数据交互 --【 后台调用 js 】
js 中调用后台方法 一.用Response.Write方法 Response.Write("<script type='text/javascript'>alert(&qu ...
- C#图片裁切,生成新图片
/// 图片裁剪,生成新图,保存在同一目录下,名字加_new,格式1.png 新图1_new.png /// </summary> /// <param name="pic ...