python矩阵运算及多元一次方程运算的多种练习

一、python 矩阵操作

先引入 numpy ,使用 mat 函数创建一个 2×3 矩阵。

#引入numpy
import numpy as np
#使用mat函数创建一个2×3矩阵
a=np.mat([[1,2,3],[4,5,6]])
a

在这里插入图片描述
使用 shape 可以获取矩阵的大小

#使用shape可以获取矩阵的大小
a.shape

在这里插入图片描述
使用下表读取矩阵中的元素

#使用下标读取矩阵中的元素
a.T

在这里插入图片描述
进行行列转换。

#进行行列转换
a.transpose()

a.T

在这里插入图片描述
在这里插入图片描述
实际上官方文档建议我们使用二维数组代替矩阵来进行矩阵运算;因为二维数组用得较多,而且基本可取代矩阵。

#用二维数组代替矩阵
b=np.array([[1,2,3],[4,5,6]])
b

b.T

在这里插入图片描述
在这里插入图片描述

加减法也是一样的。

#加减法
a+a

b+b

在这里插入图片描述
当然列表是不能这么尽兴加减的。

#列表不能尽兴加减
c=[[1,2,3],[4,5,6]]
c+c

在这里插入图片描述

二、python 矩阵乘法

使用二维数组创建两个矩阵 A 和 B。

#使用二维数组创建两个矩阵A和B
A=np.array([[1,2,3],[4,5,6]])
B=A.T

A

B

在这里插入图片描述
在这里插入图片描述

先来一个矩阵的数乘,其实是矩阵的每一个元素乘以该数。

#矩阵每个元素乘以该数
2*A

2*B

在这里插入图片描述

在这里插入图片描述
dot 函数用于矩阵乘法,对于二维数组,它计算的是矩阵乘积,对于一维数组,它计算的是内积。

A*B

np.dot(A,B)

np.dot(B,A)

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
再创建一个二维数组

#创建一个二维数组
C=np.array([[1,2],[1,3]])
C

在这里插入图片描述
我们验证一个矩阵乘法的结合性:(AB)C=A(BC)。
在这里插入图片描述

在这里插入图片描述
接着看一下对加法的分配性:(A+B)C=AC+BC、C(A+B)=CA+CB。

#验证加法的分配性 (A+B)C=AC+BC  C(A+B)=CA+CB
D=B-1
D

np.dot(A,B+D)

np.dot(A,B)+np.dot(A,D)

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
数乘的结合性,也是一样的。

#验证数乘的结合性
2*(np.dot(A,B))

np.dot(A,2*B)

np.dot(2*A,B)

np.dot(A,2*B)

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
使用 eye 创建一个单位矩阵

#使用 eye 创建一个单位矩阵
I=np.eye(3)
I

在这里插入图片描述
一个矩阵 A 乘以一个单位矩阵,还是它本身。
在这里插入图片描述

三、python 矩阵转置

A

在这里插入图片描述
我们使用属性 T 来得到矩阵 A 的转置矩阵

A.T

在这里插入图片描述
(A’)’=A

A.T.T

在这里插入图片描述

B

D

在这里插入图片描述
在这里插入图片描述
(A±B)’=A’±B’

(B+D).T

B.T+D.T

在这里插入图片描述
在这里插入图片描述
(KA)’=KA’

10*A.T

(10*A).T

在这里插入图片描述
在这里插入图片描述
(A×B)’=B’×A’

np.dot(A.T,B.T)

np.dot(B.T,A.T)

在这里插入图片描述
在这里插入图片描述

四、python 求方阵的迹

方阵的迹就是主对角元素之和,创建一个方阵

E=np.array([[1,2,3],[4,5,6],[7,8,9]])
E

在这里插入图片描述
用 trace 计算方阵的迹

np.trace(E)

在这里插入图片描述
再创建一个方阵 F

F=E-2
F

在这里插入图片描述
验证一下方阵的迹等于方阵的转置的迹

np.trace(E)

np.trace(E.T)

在这里插入图片描述
在这里插入图片描述
验证一下方阵的和的迹等于方阵的迹的和

np.trace(E+F)

np.trace(E)+np.trace(F)

在这里插入图片描述
在这里插入图片描述

五、python 方阵的行列式计算方法

如何计算方阵的行列式,用到的是 numpy 模块的 linalg.det 方法
创建两个行列式
在这里插入图片描述

在这里插入图片描述
使用 det 方法求得方阵 E 和方阵 F 的行列式

np.linalg.det(E)

np.linalg.det(F)

在这里插入图片描述

在这里插入图片描述

C

np.linalg.det(C)

在这里插入图片描述
在这里插入图片描述

六、python 求逆矩阵 / 伴随矩阵

创建一个方阵。

A=np.array([[1,-2,1],[0,2,-1],[1,1,-2]])
A

在这里插入图片描述
使用 linalg.det 求得方阵的行列式。

A_abs=np.linalg.det(A)
A_abs

在这里插入图片描述
使用 linalg.inv 求得方阵 A 的逆矩阵

B=np.linalg.inv(A)
B

在这里插入图片描述
利用公式:
在这里插入图片描述

A_bansui=B*A_abs
A_bansui

在这里插入图片描述

七、python 解多元一次方程

将这个方程格式调整好,按照 x-y-z-常数项的顺序排列:
在这里插入图片描述
未知数的系数写下来,排列成一个矩阵 a

a=[[1,2,1],[2,-1,3],[3,1,2]]
a=np.array(a)
a

在这里插入图片描述
常数项构成一个一维数组(向量)

b=[7,7,18]
b=np.array(b)
b

在这里插入图片描述
使用linalg.solve 方法解方程,参数 a 指的是系数矩阵,参数 b 指的是常数项矩阵

x=np.linalg.solve(a,b)
x

在这里插入图片描述
使用点乘的方法可以验证一下,系数乘以未知数可以得到常数项

np.dot(a,x)

在这里插入图片描述

八、总结

通过本次联系了解了并且初步熟悉了python语言再矩阵运算和多元一次方程运算中的多种调用方法,为之后的编程打基础。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值