目录

前言

今天我们学习的是,有关sympy的矩阵操作

对应官方的:Matrices

官方教程

https://docs.sympy.org/latest/tutorial/matrices.html

参考网站

https://junjiecai.github.io/posts/2017/Jan/30/sympy_intro_3/

(一)矩阵的创建-Matrix()

1.说明:

Matrix(list),使用list来确定矩阵的维度。

2.源代码:

  1. from sympy import *
  2. # 一纬矩阵
  3. m1 = Matrix([1, 2, 3])
  4. #二维矩阵
  5. m2 = Matrix([[1, -1], [3, 4], [0, 2]])
  6. print(latex(m1))
  7. print(latex(m2))

3.输出:

\[\left[\begin{matrix}1\\2\\3\end{matrix}\right]
\]

\[\left[\begin{matrix}1 & -1\\3 & 4\\0 & 2\end{matrix}\right]
\]

(二)常用的构造矩阵

1.说明:

可以使用sympy自带的方法来快速的构造常用矩阵

  1. 单位矩阵:eye()
  2. 零矩阵:zeros()
  3. 一矩阵:ones()
  4. 对角矩阵:diag()

2.源代码:

  1. from sympy import *
  2. # 单位矩阵
  3. m1 = eye(3)
  4. print(latex(m1))
  5. # 零矩阵
  6. m2 = zeros(3, 4)
  7. print(latex(m2))
  8. # 一矩阵
  9. m3 = ones(3, 4)
  10. print(latex(m3))
  11. # 对角矩阵
  12. m4 = diag([1, 2, 3])
  13. print(latex(m4))

3.输出:

单位矩阵

\[\left[\begin{matrix}1 & 0 & 0\\0 & 1 & 0\\0 & 0 & 1\end{matrix}\right]
\]

零矩阵

\[\left[\begin{matrix}0 & 0 & 0 & 0\\0 & 0 & 0 & 0\\0 & 0 & 0 & 0\end{matrix}\right]
\]

一矩阵

\[\left[\begin{matrix}1 & 1 & 1 & 1\\1 & 1 & 1 & 1\\1 & 1 & 1 & 1\end{matrix}\right]
\]

对角矩阵

\[\left[\begin{matrix}1 & 0 & 0\\0 & 2 & 0\\0 & 0 & 3\end{matrix}\right]
\]

(三)基本操作

1.说明:

基本操作有以下几个:

  1. 获取形状:.shape()
  2. 获得单行与单列:.row(n) .col(n)
  3. 删除行与列:row_del(n) .col_del(n)
  4. 插入新行与列:.row_insert(pos, M) .col_insert(pos, M)
  5. 对矩阵求转置:m.T

2.源代码:

  1. from sympy import *
  2. m = Matrix([[1, -1], [3, 4], [0, 2]])
  3. # 矩阵
  4. print(m)
  5. # 获得形状
  6. print(m.shape)
  7. # 获得单行与单列
  8. print(m.row(0))
  9. print(m.col(0))
  10. # 删除行与列
  11. m.row_del(0)
  12. print("删除第一行后:", m)
  13. m.col_del(0)
  14. print("删除第一列后:", m)
  15. print(m)
  16. # 插入新的行与列
  17. m2 = Matrix([[2, 3]])
  18. print("m2:", m2)
  19. m2 = m2.row_insert(1, Matrix([[0, 4]]))
  20. print("插入新行后:", m2)
  21. m2 = m2.col_insert(2, Matrix([9, 8]))
  22. print("插入新列后:", m2)
  23. # 求逆矩阵
  24. print("其逆矩阵是:", m2.T)

3.输出:

\[m = \left[\begin{matrix}1 & -1\\3 & 4\\0 & 2\end{matrix}\right]
\]

其形状是:(3, 2)

第一行是:

\[\left[\begin{matrix}1 & -1\end{matrix}\right]
\]

第一列是:

\[\left[\begin{matrix}1\\3\\0\end{matrix}\right]
\]

删除第一行后:

\[\left[\begin{matrix}3 & 4\\0 & 2\end{matrix}\right]
\]

删除第一列后:

\[\left[\begin{matrix}4\\2\end{matrix}\right]
\]

\[m2 = \left[\begin{matrix}2 & 3\end{matrix}\right]
\]

插入一行是:

\[\left[\begin{matrix}2 & 3\\0 & 4\end{matrix}\right]
\]

插入一列是:

\[\left[\begin{matrix}2 & 3 & 9\\0 & 4 & 8\end{matrix}\right]
\]

其转转置矩阵是:

\[\left[\begin{matrix}2 & 3 & 9\\0 & 4 & 8\end{matrix}\right]
\]

(四)矩阵的运算

1.加减法

(1)说明:

sympy里的加减法,直接使用+ -即可

(2)源代码:

  1. from sympy import *
  2. M = Matrix([1, 2, 3])
  3. N = Matrix([4, 5, 6])
  4. # 加法与减法
  5. print("M+N:", M+N)
  6. print("M-N:", M-N)

(3)输出效果:

\[M = \left[\begin{matrix}1\\2\\3\end{matrix}\right]
\]

