numpy.linalg.eigvals#
- linalg.eigvals(a)[источник]#
Вычислить собственные значения общей матрицы.
Основное различие между
eigvalsиeig: собственные векторы не возвращаются.- Параметры:
- a(…, M, M) array_like
Комплексная или вещественная матрица, собственные значения которой будут вычислены.
- Возвращает:
- w(…, M,) ndarray
Собственные значения, каждое повторённое в соответствии с его кратностью. Они не обязательно упорядочены и не обязательно вещественны для вещественных матриц.
- Вызывает:
- LinAlgError
Если вычисление собственных значений не сходится.
Смотрите также
eigсобственные значения и правые собственные векторы общих массивов
eigvalshсобственные значения вещественных симметричных или комплексных эрмитовых (сопряжённо-симметричных) массивов.
eighсобственные значения и собственные векторы вещественных симметричных или комплексных эрмитовых (сопряжённо-симметричных) массивов.
scipy.linalg.eigvalsПохожая функция в SciPy.
Примечания
Применяются правила трансляции, см.
numpy.linalgдокументации для подробностей.Это реализовано с использованием
_geevПодпрограммы LAPACK, которые вычисляют собственные значения и собственные векторы общих квадратных массивов.Примеры
Иллюстрация, используя тот факт, что собственные значения диагональной матрицы являются ее диагональными элементами, что умножение матрицы слева на ортогональную матрицу, Q, и справа на Q.T (транспонирование матрицы Q), сохраняет собственные значения "средней" матрицы. Другими словами, если Q ортогональна, тогда
Q * A * Q.Tимеет те же собственные значения, что иA:>>> import numpy as np >>> from numpy import linalg as LA >>> x = np.random.random() >>> Q = np.array([[np.cos(x), -np.sin(x)], [np.sin(x), np.cos(x)]]) >>> LA.norm(Q[0, :]), LA.norm(Q[1, :]), np.dot(Q[0, :],Q[1, :]) (1.0, 1.0, 0.0)
Теперь умножьте диагональную матрицу на
Qс одной стороны и наQ.Tс другой стороны:>>> D = np.diag((-1,1)) >>> LA.eigvals(D) array([-1., 1.]) >>> A = np.dot(Q, D) >>> A = np.dot(A, Q.T) >>> LA.eigvals(A) array([ 1., -1.]) # random