numpy.linalg.pinv#
- linalg.pinv(a, rcond=None, hermitian=False, *, rtol=<нет значение>)[источник]#
Вычислить (Мура-Пенроуза) псевдообратную матрицу.
Вычислить обобщённую обратную матрицу, используя её сингулярное разложение (SVD) и включая все большой сингулярные значения.
- Параметры:
- a(..., M, N) array_like
Матрица или набор матриц для псевдоинвертирования.
- rcond(…) array_like of float, optional
Порог для малых сингулярных значений. Сингулярные значения меньше или равные
rcond * largest_singular_valueустанавливаются в ноль. Выполняет трансляцию относительно стека матриц. По умолчанию:1e-15.- эрмитовbool, необязательно
Если True, a предполагается эрмитовой (симметричной, если вещественнозначная), что позволяет использовать более эффективный метод поиска сингулярных значений. По умолчанию False.
- rtol(…) array_like of float, optional
То же, что и rcond, но это совместимое с Array API имя параметра. Только rcond или rtol может быть установлено одновременно. Если ни один из них не предоставлен, то используется
1e-15используется значение по умолчанию. Еслиrtol=Noneпередан, то используется стандартный API по умолчанию.Новое в версии 2.0.0.
- Возвращает:
- B(…, N, M) ndarray
Псевдообратная матрица для a. Если a является
matrixэкземпляр, то также B.
- Вызывает:
- LinAlgError
Если вычисление SVD не сходится.
Смотрите также
scipy.linalg.pinvПохожая функция в SciPy.
scipy.linalg.pinvhВычислить (Мура-Пенроуза) псевдообратную эрмитовой матрицы.
Примечания
Псевдообратная матрица A, обозначаемая \(A^+\), определяется как: «матрица, которая 'решает' [задачу наименьших квадратов] \(Ax = b\), т.е., если \(\bar{x}\) является ли это решение, тогда \(A^+\) такая матрица, что \(\bar{x} = A^+b\).
Можно показать, что если \(Q_1 \Sigma Q_2^T = A\) является сингулярным разложением A, тогда \(A^+ = Q_2 \Sigma^+ Q_1^T\), где \(Q_{1,2}\) являются ортогональными матрицами, \(\Sigma\) является диагональной матрицей, состоящей из так называемых сингулярных значений A (за которыми, как правило, следуют нули), а затем \(\Sigma^+\) просто является диагональной матрицей, состоящей из обратных значений сингулярных чисел A (снова, за которыми следуют нули). [1]
Ссылки
[1]G. Strang, Linear Algebra and Its Applications, 2-е изд., Орландо, Флорида, Academic Press, Inc., 1980, стр. 139-142.
Примеры
Следующий пример проверяет, что
a * a+ * a == aиa+ * a * a+ == a+:>>> import numpy as np >>> rng = np.random.default_rng() >>> a = rng.normal(size=(9, 6)) >>> B = np.linalg.pinv(a) >>> np.allclose(a, np.dot(a, np.dot(B, a))) True >>> np.allclose(B, np.dot(B, np.dot(a, B))) True