hessenberg#
- scipy.linalg.hessenberg(a, calc_q=False, overwrite_a=False, check_finite=True)[источник]#
Вычислить форму Хессенберга матрицы.
Разложение Хессенберга:
A = Q H Q^H
где Q является унитарной/ортогональной и H имеет только нулевые элементы ниже первой поддиагонали.
Документация написана в предположении, что аргументы-массивы имеют указанные «основные» формы. Однако аргументы-массивы этой функции могут иметь дополнительные «пакетные» измерения, добавленные перед основной формой. В этом случае массив обрабатывается как пакет низкоразмерных срезов; см. Пакетные линейные операции подробности.
- Параметры:
- a(M, M) array_like
Матрица для приведения к форме Хессенберга.
- calc_qbool, необязательно
Вычислять ли матрицу преобразования. По умолчанию False.
- overwrite_abool, необязательно
Перезаписывать ли a; может улучшить производительность. По умолчанию False.
- check_finitebool, необязательно
Проверять ли, что входная матрица содержит только конечные числа. Отключение может повысить производительность, но может привести к проблемам (сбоям, незавершению) если входные данные содержат бесконечности или NaN.
- Возвращает:
- H(M, M) ndarray
Форма Хессенберга для a.
- Q(M, M) ndarray
Унитарная/ортогональная матрица преобразования подобия
A = Q H Q^H. Возвращается только еслиcalc_q=True.
Примеры
>>> import numpy as np >>> from scipy.linalg import hessenberg >>> A = np.array([[2, 5, 8, 7], [5, 2, 2, 8], [7, 5, 6, 6], [5, 4, 4, 8]]) >>> H, Q = hessenberg(A, calc_q=True) >>> H array([[ 2. , -11.65843866, 1.42005301, 0.25349066], [ -9.94987437, 14.53535354, -5.31022304, 2.43081618], [ 0. , -1.83299243, 0.38969961, -0.51527034], [ 0. , 0. , -3.83189513, 1.07494686]]) >>> np.allclose(Q @ H @ Q.conj().T - A, np.zeros((4, 4))) True