numpy.linalg.eigvals#
- linalg.eigvals(a)[源代码]#
计算一般矩阵的特征值.
eigvals和eig之间的主要区别:不返回特征向量.- 参数:
- a(…, M, M) 类数组
一个复值或实值矩阵,将计算其特征值.
- 返回:
- w(…, M,) ndarray
特征值,每个都根据其重数重复.对于实矩阵,它们不一定是排序的,也不一定是实数.
- 提出:
- LinAlgError
如果特征值计算不收敛.
参见
eig一般数组的特征值和右特征向量
eigvalsh实对称或复 Hermitian(共轭对称)数组的特征值.
eigh实对称或复埃尔米特(共轭对称)数组的特征值和特征向量.
scipy.linalg.eigvalsSciPy 中类似的函数.
注释
广播规则适用,详情请参阅
numpy.linalg的文档.这是使用
_geevLAPACK 例程实现的,该例程计算一般方阵的特征值和特征向量.示例
说明:利用对角矩阵的特征值为其对角线元素这一事实,将一个矩阵从左边乘以一个正交矩阵 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