numpy.linalg.inv#

linalg.inv(a)[源代码]#

计算矩阵的逆.

给定一个方阵 a,返回满足 a @ ainv = ainv @ a = eye(a.shape[0]) 的矩阵 ainv.

参数:
a(…, M, M) array_like

要被求逆的矩阵.

返回:
ainv(…, M, M) ndarray 或 matrix

矩阵 a 的逆.

引发:
LinAlgError

如果 a 不是方阵或求逆失败.

参见

scipy.linalg.inv

SciPy 中的类似功能.

numpy.linalg.cond

计算矩阵的条件数.

numpy.linalg.svd

计算矩阵的奇异值分解.

备注

在 1.8.0 版本加入.

广播规则适用,详情请参见 numpy.linalg 文档.

如果检测到 a 是奇异的,会引发 LinAlgError.如果 a 是病态的,可能会也可能不会引发 LinAlgError,并且由于浮点误差,结果可能不准确.

参考文献

[1]

Wikipedia, “条件数”, https://en.wikipedia.org/wiki/Condition_number

示例

>>> import numpy as np
>>> from numpy.linalg import inv
>>> a = np.array([[1., 2.], [3., 4.]])
>>> ainv = inv(a)
>>> np.allclose(a @ ainv, np.eye(2))
True
>>> np.allclose(ainv @ a, np.eye(2))
True

如果 a 是一个矩阵对象,那么返回值也是一个矩阵:

>>> ainv = inv(np.matrix(a))
>>> ainv
matrix([[-2. ,  1. ],
        [ 1.5, -0.5]])

可以一次计算几个矩阵的逆:

>>> a = np.array([[[1., 2.], [3., 4.]], [[1, 3], [3, 5]]])
>>> inv(a)
array([[[-2.  ,  1.  ],
        [ 1.5 , -0.5 ]],
       [[-1.25,  0.75],
        [ 0.75, -0.25]]])

如果一个矩阵接近奇异,计算的逆可能不满足 a @ ainv = ainv @ a = eye(a.shape[0]) 即使没有引发 LinAlgError:

>>> a = np.array([[2,4,6],[2,0,2],[6,8,14]])
>>> inv(a)  # No errors raised
array([[-1.12589991e+15, -5.62949953e+14,  5.62949953e+14],
   [-1.12589991e+15, -5.62949953e+14,  5.62949953e+14],
   [ 1.12589991e+15,  5.62949953e+14, -5.62949953e+14]])
>>> a @ inv(a)
array([[ 0.   , -0.5  ,  0.   ],  # may vary
       [-0.5  ,  0.625,  0.25 ],
       [ 0.   ,  0.   ,  1.   ]])

要检测病态矩阵,你可以使用 numpy.linalg.cond 来计算其 条件数 [1].条件数越大,矩阵越病态.根据经验,如果条件数 cond(a) = 10**k,那么你可能会失去多达 k 位的精度,除了由于算术方法导致的精度损失外.

>>> from numpy.linalg import cond
>>> cond(a)
np.float64(8.659885634118668e+17)  # may vary

通过直接检查矩阵的奇异值,也可以检测到病态情况.最大奇异值与最小奇异值之比是条件数:

>>> from numpy.linalg import svd
>>> sigma = svd(a, compute_uv=False)  # Do not compute singular vectors
>>> sigma.max()/sigma.min()
8.659885634118668e+17  # may vary