簡體   English   中英

從 SymPy 中的塊矩陣構建矩陣

[英]Build matrices from block matrices in 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⎦

我想從塊矩陣構造一個新矩陣:

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]])

您還可以使用hstackvstack函數:

A = eye(2)
B = 2 * eye(2)
Matrix.vstack(
    Matrix.hstack(A, B),
    Matrix.hstack(A, B)
)

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM