特征值分解(EVD)和奇异值分解(SVD)—应用于图片压缩

news2025/3/13 0:13:42

特征值分解(EVD)和奇异值分解(SVD)—应用于图片压缩

目录

前言

一、特征值分解

二、应用特征值分解对图片进行压缩

三、矩阵的奇异值分解

四、应用奇异值分解对图片进行压缩

五、MATLAB仿真代码


前言

        学习了特征值分解和奇异值分解相关知识,发现其可以用于图片压缩,但网上没有找到相应代码,本文在学习了之后编写出了图片压缩的代码,发现奇异值分解的效果要远好于特征值分解,本文在此简要记录一下。


提示:以下是本篇文章正文内容,欢迎各位阅读,转载请附上链接。

一、特征值分解

特征值分解英文缩写为EVD,全称为eigenvalue decomposition。

如果说一个向量\textbf{v}是m×m阶方阵\textbf{A}的特征向量,将一定可以表示成下面的形式:

\textbf{A}\textbf{v}=\lambda \textbf{v}

这种形式在数学上的含义:描述的是矩阵对向量的变换效果只有拉伸,没有旋转。(因为这个值是一个数值),这时候就被称为特征向量对应的特征值。

那么方阵\textbf{A}可以表示成

\textbf{A}=(\lambda_1\textbf{v}_1,\lambda_2\textbf{v}_2,\ldots,\lambda_m\textbf{v}_m)=(\textbf{v}_1,\textbf{v}_2,\ldots,\textbf{v}_m)\begin{bmatrix}\lambda_1&\ldots&0\\\vdots&\ddots&\vdots\\0&\ldots&\lambda_m\end{bmatrix}

\textbf{AV}=\textbf{V}\Lambda

那么就可以得到方阵\textbf{A}的特征分解公式:

\textbf{A}=\textbf{V}\Lambda \textbf{V}^{-1}

总结:特征分解,可以得到个m特征向量和特征值,利用这m个特征(代表这个矩阵最重要的特征),就可以近似这个矩阵。

二、应用特征值分解对图片进行压缩

假设原图大小为m×m,保留前k个特征值需要存储的点数为m×k+k+k×m,定义压缩率为:

r=(m×k+k+k×m)/(m×m)。

下面是一张大小为1024×1024大小的图片。

保留前10个特征值(压缩率为0.0196)可得到下图:

保留前100个特征值(压缩率为0.2048)可得到下图:

保留前200个特征值(压缩率为0.4288)可得到下图:

保留前500个特征值(压缩率为1.2150)可得到下图:

保留前988个特征值(压缩率为2.8606)可得到下图:

总结:这张原始图片的秩为988,发现保留前988个特征值就能完全恢复原图像,但是会发现保留特征值个数太多,其实并没有起到压缩的作用。因此特征值分解的确能压缩图片,但是恢复的效果不是很好,而且仅仅适用于方阵。所以接下来继续介绍矩阵的奇异值分解。

三、矩阵的奇异值分解

奇异值分解英文缩写为SVD,全称为singular value decomposition。

先上结论:对于任意一个矩阵m×n阶矩阵\textbf{A},我们都可以将它分解为

\textbf{A}=\textbf{U}\sum \textbf{V}^{T}

其中U,V是正交矩阵,∑是对角矩阵,其主对角线上的每个值我们称为奇异值。

具体原理推导可以参考文章:奇异值分解(SVD分解)———超详细讲解-CSDN博客

本文重在应用。

四、应用奇异值分解对图片进行压缩

假设原图大小为m×n,保留前k个奇异值需要存储的点数为m×k+k+k×n,定义压缩率为:

r=(m×k+k+k×n)/(m×n)。

还是刚才那张大小为1024×1024大小的图片。

保留前10个奇异值(压缩率为0.0195)可得到下图:

保留前100个奇异值(压缩率为0.1954)可得到下图:

保留前200个奇异值(压缩率为0.3908)可得到下图:

