python作为编程中较为简单的编程方法,是可以实现线性计算的,
numpy库提供了矩阵运算,可以实现求取矩阵特征向量,
scipy也可以实现
numpy库提供的矩阵运算功能,是对
numpy库提供矩阵运算的扩展,本文介绍python中计算矩阵特征向量的两种方法:1、
使用numpy.linalg.eig(a)函数;2、
使用scipy.linalg.eig()计算方阵的特征向量(
numpy方法的拓展
)。
一、使用numpy.linalg.eig(a)函数
参数:
a:想要计算奇异值和右奇异值的方阵。
返回值:
w:特征值。每个特征值根据其多重性重复。除非虚部为0,否则该数组将是复数类型。当传入的参数a为实数时,得到的特征值为实数。
v:特征向量。
使用实例
>>> from numpy import linalg as LA
>>> a = np.array([[1, 1j], [-1j, 1]])
>>> w, v = LA.eig(a)
>>> w; v
array([ 2.00000000e+00+0.j, 5.98651912e-36+0.j]) # i.e., {2, 0}
array([[ 0.00000000+0.70710678j, 0.70710678+0.j ],
[ 0.70710678+0.j , 0.00000000+0.70710678j]])
>>> a = np.array([[1 + 1e-9, 0], [0, 1 - 1e-9]])
>>> # Theor. e-values are 1 +/- 1e-9
>>> w, v = LA.eig(a)
>>> w; v
array([ 1., 1.])
array([[ 1., 0.],
[ 0., 1.]])
二、使用scipy.linalg.eig()计算方阵的特征向量(
numpy方法的拓展
)
1、语法格式
print('Eig:',lg.eig(arr)) #求矩阵arr的特征向量
2、使用实例
#coding:utf-8
from __future__ import division
from scipy import linalg as la
from scipy import optimize
import sympy
import numpy as np
sympy.init_printing()
import matplotlib.pyplot as plt
# 使用scipy求解矩阵特征值
A = np.array([[1, 3, 5], [3, 5, 3], [5, 3, 9]])
evals, evecs = la.eig(A)
eigvalues = la.eigvalsh(A)
以上就是python中计算矩阵特征向量的两种方法,希望对你有帮助~
本文为原创文章,版权归知行编程网所有,欢迎分享本文,转载请保留出处!
你可能也喜欢
- ♥ c和python有什么区别08/17
- ♥ 如何在python中编写代码09/29
- ♥ python是免费语言吗?09/22
- ♥ python参数中默认值的强制执行01/10
- ♥ python标准库是什么意思09/22
- ♥ python函数的两个参数比较10/23
内容反馈