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

2024-09-08 01:04

本文主要是介绍特征值分解(EVD)和奇异值分解(SVD)—应用于图片压缩,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

特征值分解(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

这篇关于特征值分解(EVD)和奇异值分解(SVD)—应用于图片压缩的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1146671

相关文章

Java实现将HTML文件与字符串转换为图片

《Java实现将HTML文件与字符串转换为图片》在Java开发中,我们经常会遇到将HTML内容转换为图片的需求,本文小编就来和大家详细讲讲如何使用FreeSpire.DocforJava库来实现这一功... 目录前言核心实现:html 转图片完整代码场景 1:转换本地 HTML 文件为图片场景 2:转换 H

PHP应用中处理限流和API节流的最佳实践

《PHP应用中处理限流和API节流的最佳实践》限流和API节流对于确保Web应用程序的可靠性、安全性和可扩展性至关重要,本文将详细介绍PHP应用中处理限流和API节流的最佳实践,下面就来和小编一起学习... 目录限流的重要性在 php 中实施限流的最佳实践使用集中式存储进行状态管理(如 Redis)采用滑动

Java实现在Word文档中添加文本水印和图片水印的操作指南

《Java实现在Word文档中添加文本水印和图片水印的操作指南》在当今数字时代,文档的自动化处理与安全防护变得尤为重要,无论是为了保护版权、推广品牌,还是为了在文档中加入特定的标识,为Word文档添加... 目录引言Spire.Doc for Java:高效Word文档处理的利器代码实战:使用Java为Wo

深入浅出Spring中的@Autowired自动注入的工作原理及实践应用

《深入浅出Spring中的@Autowired自动注入的工作原理及实践应用》在Spring框架的学习旅程中,@Autowired无疑是一个高频出现却又让初学者头疼的注解,它看似简单,却蕴含着Sprin... 目录深入浅出Spring中的@Autowired:自动注入的奥秘什么是依赖注入?@Autowired

基于C#实现PDF转图片的详细教程

《基于C#实现PDF转图片的详细教程》在数字化办公场景中,PDF文件的可视化处理需求日益增长,本文将围绕Spire.PDFfor.NET这一工具,详解如何通过C#将PDF转换为JPG、PNG等主流图片... 目录引言一、组件部署二、快速入门:PDF 转图片的核心 C# 代码三、分辨率设置 - 清晰度的决定因

Python从Word文档中提取图片并生成PPT的操作代码

《Python从Word文档中提取图片并生成PPT的操作代码》在日常办公场景中,我们经常需要从Word文档中提取图片,并将这些图片整理到PowerPoint幻灯片中,手动完成这一任务既耗时又容易出错,... 目录引言背景与需求解决方案概述代码解析代码核心逻辑说明总结引言在日常办公场景中,我们经常需要从 W

PostgreSQL简介及实战应用

《PostgreSQL简介及实战应用》PostgreSQL是一种功能强大的开源关系型数据库管理系统,以其稳定性、高性能、扩展性和复杂查询能力在众多项目中得到广泛应用,本文将从基础概念讲起,逐步深入到高... 目录前言1. PostgreSQL基础1.1 PostgreSQL简介1.2 基础语法1.3 数据库

使用Python实现无损放大图片功能

《使用Python实现无损放大图片功能》本文介绍了如何使用Python的Pillow库进行无损图片放大,区分了JPEG和PNG格式在放大过程中的特点,并给出了示例代码,JPEG格式可能受压缩影响,需先... 目录一、什么是无损放大?二、实现方法步骤1:读取图片步骤2:无损放大图片步骤3:保存图片三、示php

Python中的filter() 函数的工作原理及应用技巧

《Python中的filter()函数的工作原理及应用技巧》Python的filter()函数用于筛选序列元素,返回迭代器,适合函数式编程,相比列表推导式,内存更优,尤其适用于大数据集,结合lamb... 目录前言一、基本概念基本语法二、使用方式1. 使用 lambda 函数2. 使用普通函数3. 使用 N

Python中yield的用法和实际应用示例

《Python中yield的用法和实际应用示例》在Python中,yield关键字主要用于生成器函数(generatorfunctions)中,其目的是使函数能够像迭代器一样工作,即可以被遍历,但不会... 目录python中yield的用法详解一、引言二、yield的基本用法1、yield与生成器2、yi