我想在sympy中创建以下表达式:
M
,U
和A^(k)
是大小为m
的方形矩阵。
到目前为止,我设法为给定的p
执行此操作:
import sympy
m = sympy.symbols('m', integer=True)
p = 3
A = [sympy.MatrixSymbol('A^({})'.format(k), m, m) for k in range(p)]
M = sympy.MatrixSymbol('M', m, m)
U = sympy.MatrixSymbol('U', m, m)
expr = M*A[0]*U
for k in range(1, p):
expr += M*A[k]*U
expr
但是,我不想将p
设置为固定数字。相反,我希望p
成为一个符号,就像m
一样。如何在同情中实现这一目标?
答案 0 :(得分:1)
可能有更好的方法。现在,我通过将A
定义为函数而不是列表来实现我想要的目标:
m, p, k = symbols('m, p, k')
M = sympy.MatrixSymbol('M', m, m)
U = sympy.MatrixSymbol('U', m, m)
class A(sympy.Function):
@classmethod
def eval(cls, k):
return sympy.MatrixSymbol('A^({})'.format(k), m, m)
sympy.Sum(M * A(k) * U, (k, 1, p))