保留前300个奇异值(压缩率为0.5862)可得到下图:

总结:可以看出奇异值分解的效果比特征值分解好的多,能在起到压缩大小的情况下还能比较好的保留原图像的效果。

五、MATLAB仿真代码

https://download.csdn.net/download/m0_66360845/89724139icon-default.png?t=O83Ahttps://download.csdn.net/download/m0_66360845/89724139

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2114054.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

初次使用住宅代理有哪些常见误区?

随着网络技术的发展,住宅代理因其高匿名性和稳定性成为许多用户进行网络活动的首选工具。然而,对于新手而言,使用住宅代理时往往容易陷入一些误区,这不仅可能影响使用效果,还可能带来安全风险。本文将探讨新手在使用住…

我与Linux的爱恋:yum和vim以及gcc的使用

​ ​ 🔥个人主页:guoguoqiang. 🔥专栏:Linux的学习 文章目录 ​1.Linux软件包管理器yum2.Linux开发工具3.Linux编译器 vimvim的基本概念vim的基本操作vim正常模式命令集vim末行模式命令集vim操作总结批量化注释批量化去注释简…

【数据库中级】1_DBeaver操作数据库

文章目录 一、连接数据库1.1 命令行连接数据库1.2 DBeaver工具连接数据库 二、DBeaver操作数据库2.1 通过DBeaver操作数据库2.2 通过DBeaver操作表2.3 通过DBeaver操作数据 三、DBeaver界面3.1 SQL编辑区3.2 导航区3.3 修改字体大小 一、连接数据库 1.1 命令行连接数据库 命令…

《Learning to Count without Annotations》CVPR2024

摘要 论文提出了一种名为UnCounTR的模型,该模型能够在没有任何手动标注的情况下学习进行基于参考的对象计数。这是通过构建“Self-Collages”(自我拼贴画)实现的,即在背景图像上粘贴不同对象的图像作为训练样本,提供覆…

【Git 学习笔记_24】Git 实用冷门操作技巧(四)—— 更多实用 git 别名设置、交互式新增提交

文章目录 11.8 更多别名设置别名1:只查看当前分支(git b)别名2:以图表形式显示自定义格式的 git 日志(git graph)别名3:查看由于合并分支导致的冲突后仍有冲突的、待合并的文件列表(…

Excel文档的读取(1)

熟悉使用Excel的同学应该都知道,在单个Excel表格里想要分商品计算总销售额,使用数据透视表也可以非常快速方便的获得结果。但当有非常大量的Excel文件需要处理时,每一个Excel文件单独去做数据透视也会消耗大量的时间。就算使用Power Query这样…

python容器3——字典

(1) 什么是字典 字典:python中使用关键字dict表示 字典中允许通过key:value键值对的方式存储数据,让数据的管理更加友好! 如图: 字典是一个哈希结构 (传入一个值算出内存地址,将该值保存在该…

产品经理就业

供需关系 1.需求分析核心价值是? 将真实的用户需求分析得到与之匹配的产品方案(功能) 2.Y模型的主要内容及其侧重点? 1)用户需求、2)目标动机、3)产品功能、4)人性(马斯洛需求) 1-2-4侧重深入想清楚需求本质 Why、4 -2-3 侧重浅出 How 结果输出 3.可以从哪些角度做好需求分析…

java.lang.IndexOutOfBoundsException: setSpan ( 0...x ) ends beyond length X

1,可能是EditText,setSelection(x)时超过了 输入框内容的实际长度导致的。 2,手机开启“拼写检查功能”,EditText设置了最大长度,选择提示的某一项文案时超过设置的最大长度限制,导致崩溃。 针对情况2 开…

【电子通识】洁净度等级划分及等级标准

洁净度常用于评估半导体、生物制药、医疗、实验室及科研院所、新能源等领域的洁净室、无尘室或者无菌室等环境。 一般来说,晶圆光刻、制造、测试等级为100级或1000级的洁净间,百级洁净间要求空气中0.5微米的尘埃粒子数不得超过每立方米3520个&#xff1b…

