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

相关文章

Python标准库之数据压缩和存档的应用详解

《Python标准库之数据压缩和存档的应用详解》在数据处理与存储领域,压缩和存档是提升效率的关键技术,Python标准库提供了一套完整的工具链,下面小编就来和大家简单介绍一下吧... 目录一、核心模块架构与设计哲学二、关键模块深度解析1.tarfile:专业级归档工具2.zipfile:跨平台归档首选3.

使用IDEA部署Docker应用指南分享

《使用IDEA部署Docker应用指南分享》本文介绍了使用IDEA部署Docker应用的四步流程:创建Dockerfile、配置IDEADocker连接、设置运行调试环境、构建运行镜像,并强调需准备本... 目录一、创建 dockerfile 配置文件二、配置 IDEA 的 Docker 连接三、配置 Do

深入浅出SpringBoot WebSocket构建实时应用全面指南

《深入浅出SpringBootWebSocket构建实时应用全面指南》WebSocket是一种在单个TCP连接上进行全双工通信的协议,这篇文章主要为大家详细介绍了SpringBoot如何集成WebS... 目录前言为什么需要 WebSocketWebSocket 是什么Spring Boot 如何简化 We

Java Stream流之GroupBy的用法及应用场景

《JavaStream流之GroupBy的用法及应用场景》本教程将详细介绍如何在Java中使用Stream流的groupby方法,包括基本用法和一些常见的实际应用场景,感兴趣的朋友一起看看吧... 目录Java Stream流之GroupBy的用法1. 前言2. 基础概念什么是 GroupBy?Stream

python中列表应用和扩展性实用详解

《python中列表应用和扩展性实用详解》文章介绍了Python列表的核心特性:有序数据集合,用[]定义,元素类型可不同,支持迭代、循环、切片,可执行增删改查、排序、推导式及嵌套操作,是常用的数据处理... 目录1、列表定义2、格式3、列表是可迭代对象4、列表的常见操作总结1、列表定义是处理一组有序项目的

C#中的Converter的具体应用

《C#中的Converter的具体应用》C#中的Converter提供了一种灵活的类型转换机制,本文详细介绍了Converter的基本概念、使用场景,具有一定的参考价值,感兴趣的可以了解一下... 目录Converter的基本概念1. Converter委托2. 使用场景布尔型转换示例示例1:简单的字符串到

Spring Boot Actuator应用监控与管理的详细步骤

《SpringBootActuator应用监控与管理的详细步骤》SpringBootActuator是SpringBoot的监控工具,提供健康检查、性能指标、日志管理等核心功能,支持自定义和扩展端... 目录一、 Spring Boot Actuator 概述二、 集成 Spring Boot Actuat

PyTorch中的词嵌入层(nn.Embedding)详解与实战应用示例

《PyTorch中的词嵌入层(nn.Embedding)详解与实战应用示例》词嵌入解决NLP维度灾难,捕捉语义关系,PyTorch的nn.Embedding模块提供灵活实现,支持参数配置、预训练及变长... 目录一、词嵌入(Word Embedding)简介为什么需要词嵌入?二、PyTorch中的nn.Em

Spring Boot3.0新特性全面解析与应用实战

《SpringBoot3.0新特性全面解析与应用实战》SpringBoot3.0作为Spring生态系统的一个重要里程碑,带来了众多令人兴奋的新特性和改进,本文将深入解析SpringBoot3.0的... 目录核心变化概览Java版本要求提升迁移至Jakarta EE重要新特性详解1. Native Ima

使用zip4j实现Java中的ZIP文件加密压缩的操作方法

《使用zip4j实现Java中的ZIP文件加密压缩的操作方法》本文介绍如何通过Maven集成zip4j1.3.2库创建带密码保护的ZIP文件,涵盖依赖配置、代码示例及加密原理,确保数据安全性,感兴趣的... 目录1. zip4j库介绍和版本1.1 zip4j库概述1.2 zip4j的版本演变1.3 zip4