首页 > 解决方案 > 在 sympy 中求解多项式矩阵方程组

问题描述

我想使用 sympy 来求解满足一组二次和线性方程的向量,例如x.T @ A @ x = x.T @ B @ x = 1x.T @ C = 0。这是我的尝试:

import numpy as np
from sympy.polys.polymatrix import PolyMatrix
from sympy import symbols
from sympy.solvers import solve_poly_system

x = PolyMatrix([symbols(f'x{k}') for k in range(2)])
A = np.eye(2)
B = np.array([1, 0]).reshape([2, 1])
one = PolyMatrix([1])

solve_poly_system([x.T @ A @ x - one, x.T @ B], [symbols(f'x{k}') for k in range(2)])

但是,这会产生以下错误:

PolynomialError: non-commutative expressions are not supported

有什么建议么?

标签: sympy

解决方案


只需使用solve而不是solve_poly_system

>>> solve([x.T @ A @ x - one, x.T @ B], [symbols(f'x{k}') for k in range(2)])
[(0.0, -1.0), (0.0, 1.0)]

推荐阅读