scipy.linalg.
solve_continuous_lyapunov#
- scipy.linalg.solve_continuous_lyapunov(a, q)[源代码]#
求解连续李雅普诺夫方程 \(AX + XA^H = Q\)。
使用 Bartels-Stewart 算法找到 \(X\)。
- 参数:
- aarray_like
一个方阵
- qarray_like
右侧的方阵
- 返回:
- xndarray
连续李雅普诺夫方程的解
参见
solve_discrete_lyapunov
计算离散时间李雅普诺夫方程的解
solve_sylvester
计算西尔维斯特方程的解
注释
连续李雅普诺夫方程是西尔维斯特方程的一种特殊形式,因此该求解器依赖于 LAPACK 例程 ?TRSYL。
在版本 0.11.0 中添加。
示例
给定 a 和 q,求解 x
>>> import numpy as np >>> from scipy import linalg >>> a = np.array([[-3, -2, 0], [-1, -1, 0], [0, -5, -1]]) >>> b = np.array([2, 4, -1]) >>> q = np.eye(3) >>> x = linalg.solve_continuous_lyapunov(a, q) >>> x array([[ -0.75 , 0.875 , -3.75 ], [ 0.875 , -1.375 , 5.3125], [ -3.75 , 5.3125, -27.0625]]) >>> np.allclose(a.dot(x) + x.dot(a.T), q) True