scipy.linalg.
expm_frechet#
- scipy.linalg.expm_frechet(A, E, method=None, compute_expm=True, check_finite=True)[源代码][源代码]#
矩阵指数 A 在方向 E 上的 Frechet 导数。
- 参数:
- A(N, N) array_like
要取矩阵指数的矩阵。
- E(N, N) array_like
要取Frechet导数的矩阵方向。
- 方法str, 可选
算法选择。应为以下之一
SPS (默认)
blockEnlarge
- compute_expmbool, 可选
是否也要计算 expm_A 除了 expm_frechet_AE。默认是 True。
- check_finitebool, 可选
是否检查输入矩阵是否仅包含有限数值。禁用可能会提高性能,但如果输入包含无穷大或NaN,可能会导致问题(崩溃、非终止)。
- 返回:
- expm_Andarray
A 的矩阵指数。
- expm_frechet_AEndarray
矩阵指数 A 在方向 E 上的 Frechet 导数。
- 对于
compute_expm = False
,仅返回 expm_frechet_AE。
参见
expm
计算矩阵的指数。
注释
本节描述了可通过 method 参数选择的可用实现。默认方法是 SPS。
方法 blockEnlarge 是一个简单的算法。
方法 SPS 是 Scaling-Pade-Squaring [1]。它是一个复杂的实现,所需时间大约只有朴素实现的 3/8。渐近性相同。
Added in version 0.13.0.
参考文献
[1]Awad H. Al-Mohy 和 Nicholas J. Higham (2009) 计算矩阵指数的 Frechet 导数,及其在条件数估计中的应用。SIAM 矩阵分析与应用杂志,30 (4)。第 1639-1657 页。ISSN 1095-7162
示例
>>> import numpy as np >>> from scipy import linalg >>> rng = np.random.default_rng()
>>> A = rng.standard_normal((3, 3)) >>> E = rng.standard_normal((3, 3)) >>> expm_A, expm_frechet_AE = linalg.expm_frechet(A, E) >>> expm_A.shape, expm_frechet_AE.shape ((3, 3), (3, 3))
创建一个包含 [[A, E], [0, A]] 的 6x6 矩阵:
>>> M = np.zeros((6, 6)) >>> M[:3, :3] = A >>> M[:3, 3:] = E >>> M[3:, 3:] = A
>>> expm_M = linalg.expm(M) >>> np.allclose(expm_A, expm_M[:3, :3]) True >>> np.allclose(expm_frechet_AE, expm_M[:3, 3:]) True