【Python】Numpy--np.linalg.eig()求对称矩阵的特征值和特征向量
创始人
2024-05-27 08:52:26
0

【Python】Numpy–np.linalg.eig()求对称矩阵的特征值和特征向量

文章目录

  • 【Python】Numpy--np.linalg.eig()求对称矩阵的特征值和特征向量
    • 1. 介绍
    • 2. API
    • 3. 代码示例

1. 介绍

特征分解(Eigendecomposition),又称谱分解(Spectral decomposition)是将矩阵分解为由其特征值和特征向量表示的矩阵之积的方法。

  • 需要注意:只有对可对角化矩阵才可以施以特征分解。
  • 当方阵的行列式不为0时,它才可以特征分解。
  • 对称矩阵的行列式不为0。故实对称矩阵 A 可被分解成:
    A=QΛQTA = QΛ Q^T A=QΛQTΛ是特征值构成的对角矩阵,Q为特征向量构成的矩阵(每列为一个特征向量)。

2. API

Numpy提供了丰富的API:

  • 求矩阵的特征值和特征向量;
  • 求矩阵的行列式
  • 求方阵的逆
import numpy as np
# 计算特征值和特征向量
x, V = np.linalg.eig(A)# 计算矩阵的行列式
det = np.linalg.det(A)# 计算方阵的逆
A_inv = np.linalg.inv(A)

3. 代码示例

import numpy as npA = np.array([[0, 1, 2, 3],[1, 0, 3, 1],[2, 3, 0, 2],[3, 1, 2, 0]])x, V = np.linalg.eig(A)V_inv = np.linalg.inv(V)print('A的行列式', np.linalg.det(A))# 注意这里:且不可使用‘*’做乘法(因为*优先使用点乘,点乘不成立,才会进行矩阵乘法)
B = np.matmul(np.matmul(V, np.diag(x)), (V_inv))print('特征值x: \n', x)print('特征向量V: \n', V)print('V_T: \n', V.T)print('V_inv: \n', V_inv)print('B: \n', B)-----------------------------输出-----------------------------------
A的行列式 9.000000000000009
特征值x:[ 6.05572176  0.15432761 -3.         -3.21004937]
特征向量V:[[-5.03020107e-01 -4.75446017e-01 -7.07106781e-01 -1.44643895e-01][-4.38300211e-01  6.51958757e-01 -2.36695808e-17 -6.18742842e-01][-5.49394638e-01  3.50502424e-01 -1.50578103e-16  7.58494287e-01][-5.03020107e-01 -4.75446017e-01  7.07106781e-01 -1.44643895e-01]]
V_T:[[-5.03020107e-01 -4.38300211e-01 -5.49394638e-01 -5.03020107e-01][-4.75446017e-01  6.51958757e-01  3.50502424e-01 -4.75446017e-01][-7.07106781e-01 -2.36695808e-17 -1.50578103e-16  7.07106781e-01][-1.44643895e-01 -6.18742842e-01  7.58494287e-01 -1.44643895e-01]]
V_inv:[[-5.03020107e-01 -4.38300211e-01 -5.49394638e-01 -5.03020107e-01][-4.75446017e-01  6.51958757e-01  3.50502424e-01 -4.75446017e-01][-7.07106781e-01 -8.99464510e-16  8.86986655e-16  7.07106781e-01][-1.44643895e-01 -6.18742842e-01  7.58494287e-01 -1.44643895e-01]]
B:
[[ 1.71102595e-15  1.00000000e+00  2.00000000e+00  3.00000000e+00][ 1.00000000e+00  9.30160211e-16  3.00000000e+00  1.00000000e+00][ 2.00000000e+00  3.00000000e+00 -2.20312258e-16  2.00000000e+00][ 3.00000000e+00  1.00000000e+00  2.00000000e+00  1.88043220e-15]]

相关内容

热门资讯

中证A500ETF摩根(560... 8月22日,截止午间收盘,中证A500ETF摩根(560530)涨1.19%,报1.106元,成交额...
A500ETF易方达(1593... 8月22日,截止午间收盘,A500ETF易方达(159361)涨1.28%,报1.104元,成交额1...
何小鹏斥资约2.5亿港元增持小... 每经记者|孙磊    每经编辑|裴健如 8月21日晚间,小鹏汽车发布公告称,公司联...
中证500ETF基金(1593... 8月22日,截止午间收盘,中证500ETF基金(159337)涨0.94%,报1.509元,成交额2...
中证A500ETF华安(159... 8月22日,截止午间收盘,中证A500ETF华安(159359)涨1.15%,报1.139元,成交额...
科创AIETF(588790)... 8月22日,截止午间收盘,科创AIETF(588790)涨4.83%,报0.760元,成交额6.98...
创业板50ETF嘉实(1593... 8月22日,截止午间收盘,创业板50ETF嘉实(159373)涨2.61%,报1.296元,成交额1...
港股异动丨航空股大幅走低 中国... 港股航空股大幅下跌,其中,中国国航跌近7%表现最弱,中国东方航空跌近5%,中国南方航空跌超3%,美兰...
电网设备ETF(159326)... 8月22日,截止午间收盘,电网设备ETF(159326)跌0.25%,报1.198元,成交额409....
红利ETF国企(530880)... 8月22日,截止午间收盘,红利ETF国企(530880)跌0.67%,报1.034元,成交额29.0...