草庐IT

Python求矩阵的特征值和广义特征值

微小冷 2024-04-29 原文

文章目录

简介

对于矩阵 A A A而言, A x = λ x Ax=\lambda x Ax=λx成立,则 λ \lambda λ A A A的一个特征值, x x x为其对应的特征向量。

scipy.linalg中,提供了8个特征值函数,名字中带有vals的函数,用于特征值;不带有vals的,既求解特征值,也求解特征向量,列表如下:

适用情况
eigeigvals方阵
eigheigvalsh厄米矩阵
eig_bandedeigvals_banded厄米带状矩阵
eigh_tridiagonaleigvalsh_tridiagonal对称三对角矩阵

下面以eigeigvals为例,首先,新建一个随机矩阵

import scipy.linalg as sl
import numpy as np
A = np.random.rand(3,3)

然后求解

>>> sl.eig(A)
(array([2.16638067+0.j, 0.6904848 +0.j, 0.01668197+0.j]), array([[-0.39800769, -0.70823117, -0.26519409],
       [-0.57654765,  0.69476372, -0.54787827],
       [-0.71357038,  0.12534748,  0.7934113 ]]))
>>> sl.eigvals(A)
array([2.16638067+0.j, 0.6904848 +0.j, 0.01668197+0.j])

可见,eigvals返回的是三个特征值;eig则在三个特征值之外,还返回了三个特征向量。

广义特征值

对于矩阵 A A A而言,若 A x = λ B x Ax=\lambda Bx Ax=λBx成立,则 λ \lambda λ A A A关于 B B B的一个特征值, x x x为其对应的特征向量。所以,特征值,就是 B B B为单位矩阵情况下的广义特征值。而当 B B B正定时,广义特征值问题可退化为特征值问题 B − 1 A x = λ x B^{-1}Ax=\lambda x B1Ax=λx

scipy.linalg所提供的特征值求解函数中,用参数b表示广义特征值中的 B B B矩阵。下面仍以eig为例,做下示范

B = np.random.rand(3,3)
e,v = sl.eig(A,B)
A@v[:,0]
# array([-0.72856533, -0.05542475, -0.47954844])
e[0]*B@v[:,0]
# array([-0.72856533+0.j, -0.05542475+0.j, -0.47954844+0.j])

可见 A x = λ B x Ax=\lambda Bx Ax=λBx

参数

这8个特征向量求解器中,前四个参数比较相近,其主要参数形式均为eig(a, b=None),其中a为待求矩阵;b为矩阵时求广义特征值。

默认check_finite=True,即求解之前检查有限情况;且通过设置overwrite_aoverwrite_bTrue,可以在处理过程中覆盖ab,以获取更快的速度。

eig, eigvals中,提供参数homogeneous_eigvals,为True时返回齐次坐标结果。eig可设置leftrightTrueFalse,以求解左特征向量或右特征向量,默认为右。

eigh, eigvalsh主要用于求解厄米矩阵,即对称共轭矩阵,除了上面提到的a, b, check_finite, overwrite_xx之外,还有下列参数

  • lower 默认为True, 表示在计算时适用下三角,否则使用上三角。
  • type 可选1, 2, 3,分别对应下面三种情况
    1. a @ v = w @ b @ v
    2. a @ b @v = w @ b @ v
    3. b @ a @v = w @ v
  • driver 可指定LAPACK中的求解器,对于某些求解器,需要设置subset_by_indexsubset_by_value参数。由于内容太多,所以不再赘述。

后面四个函数感觉用的并不多,所以就不介绍了。

