scipy.linalg.
svdvals#
- scipy.linalg.svdvals(a, overwrite_a=False, check_finite=True)[源代码]#
计算矩阵的奇异值。
- 参数:
- a(M, N) array_like
分解的矩阵。
- overwrite_a布尔值,可选
是否覆盖 a;可能会提高性能。默认值为 False。
- check_finite布尔值,可选
是否检查输入矩阵是否仅包含有限个数字。禁用可能会有所提速,但如果输入确实包含无穷大或 NaN,则可能会导致问题(崩溃、无法终止)。
- 返回:
- s(min(M, N),) ndarray
奇异值,按降序排列。
- 引发:
- LinAlgError
如果 SVD 计算不收敛。
示例
>>> import numpy as np >>> from scipy.linalg import svdvals >>> m = np.array([[1.0, 0.0], ... [2.0, 3.0], ... [1.0, 1.0], ... [0.0, 2.0], ... [1.0, 0.0]]) >>> svdvals(m) array([ 4.28091555, 1.63516424])
我们可以通过计算 m 的所有单位向量 (x,y) 平面中的 m.dot(u) 的最大长度来验证 m 的最大奇异值。我们使用大量的样本逼近“所有”单位向量。由于线性,我们只需要角度在 [0, pi] 之间的单位向量。
>>> t = np.linspace(0, np.pi, 2000) >>> u = np.array([np.cos(t), np.sin(t)]) >>> np.linalg.norm(m.dot(u), axis=0).max() 4.2809152422538475
p 是秩为 1 的投影矩阵。通过精确计算,其奇异值为 [1, 0, 0, 0]。
>>> v = np.array([0.1, 0.3, 0.9, 0.3]) >>> p = np.outer(v, v) >>> svdvals(p) array([ 1.00000000e+00, 2.02021698e-17, 1.56692500e-17, 8.15115104e-34])
正交矩阵的所有奇异值为 1。在这里,我们可以使用
scipy.stats.ortho_group
的 rvs() 方法创建一个随机正交矩阵。>>> from scipy.stats import ortho_group >>> orth = ortho_group.rvs(4) >>> svdvals(orth) array([ 1., 1., 1., 1.])