python - 在 SymPy 中从分块矩阵构建矩阵

标签 python matrix sympy

我想要一个像这样的矩阵:

import sympy as sp
sp.Matrix([[1,0,2,0],[0,1,0,2],[1,0,2,0],[0,1,0,2]])
# output
#⎡1  0  2  0⎤
#⎢          ⎥
#⎢0  1  0  2⎥
#⎢          ⎥
#⎢1  0  2  0⎥
#⎢          ⎥
#⎣0  1  0  2⎦

我想从 block 矩阵构造一个新矩阵:

s=sp.eye(2)
sp.Matrix([[s,2*s],[s,2*s]])
# output:
#⎡⎡1  0⎤  ⎡2  0⎤⎤
#⎢⎢    ⎥  ⎢    ⎥⎥
#⎢⎣0  1⎦  ⎣0  2⎦⎥
#⎢              ⎥
#⎢⎡1  0⎤  ⎡2  0⎤⎥
#⎢⎢    ⎥  ⎢    ⎥⎥
#⎣⎣0  1⎦  ⎣0  2⎦⎦

输出内部有额外的括号。

一种解决方案是通过 sympy.functions.transpose 方法:

from sympy.functions import transpose
sp.Matrix([transpose(sp.Matrix([s*i for i in range(1,3)])) for j in range(1,3)])
# output 
#⎡1  0  2  0⎤
#⎢          ⎥
#⎢0  1  0  2⎥
#⎢          ⎥
#⎢1  0  2  0⎥
#⎢          ⎥
#⎣0  1  0  2⎦

这个解决方案相当乏味。我想知道是否有更好的解决方案?

简而言之,sp.Matrix 方法似乎可以组合矩阵,只要它们位于一维列表中。

最佳答案

使用 TensorProduct :

>>> from sympy import *
>>> from sympy.physics.quantum import TensorProduct
>>> A = ones(2,1) * Matrix([1,2]).T
>>> A
Matrix([
[1, 2],
[1, 2]])
>>> TensorProduct(A, eye(2))
Matrix([
[1, 0, 2, 0],
[0, 1, 0, 2],
[1, 0, 2, 0],
[0, 1, 0, 2]])

使用 BlockMatrix :

>>> from sympy import *
>>> BlockMatrix([[eye(2), 2*eye(2)],[eye(2), 2*eye(2)]])
Matrix([
[Matrix([
[1, 0],
[0, 1]]), Matrix([
[2, 0],
[0, 2]])],
[Matrix([
[1, 0],
[0, 1]]), Matrix([
[2, 0],
[0, 2]])]])
>>> Matrix(BlockMatrix([[eye(2), 2*eye(2)],[eye(2), 2*eye(2)]]))
Matrix([
[1, 0, 2, 0],
[0, 1, 0, 2],
[1, 0, 2, 0],
[0, 1, 0, 2]])

关于python - 在 SymPy 中从分块矩阵构建矩阵,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50606675/

相关文章:

opengl - 如何反转3D look_at函数?

R:成对比较矩阵中的所有列

python - 傅立叶变换 Sympy 中的三角函数返回意外结果

python - `S` 在 sympy 中表示什么

python - Python 版本行是什么意思?

python - 尝试将 session 从模型保存传递到 View 中

python - Flask + Flask_SocketIO = 运行时错误 : Working outside of request context

python - 将列表中的每个元素与另一个列表中相应的索引进行比较

matlab - 如何在 Matlab 中查找矩阵是否为奇异矩阵

python - 积分内部总和给出索引标签错误