SageMath矩阵操作及解线性方程组

矩阵所处环的表示

  • ZZ:整数环
  • QQ:有理数环
  • Zmod(p):p为素数,定义在 Z P Z_P ZP

矩阵操作

声明

超完整定义

mt = matrix(QQ, 3, 2, [1, 2, 3, 4, 5, 6])

完整定义

mt = matrix(ZZ, 3, 4) #定义一个在整数环上的3行4列的矩阵
mt = matrix(ZZ, 0, 4) #定义一个在整数环上0行4列的矩阵,后期可动态添加行

部分定义

mt = matrix(QQ, 3, [1, 2, 3, 4, 5, 6]) #定义在有理数环上的3列矩阵,并赋值

添加行

在末尾添加

mt = mt.stack(vector([1, 2, 3]) #矩阵后添加一行

在指定行插入一行,第一个参数为行号,第二个为元素list

mt = mt.insert_row(1, vector([1, 2, 3])) #在第一行插入

修改元素值

注意,矩阵行列均从0开始!
修改单个值

mt[2, 3] = 8 #将第3行第4列的值修改为8

修改整行值

mt[2] = [1, 2, 3, 4] #将第3行的值依次修改为list中的值

求秩

mt.rank()

求行、列值

mt.nrows() #将返回矩阵行数
mt.ncols() #将返回矩阵列数

求行列式的值

mt.determinant()

求是否为可逆矩阵

是可逆矩阵则输出TRUE,否则输出FALSE

mt.is_invertible()

求逆

两种方法

mt.inverse()
mt = mt^(-1)

改变矩阵所处环

mt.change_ring(ZZ) ##将矩阵的环改为ZZ

求解线性方程组和线性相关组

求矩阵X满足XA=B

X = A.solve_left(B)

求矩阵X满足AX=B

X = A.solve_right(B)

求向量x满足Ax=b

两种方法

x = A \ b
x = A.solve_right(b)

找线性相关的行向量

满足XA=0

X = A.left_kernel()

满足AX=0

X = A.right_kernel()

找X中指定行向量

X.gen(0) #解X中的第1行

求最短正交基

LLL格基约简算法

mt.LLL()

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

D-A-X

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值