我正在尝试使用numpy的linalg.eig()函数来获得特征向量和特征值。
import numpy as np
M = np.array([[168.04570515, 1.38100609, -48.60662242],
[1.38100609, 16.49647382, 9.18370965],
[-48.60662242, 9.18370965, 38.37842496]])
eigenvalue, eigenvector = np.linalg.eig(M)
>>>eigenvalue
array([184.25812834, 28.91371368, 9.74876191])
>>>eigenvector
array([[-0.94849917, -0.26039343, -0.18040119],
[ 0.0095255 , -0.59267178, 0.80538775],
[ 0.31663637, -0.7621912 , -0.56462906]])但是,当我在WolframAlpha中输入相同的M值时,我得到以下结果:

为什么我会得到不同的特征向量?
发布于 2020-01-15 02:31:08
所以你实际上得到了相同的特征向量。只是Wolfram Alpha缩放了特征向量,所以最后一个元素是1(如果你还记得,特征向量是尺度不变的)。让我们看一下结果的第一列。如果你跑了,
np.array([-0.94849917, 0.0095255, 0.31663637])/0.31663637你会得到
array([-2.99554713, 0.0300834 , 1. ])如果你注意到了这就是Wolfram Alpha所报道的。您也可以检查其他两个。
https://stackoverflow.com/questions/59739537
复制相似问题