\[N = \left[\begin{matrix}4\\5\\6\end{matrix}\right]
\]

\[M + N =\left[\begin{matrix}5\\7\\9\end{matrix}\right]
\]

\[M - N = \left[\begin{matrix}-3\\-3\\-3\end{matrix}\right]
\]

2.乘法与求逆

(1)说明:

乘法:*

求逆矩阵:M**(-1)

(2)源代码:

  1. from sympy import *
  2. M = Matrix([[1, -1, 1], [2, 3, -2]])
  3. N = Matrix([[1, 2], [2, 1], [1, 1]])
  4. # 求乘法
  5. print(M*N)
  6. # 求逆矩阵
  7. m = Matrix([[1, 3], [-2, 3]])
  8. print(m**(-1))

(3)输出效果:

\[M = \left[\begin{matrix}1 & -1 & 1\\2 & 3 & -2\end{matrix}\right]
\]

\[N = \left[\begin{matrix}1 & 2\\2 & 1\\1 & 1\end{matrix}\right]
\]

\[M*N = \left[\begin{matrix}0 & 2\\6 & 5\end{matrix}\right]
\]

\[m = \left[\begin{matrix}1 & 3\\-2 & 3\end{matrix}\right]
\]

\[m^{-1} = \left[\begin{matrix}\frac{1}{3} & - \frac{1}{3}\\\frac{2}{9} & \frac{1}{9}\end{matrix}\right]
\]

(五)行列式

1.说明:

  1. 求行列式:M.det()
  2. 求阶梯矩阵:M.rref()
  3. 求特征值与向量:M.eignvals()

2.源代码:

  1. from sympy import *
  2. M = Matrix([[1, 0, 1], [2, -1, 3], [4, 3, 2]])
  3. # 求行列式
  4. print("行列式:", M.det())
  5. # 求阶梯行列式
  6. print("阶梯行列式:", M.rref())
  7. # 求特征值与特征向量
  8. M = Matrix([[3, -2, 4, -2], [5, 3, -3, -2], [5, -2, 2, -2], [5, -2, -3, 3]])
  9. print("特征值与特征向量: ", M.eigenvals())

3.输出:

\[\begin{vmatrix}1 & 0 & 1\\2 & -1 & 3\\4 & 3 & 2\end{vmatrix}=1
\]

\[M = \left[\begin{matrix}1 & 0 & 1\\2 & -1 & 3\\4 & 3 & 2\end{matrix}\right]
\]

M的阶梯矩阵:

\[\left ( \left[\begin{matrix}1 & 0 & 0\\0 & 1 & 0\\0 & 0 & 1\end{matrix}\right], \quad \left ( 0, \quad 1, \quad 2\right )\right )
\]

另一个M矩阵:

\[M = \left[\begin{matrix}3 & -2 & 4 & -2\\5 & 3 & -3 & -2\\5 & -2 & 2 & -2\\5 & -2 & -3 & 3\end{matrix}\right]
\]

其特征值是:

\[\left \{ -2 : 1, \quad 3 : 1, \quad 5 : 2\right \}
\]

(六)对角化矩阵

1.说明:

如果要对角化一个矩阵,用diagonalize()

2.源代码:

  1. from sympy import *
  2. M = Matrix([[3, -2, 4, -2], [5, 3, -3, -2], [5, -2, 2, -2], [5, -2, -3, 3]])
  3. P, D = M.diagonalize()
  4. print('矩阵M')
  5. print(M)
  6. print('矩阵P')
  7. print(P)
  8. print('矩阵D')
  9. print(D)
  10. print("P*D*P**-1")
  11. print(P*D*P**-1)

3.输出:

\[M = \left[\begin{matrix}3 & -2 & 4 & -2\\5 & 3 & -3 & -2\\5 & -2 & 2 & -2\\5 & -2 & -3 & 3\end{matrix}\right]
\]

\[ P = \left[\begin{matrix}0 & 1 & 1 & 0\\1 & 1 & 1 & -1\\1 & 1 & 1 & 0\\1 & 1 & 0 & 1\end{matrix}\right]
\]

\[D = \left[\begin{matrix}-2 & 0 & 0 & 0\\0 & 3 & 0 & 0\\0 & 0 & 5 & 0\\0 & 0 & 0 & 5\end{matrix}\right]
\]

\(PDP^{−1}=\)

\[\left[\begin{matrix}3 & -2 & 4 & -2\\5 & 3 & -3 & -2\\5 & -2 & 2 & -2\\5 & -2 & -3 & 3\end{matrix}\right]
\]

作者:Mark

日期:2019/03/18 周一