有关Python求矩阵的特征值和广义特征值的更多相关文章

  1. python - 如何使用 Ruby 或 Python 创建一系列高音调和低音调的蜂鸣声? - 2

    关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。

  2. ruby - 如何根据特征实现 FactoryGirl 的条件行为 - 2

    我有一个用户工厂。我希望默认情况下确认用户。但是鉴于unconfirmed特征,我不希望它们被确认。虽然我有一个基于实现细节而不是抽象的工作实现,但我想知道如何正确地做到这一点。factory:userdoafter(:create)do|user,evaluator|#unwantedimplementationdetailshereunlessFactoryGirl.factories[:user].defined_traits.map(&:name).include?(:unconfirmed)user.confirm!endendtrait:unconfirmeddoenden

  3. Python 相当于 Perl/Ruby ||= - 2

    这个问题在这里已经有了答案:关闭10年前。PossibleDuplicate:Pythonconditionalassignmentoperator对于这样一个简单的问题表示歉意,但是谷歌搜索||=并不是很有帮助;)Python中是否有与Ruby和Perl中的||=语句等效的语句?例如:foo="hey"foo||="what"#assignfooifit'sundefined#fooisstill"hey"bar||="yeah"#baris"yeah"另外,类似这样的东西的通用术语是什么?条件分配是我的第一个猜测,但Wikipediapage跟我想的不太一样。

  4. java - 什么相当于 ruby​​ 的 rack 或 python 的 Java wsgi? - 2

    什么是ruby​​的rack或python的Java的wsgi?还有一个路由库。 最佳答案 来自Python标准PEP333:Bycontrast,althoughJavahasjustasmanywebapplicationframeworksavailable,Java's"servlet"APImakesitpossibleforapplicationswrittenwithanyJavawebapplicationframeworktoruninanywebserverthatsupportstheservletAPI.ht

  5. 旋转矩阵的几何意义 - 2

    点向量坐标矩阵的几何意义介绍旋转矩阵的几何含义之前,先介绍一下点向量坐标矩阵的几何含义点:在一维空间下就是一个标量,如同一条直线上,以任意某一个位置为0点,以一定的尺度间隔为1,2,3...,相反方向为-1,-2,-3...;如此就形成了一维坐标系,这时候任何一个点都可以用一个数值表示,如点p1=5,即即从原点出发沿着x轴正方向移动5个尺度;点p2=-3,负方向移动3个尺度;     在一维坐标系上过原点做垂直于一维坐标系的直线,则形成了二维坐标系,此时描述一个点需要两个数值来表示点p3=(3,2),即从原点出发沿着x轴正方向移动3个尺度,在此基础上沿着y轴正方向移动两个尺度的位置就是点p3。

  6. 华为OD机试用Python实现 -【明明的随机数】 2023Q1A - 2

    华为OD机试题本篇题目:明明的随机数题目输入描述输出描述:示例1输入输出说明代码编写思路最近更新的博客华为od2023|什么是华为od,od薪资待遇,od机试题清单华为OD机试真题大全,用Python解华为机试题|机试宝典【华为OD机试】全流程解析+经验分享,题型分享,防作弊指南华为o

  7. python - 如何读取 MIDI 文件、更改其乐器并将其写回? - 2

    我想解析一个已经存在的.mid文件,改变它的乐器,例如从“acousticgrandpiano”到“violin”,然后将它保存回去或作为另一个.mid文件。根据我在文档中看到的内容,该乐器通过program_change或patch_change指令进行了更改,但我找不到任何在已经存在的MIDI文件中执行此操作的库.他们似乎都只支持从头开始创建的MIDI文件。 最佳答案 MIDIpackage会为您完成此操作,但具体方法取决于midi文件的原始内容。一个MIDI文件由一个或多个音轨组成,每个音轨是十六个channel中任何一个上的

  8. 「Python|Selenium|场景案例」如何定位iframe中的元素? - 2

    本文主要介绍在使用Selenium进行自动化测试或者任务时,对于使用了iframe的页面,如何定位iframe中的元素文章目录场景描述解决方案具体代码场景描述当我们在使用Selenium进行自动化测试的时候,可能会遇到一些界面或者窗体是使用HTML的iframe标签进行承载的。对于iframe中的标签,如果直接查找是无法找到的,会抛出没有找到元素的异常。比如近在咫尺的例子就是,CSDN的登录窗体就是使用的iframe,大家可以尝试通过F12开发者模式查看到的tag_name,class_name,id或者xpath来定位中的页面元素,会抛出NoSuchElementException异常。解决

  9. python ffmpeg 使用 pyav 转换 一组图像 到 视频 - 2

    2022/8/4更新支持加入水印水印必须包含透明图像,并且水印图像大小要等于原图像的大小pythonconvert_image_to_video.py-f30-mwatermark.pngim_dirout.mkv2022/6/21更新让命令行参数更加易用新的命令行使用方法pythonconvert_image_to_video.py-f30im_dirout.mkvFFMPEG命令行转换一组JPG图像到视频时,是将这组图像视为MJPG流。我需要转换一组PNG图像到视频,FFMPEG就不认了。pyav内置了ffmpeg库,不需要系统带有ffmpeg工具因此我使用ffmpeg的python包装p

  10. Python 刷Leetcode题库,顺带学英语单词(31) - 2

    ValidPalindromeGivenastring,determineifitisapalindrome,consideringonlyalphanumericcharactersandignoringcases. [#125]Example:"Aman,aplan,acanal:Panama"isapalindrome."raceacar"isnotapalindrome.Haveyouconsiderthatthestringmightbeempty?Thisisagoodquestiontoaskduringaninterview.Forthepurposeofthisproblem

随机推荐