当前位置: 首页 > news >正文

数学-奇异值

有点名词党

奇异值的计算通常涉及矩阵的奇异值分解Singular Value Decomposition, SVD。奇异值分解是将一个矩形矩阵 ( A ) 分解为三个矩阵的乘积:

[ A = U ΣVT]

其中:

- ( U ) 是一个 ( m ×m ) 的正交矩阵,它的列向量是 ( A AT) 的特征向量。

- ( V ) 是一个 ( n ×n ) 的正交矩阵,它的列向量是 ( ATA ) 的特征向量。

- ( Σ) 是一个 ( m ×n ) 的对角矩阵,对角线上的非负数称为奇异值,其余位置上的元素都是零。

计算奇异值的步骤如下:

1. **计算 ( ATA ) ( A AT)** 对给定的矩阵 ( A ) 计算 ( ATA ) ( A AT)。

2. **计算特征值:** 分别计算 ( ATA ) ( A AT) 的特征值。

3. **计算奇异值:** 奇异值是 ( ATA ) ( A AT) 的特征值的平方根。具体来说,( ATA ) 的特征值 ( λ) ( A ) 的奇异值 ( σ) 之间的关系是 ( σ= λ)。

4. **排序奇异值:** 将计算得到的奇异值按照从大到小的顺序排列,这些值就是 ( Σ) 对角线上的元素。

特征值和奇异值是两个不同的概念,它们之间的关系取决于矩阵的结构和大小。
对于一个方阵(即行数和列数相等的矩阵),其特征值和奇异值是有直接关系的。在这种情况下,方阵的特征值的平方确实等于奇异值的平方。这是因为方阵的奇异值分解与其特征值分解是等价的,奇异值就是特征值的绝对值。
但是,对于一个长方形矩阵(即行数和列数不相等的矩阵),情况就不同了。长方形矩阵没有特征值(因为它不是方阵,不能被对角化),但可以有奇异值。在这种情况下,奇异值是由矩阵的谱范数(即最大奇异值)和列空间、行空间的几何关系决定的,并不直接对应于特征值的平方。
总结来说:
- 对于方阵,特征值的绝对值等于奇异值。
- 对于长方形矩阵,没有特征值,但有奇异值,且奇异值的计算与特征值无关。
因此,不能简单地说特征值是奇异值的平方,这种关系只适用于方阵,并且是在特征值的绝对值和奇异值之间。对于非方阵,我们必须使用奇异值分解来计算奇异值。

在实际应用中,通常使用数值计算软件(如MATLAB、NumPy)提供的函数来计算奇异值,因为这些软件已经对奇异值分解算法进行了优化,能够高效且准确地计算奇异值。例如,在Python中,可以使用NumPy库的 `numpy.linalg.svd` 函数来计算矩阵的奇异值分解。

相关文章:

  • STM32通过SPI硬件读写W25Q64
  • MFC GDI绘制卡通人物
  • 长亭网络通信基础
  • LabVIEW、Matlab与Python的比较:从多角度详解三大编程工具
  • 网络安全:Web 安全 面试题.(文件上传漏洞)
  • WPF——属性
  • 案例分享:同为科技与军工项目合作
  • 多层感知器的进化:从基础到并行门控——深入探讨MLP变体的实现、优化与风险
  • 深度解析SD-WAN在企业组网中的应用场景
  • [18] Opencv_CUDA应用之 基于颜色的对象检测与跟踪
  • java -jar
  • 我理解的文本表示模型
  • 【SpringBoot3.x】自定义开发通用SDK
  • [FlareOn5]Ultimate Minesweeper
  • 教程:LVM操作讲解
  • Android 架构优化~MVP 架构改造
  • CSS选择器——伪元素选择器之处理父元素高度及外边距溢出
  • docker容器内的网络抓包
  • es6(二):字符串的扩展
  • Git 使用集
  • isset在php5.6-和php7.0+的一些差异
  • java中具有继承关系的类及其对象初始化顺序
  • JS学习笔记——闭包
  • LeetCode29.两数相除 JavaScript
  • Less 日常用法
  • Nodejs和JavaWeb协助开发
  • Otto开发初探——微服务依赖管理新利器
  • Redis字符串类型内部编码剖析
  • SpiderData 2019年2月23日 DApp数据排行榜
  • Sublime Text 2/3 绑定Eclipse快捷键
  • vue2.0一起在懵逼的海洋里越陷越深(四)
  • vuex 学习笔记 01
  • vue--为什么data属性必须是一个函数
  • Wamp集成环境 添加PHP的新版本
  • 开发了一款写作软件(OSX,Windows),附带Electron开发指南
  • 前端存储 - localStorage
  • 算法---两个栈实现一个队列
  • Python 之网络式编程
  • ​Linux Ubuntu环境下使用docker构建spark运行环境(超级详细)
  • ​第20课 在Android Native开发中加入新的C++类
  • ​学习笔记——动态路由——IS-IS中间系统到中间系统(报文/TLV)​
  • #Datawhale X 李宏毅苹果书 AI夏令营#3.13.2局部极小值与鞍点批量和动量
  • #QT(一种朴素的计算器实现方法)
  • (+4)2.2UML建模图
  • (1)Map集合 (2)异常机制 (3)File类 (4)I/O流
  • (1/2)敏捷实践指南 Agile Practice Guide ([美] Project Management institute 著)
  • (3)llvm ir转换过程
  • (BAT向)Java岗常问高频面试汇总:MyBatis 微服务 Spring 分布式 MySQL等(1)
  • (笔试题)合法字符串
  • (二) 初入MySQL 【数据库管理】
  • (二十六)Java 数据结构
  • (论文阅读40-45)图像描述1
  • (全部习题答案)研究生英语读写教程基础级教师用书PDF|| 研究生英语读写教程提高级教师用书PDF
  • (入门自用)--C++--抽象类--多态原理--虚表--1020
  • (十七)Flink 容错机制