5.6Python数据处理篇之Sympy系列(六)---矩阵的操作的更多相关文章

  1. 3.6Python数据处理篇之Numpy系列(六)---Numpy随机函数

    目录 目录 前言 (一)基础的随机函数 (二)轴的随机函数 (三)概率的随机函数 目录 前言 前一段日子学了numpy,觉得无趣,没有学完,不过后来看了看matplotlib,sympy等库时,频频用 ...

  2. 4.6Python数据处理篇之Matplotlib系列(六)---plt.hist()与plt.hist2d()直方图

    目录 目录 前言 (一)直方图 (二)双直方图 目录 前言 今天我们学习的是直方图,导入的函数是: plt.hist(x=x, bins=10) 与plt.hist2D(x=x, y=y) (一)直方 ...

  3. 5.5Python数据处理篇之Sympy系列(五)---解方程

    目录 目录 前言 (一)求解多元一次方程-solve() 1.说明: 2.源代码: 3.输出: (二)解线性方程组-linsolve() 1.说明: 2.源代码: 3.输出: (三)解非线性方程组-n ...

  4. 5.4Python数据处理篇之Sympy系列(四)---微积分

    目录 目录 前言 (一)求导数-diff() 1.一阶求导-diff() 2.多阶求导-diff() 3.求偏导数-diff() (二)求积分-integrate() (三)求极限-limit() ( ...

  5. 5.3Python数据处理篇之Sympy系列(三)---简化操作

    目录 5.3简化操作 目录 前言 (一)有理数与多项式的简化 1.最简化-simplify() 2.展开-expand() 3.提公因式-factor() 4.合并同类项-ceiling() 5.简化 ...

  6. 5.2Python数据处理篇之Sympy系列(二)---Sympy的基本操作

    目录 目录 前言 (一)符号的初始化与输出设置-symbol() symbols() latex() 1.作用: 2.操作: (二)替换符号-subs(old,new) 1.说明: 2.源代码: 3. ...

  7. 5.1Python数据处理篇之Sympy系列(一)---Sympy的大体认识

    目录 目录 前言 目录 前言 sympy是python一个强大的数学符号运算第三方库,具体的功能请看下面操作 官网教程: https://docs.sympy.org/latest/tutorial/ ...

  8. 4.3Python数据处理篇之Matplotlib系列(三)---plt.plot()折线图

    目录 前言 (一)plt.plot()函数的本质 ==1.说明== ==2.源代码== ==3.展示效果== (二)plt.plot()函数缺省x时 ==1.说明== ==2.源代码== ==3.展示 ...

  9. paper 9:SVM番外篇:支持向量机系列六:Duality —— 关于 dual 问题推导的一些补充理论。

    在之前关于 support vector 的推导中,我们提到了 dual ,这里再来补充一点相关的知识.这套理论不仅适用于 SVM 的优化问题,而是对于所有带约束的优化问题都适用的,是优化理论中的一个 ...

随机推荐

  1. scala中spark运行内存不足

    用 bash spark-submit 在spark上跑代码的时候出现错误: ERROR executor.Executor: Exception in task 9.0 in stage 416.0 ...

  2. 【Spark篇】---Spark中Transformations转换算子

    一.前述 Spark中默认有两大类算子,Transformation(转换算子),懒执行.action算子,立即执行,有一个action算子 ,就有一个job. 通俗些来说由RDD变成RDD就是Tra ...

  3. qt4升级到qt5的一些问题

    由于最近项目使用的qt版本从qt4.8升级到qt5.5,虽然从4到5的变化不大,不过还是有许多的问题需要记录一下,希望可以帮助到更多的人​ 1.由于Qt5将大部分桌面部件移到了Qt Widgets模块 ...

  4. Android中广播接收者BroadcastReceiver详解

    1. 接收系统的广播步骤 (1)  新建一个类继承BroadcastReceiver 以监听sd卡状态的广播接收者为例 public class SdCardBroadcastReceiver ext ...

  5. Netty 简介

    上文我们介绍了NIO和BIO的区别,NIO相对于BIO是一次很大的进步.但我们平时开发中并不会使用NIO.这是因为NIO在开发中存在以下问题 NIO的类库和API繁杂,使用麻烦,需要熟练掌握Selec ...

  6. python学习第一讲,python简介

    目录 python学习第一讲,python简介 一丶python简介 1.解释型语言与编译型语言 2.python的特点 3.python的优缺点 二丶第一个python程序 1.python源程序概 ...

  7. ES6躬行记(20)——类

    ES6正式将类(Class)的概念在语法层面标准化,今后不必再用构造函数模拟类的行为.而ES6引入的类本质上只是个语法糖(即代码更为简洁.语义更为清晰),其大部分功能(例如继承.封装和复用等)均可在E ...

  8. Java提高班(一)Thread详解

    一.概述 在开始学习Thread之前,我们先来了解一下 线程和进程之间的关系: 线程(Thread)是进程的一个实体,是CPU调度和分派的基本单位. 线程不能够独立执行,必须依存在应用程序中,由应用程 ...

  9. 痞子衡嵌入式:飞思卡尔i.MX RT系列MCU特性介绍(4)- RT105x选型

    大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是飞思卡尔i.MX RT系列MCU的RT105x选型. 大家都知道i.MX RT105x是i.MX RT系列第一款产品,在提这款产品特性的 ...

  10. Docker入门(一)用hello world入门docker

    初识Docker Docker是什么?   Docker 是一个开源的应用容器引擎,基于 Go 语言并遵从Apache2.0协议开源.   Docker 可以让开发者打包他们的应用以及依赖包到一个轻量 ...