移动UI:新手指引页面,跟着指引不迷路。

移动端新手指引在提供用户引导、提升用户体验、提高用户留存率、促进功能使用和降低用户流失率方面都有积极的作用。 移动端新手指引在应用程序或移动网站中有以下几个作用: 1. 提供用户引导: 新手指引可以帮助用户快速了解应用程序或移动网站的功能和…

【网络安全】Exif 数据储存型XSS

未经许可,不得转载。 文章目录 Exif步骤Exif EXIF(Exchangeable Image File Format)数据是一种存储在图像文件中的元数据格式,常用于数码照片和扫描图像。它包含了与图像相关的各种信息,比如拍摄日期和时间、相机品牌和型号、拍摄时的设置(如曝光时间、光圈、ISO等)、地…

输送线相机拍照信号触发(博途PLC高速计数器中断立即输出应用)

博途PLC相关中断应用请参考下面文章链接: T法测速功能块 T法测速功能块(博途PLC上升沿中断应用)-CSDN博客文章浏览阅读165次。本文介绍了博途PLC中T法测速的原理和应用,包括如何开启上升沿中断、配置中断以及T法测速功能块的使用。重点讲述了在中断事件发生后执行的功能块处…

dp算法练习【6】

最长公共子序列 1143. 最长公共子序列 给定两个字符串 text1 和 text2,返回这两个字符串的最长 公共子序列 的长度。如果不存在 公共子序列 ,返回 0 。 一个字符串的 子序列 是指这样一个新的字符串:它是由原字符串在不改变字符的相对顺序…

被审稿人批得体无完肤?参考文献这样引用就对了!

我是娜姐 迪娜学姐 ,一个SCI医学期刊编辑,探索用AI工具提效论文写作和发表。 审稿人对参考文献引用提出质疑,在comments中还挺常见的。一般来说,是最新的、相关的、重要的文献引用缺失。此外,如果仔细分析引文来源&…

QT定时器QObiect/QTimer

QT定时器 一、QObiect: startTimer ----------- killTimer 电子相册,利用定时器轮播图片 #include "widget.h" #include "ui_widget.h"Widget::Widget(QWidget *parent) :QWidget(parent),ui(new Ui::Widget) {ui->setupUi(this);picID …

【自动驾驶】控制算法(八)横向控制Ⅱ | Carsim 与 Matlab 联合仿真基本操作

写在前面: 🌟 欢迎光临 清流君 的博客小天地,这里是我分享技术与心得的温馨角落。📝 个人主页:清流君_CSDN博客,期待与您一同探索 移动机器人 领域的无限可能。 🔍 本文系 清流君 原创之作&…

[SWPUCTF 2021 新生赛]web方向(一到六题) 解题思路,实操解析,解题软件使用,解题方法教程

题目来源 NSSCTF | 在线CTF平台因为热爱,所以长远!NSSCTF平台秉承着开放、自由、共享的精神,欢迎每一个CTFer使用。https://www.nssctf.cn/problem [SWPUCTF 2021 新生赛]gift_F12 这个题目简单打开后是一个网页 我们一般按F12或者是右键查…

AWTK 如何用 OpenGL 绘制图形

在有 GPU 的情况下,AWTK 使用 OpenGL 绘制图形。但是你会发现,如果自己在 paint 事件中使用 OpenGL 绘制图形,图形是无法显示的。原因是,AWTK 采用 nanovg 绘制图形,而 nanovg 并不是在绘制时立即执行的,而…

Visual Studio Code:让你的工作效率飞升的秘密武器

在现代软件开发环境中,效率已成为每个开发者追求的目标。而在众多编程工具中,Visual Studio Code(简称VS Code)凭借其强大的功能、轻量的界面和高度的可定制性,成为了全球开发者的首选。无论你是编写前端代码、后端服务…