numpy.linalg.inv#
- linalg.inv(a)[источник]#
Вычислить обратную матрицу.
Для квадратной матрицы a, вернуть матрицу ainv удовлетворяющий
a @ ainv = ainv @ a = eye(a.shape[0]).- Параметры:
- a(…, M, M) array_like
Матрица для обращения.
- Возвращает:
- ainv(…, M, M) ndarray или matrix
Обратная матрица a.
- Вызывает:
- LinAlgError
Если a не является квадратной или инверсия не удалась.
Смотрите также
scipy.linalg.invПохожая функция в SciPy.
numpy.linalg.condВычислить число обусловленности матрицы.
numpy.linalg.svdВычислить сингулярное разложение матрицы.
Примечания
Применяются правила трансляции, см.
numpy.linalgдокументации для подробностей.Если a обнаружена как вырожденная, выдается
LinAlgErrorвызывается. Если a является плохо обусловленной,LinAlgErrorможет быть или не быть вызвано, и результаты могут быть неточными из-за ошибок с плавающей запятой.Ссылки
[1]Википедия, «Число обусловленности», 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