python进行矩阵计算可以用两个模块:
numpy
和
sympy
1、Numpy
创建矩阵:
from numpy import *
a1=array([1,2,3]) #数组
a2=mat([1,2,3]) #矩阵
a3=mat(a1)
b=matrix([1,2,3]) #matrix是矩阵的意思
print(a1)
print(a2)
print(a3)
print(shape(a1),shape(a2),shape(a3))
print(shape(b)) #shape——打印矩阵的行列数
结果:
[1 2 3]
[[1 2 3]]
[[1 2 3]]
(3,) (1, 3) (1, 3)
(1, 3)
from numpy import *
data1=mat(zeros((3,3))) #创建一个3*3的零矩阵,矩阵这里zeros函数的参数是一个tuple类型(3,3)
print(data1)
data2=mat(ones((2,4))) #创建一个2*4的1矩阵,默认是浮点型的数据,如果需要时int类型,可以使用dtype=int
print(data2)
data3=mat(random.rand(2,2)) #这里的random模块使用的是numpy中的random模块,random.rand(2,2)创建的是一个二维数组,需要将其转换成#matrix
print(data3)
data4=mat(random.randint(10,size=(3,3))) #生成一个3*3的0-10之间的随机整数矩阵,如果需要指定下界则可以多加一个参数
print(data4)
data5=mat(random.randint(2,8,size=(2,5))) #产生一个2-8之间的随机整数矩阵
print(data5)
data6=mat(eye(2,2,dtype=int)) #产生一个2*2的对角矩阵,其实是单位阵
print(data6)
data7=mat(diag([1,2,3])) #生成一个对角线为1、2、3的对角矩阵
print(data7)
结果:
[[0. 0. 0.]
[0. 0. 0.]
[0. 0. 0.]]
[[1. 1. 1. 1.]
[1. 1. 1. 1.]]
[[0.89395956 0.8750971 ]
[0.86046462 0.998561 ]]
[[1 3 2]
[1 4 6]
[1 4 5]]
[[4 5 7 7 7]
[4 2 6 2 4]]
[[1 0]
[0 1]]
[[1 0 0]
[0 2 0]
[0 0 3]]
操作矩阵之前需要引入numpy的linalg模块
numpy.linalg模块包含线性代数的函数。使用这个模块,可以计算逆矩阵、求特征值、解线性方程组以及求解行列式等</