scipy.linalg.
null_space#
- scipy.linalg.null_space(A, rcond=None, *, overwrite_a=False, check_finite=True, lapack_driver='gesdd')[源代码]#
使用SVD构造 A 的零空间的标准正交基
- 参数:
- A(M, N) 类数组
输入数组
- rcond浮点数,可选
相对条件数。奇异值
s
小于rcond * max(s)
的被视为零。默认值:浮点数 eps * max(M,N)。- overwrite_a布尔值,可选
是否覆盖 a;可以提高性能。默认值为 False。
- check_finite布尔值,可选
是否检查输入矩阵是否仅包含有限数字。禁用可以提高性能,但如果输入确实包含无穷大或 NaN,可能会导致问题(崩溃、非终止)。
- lapack_driver{‘gesdd’, ‘gesvd’}, 可选
是否使用更高效的分治方法 (
'gesdd'
) 或通用矩形方法 ('gesvd'
) 来计算 SVD。 MATLAB 和 Octave 使用'gesvd'
方法。默认值为'gesdd'
。
- 返回:
- Z(N, K) ndarray
A 的零空间的标准正交基。K = 由 rcond 确定的有效零空间的维度
示例
一维零空间
>>> import numpy as np >>> from scipy.linalg import null_space >>> A = np.array([[1, 1], [1, 1]]) >>> ns = null_space(A) >>> ns * np.copysign(1, ns[0,0]) # Remove the sign ambiguity of the vector array([[ 0.70710678], [-0.70710678]])
二维零空间
>>> from numpy.random import default_rng >>> rng = default_rng() >>> B = rng.random((3, 5)) >>> Z = null_space(B) >>> Z.shape (5, 2) >>> np.allclose(B.dot(Z), 0) True
基向量是标准正交的(直到舍入误差)
>>> Z.T.dot(Z) array([[ 1.00000000e+00, 6.92087741e-17], [ 6.92087741e-17, 1.00000000e+00]])