图像压缩算法

8.1 JPEG压缩 (JPEG Compression)

介绍

JPEG(Joint Photographic Experts Group)压缩是最常用的有损图像压缩算法之一。它通过减少图像中的冗余数据来实现高效压缩,特别适用于自然图像。

原理

JPEG压缩的基本步骤包括颜色空间转换、离散余弦变换(DCT)、量化和熵编码。颜色空间转换将RGB图像转换为YCrCb格式,以分离亮度信息和色度信息。DCT将图像块转换到频域,量化步骤减少高频系数的精度,熵编码则进一步压缩数据。

公式

JPEG压缩的核心步骤是离散余弦变换,其公式为:

其中,f(x,y) 为图像块中的像素值,α(u) 和 α(v) 为正则化系数。

案例

使用Python和OpenCV进行JPEG压缩和解压缩。

代码解析
import cv2
import numpy as np# 读取图像
image = cv2.imread('image.jpg')# 保存为JPEG格式,设置压缩质量
cv2.imwrite('compressed_image.jpg', image, [int(cv2.IMWRITE_JPEG_QUALITY), 50])# 读取压缩后的图像
compressed_image = cv2.imread('compressed_image.jpg')# 显示原图和压缩图像
cv2.imshow('Original Image', image)
cv2.imshow('Compressed Image', compressed_image)
cv2.waitKey(0)
cv2.destroyAllWindows()
生活场景案例

JPEG压缩广泛应用于数码相机、手机、互联网中的图像存储和传输,由于其压缩效率高且支持大多数设备,是最流行的图像格式之一。

总结

JPEG压缩通过有损的方式显著减少图像文件大小,适用于对压缩质量要求不高的场景,如照片存储和网页图像加载。

8.2 无损压缩 (Lossless Compression)

介绍

无损压缩通过高效编码原理在不丢失任何信息的情况下压缩图像数据。常见的无损压缩格式包括PNG和GIF,适用于需要精确保存图像信息的场景。

原理

无损压缩利用了图像中的冗余信息,通过熵编码、预测编码等技术来减少数据量。典型的无损压缩方法包括基于LZ77算法的PNG和基于LZW算法的GIF。

公式

无损压缩的一般原理基于信息论中的熵编码:

其中,H(X) 是信息熵,P(xi) 是符号 xi 的概率。

案例

使用Python和PIL进行PNG图像的压缩和解压缩。

代码解析
from PIL import Image# 读取图像
image = Image.open('image.png')# 保存为PNG格式
image.save('compressed_image.png', format='PNG')# 读取压缩后的图像
compressed_image = Image.open('compressed_image.png')# 显示图像信息
compressed_image.show()
生活场景案例

无损压缩适用于需要精确保存每个像素值的图像,如医学图像、工程图纸和一些高质量的图形设计工作。

总结

无损压缩可以在保持图像完整性的同时,减少存储空间,适用于精确度要求高的应用场景。

8.3 基于变换的压缩 (Transform-based Compression)

介绍

基于变换的压缩方法,如小波变换压缩,是现代图像压缩技术的核心。它通过多分辨率分析,对图像进行有效压缩,适合于各种图像类型的高效存储。

原理

小波变换通过将图像分解为多个不同尺度和分辨率的子带,捕捉图像的局部特征。高频部分通常代表图像的细节,而低频部分代表图像的整体结构。通过量化和编码这些分解后的子带,能够实现图像的高效压缩。

公式

小波变换的基本公式为:

其中,Wψ(a,b) 是小波系数,f(t) 是原始信号,ψ是小波函数,a 和 b 分别是尺度和位置参数。

案例

使用Python和PyWavelets进行小波变换图像压缩。

代码解析
import pywt
import cv2
import numpy as np
import matplotlib.pyplot as plt# 读取图像
image = cv2.imread('image.jpg', 0)# 进行小波变换
coeffs2 = pywt.dwt2(image, 'haar')
LL, (LH, HL, HH) = coeffs2# 显示不同分辨率下的子带
plt.subplot(221), plt.imshow(LL, cmap='gray')
plt.title('Approximation')
plt.subplot(222), plt.imshow(LH, cmap='gray')
plt.title('Horizontal detail')
plt.subplot(223), plt.imshow(HL, cmap='gray')
plt.title('Vertical detail')
plt.subplot(224), plt.imshow(HH, cmap='gray')
plt.title('Diagonal detail')plt.show()
生活场景案例

基于变换的压缩广泛应用于高清电视、电影存储、医疗成像等领域,能够在保持图像质量的同时,显著降低数据量。

总结

基于变换的压缩方法通过对图像的频域分析实现高效压缩,适用于对压缩效率和图像质量要求高的场景。

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

WPF篇(18)-DataGrid数据表格控件+ComboBox下拉框控件

DataGrid数据表格控件 DataGrid是一个可以多选的数据表格控件。所以,它继承一个支持多选的父类——MultiSelector。 public abstract class MultiSelector : Selector {protected MultiSelector();public IList SelectedItems { get; }protected bool CanSelectMu…

Python学习day16-类与对象

这里写目录标题 类示例 成员方法self关键字 类与对象构造方法其他类内置方法(魔术方法)_str_符号_Lt_符号le小于等于比较eq比较运算小结 类 在Python中,class(类)是一种用于创建对象的模板或蓝图。它封装了数据&#…

基于Django的停车场车辆出入管理系统,可识别车牌图片

研究背景 随着城市化进程的加快,车辆数量不断增加,停车场的管理成为一个日益重要的课题。传统的停车场管理系统依赖人工登记和监控,不仅效率低下,而且容易出现疏漏和错误,难以满足现代社会对停车场管理智能化、高效化…

STM32标准库学习笔记-3.外部中断

参考教程:【STM32入门教程-2023版 细致讲解 中文字幕】 中断 中断含义:在计算机执行主程序运行过程中,出现了特定的中断触发条件(中断源),使得CPU暂停当前正在运行的程序,转而去处理中断程序&…

2024 国内自闭症学校排名榜:突破边界,创造无限可能

在 2024 年,当家长们面对国内自闭症学校的排名榜时,心中或许充满了期待与困惑。然而,这些排名榜虽然能提供一定的参考,但绝不能成为选择学校的唯一依据。家长们更需要深入了解每所学校的真实情况,通过线下考察&#xf…

python及pycharm安装配置

PS:这篇是对于初学者的python以及pycharm配置教程,配置完成后可以直接看我的python学习笔记来进行python全套学习,现在已更新第一部分。 Python学习笔记(一)-CSDN博客 目录 一、python以及pycharm的安装配置 1.1 py…

Nuxt3:构建的时候报错Search string not found: “for (const existingRoot of buildInfoVersionMap.roots)

我们完成初步页面开发后,需要构建下项目生成我们需要的页面,在执行构建的时候报错: 找了很多资料,这个问题是由于 vue-tsc v1 版本引起,只需要将 vue-tsc 升级到v2 即可 我们在执行删除的时候,结果发现它…

【MySQL】数据库约束

系列文章目录 第一章 数据库基础 第二章 数据库基本操作 文章目录 系列文章目录前言约束关键字一览NOT NULLUNIQUEDEFAULTPRIMARY KEY自增主键 FOREIGN KEY总结 前言 在学习了数据库的增删改查操作之后,接下来就需要进阶的学习关键字来完善SQL语句的条件。学习数据…

数据结构----链表

一丶概念 链表又称单链表、链式存储结构,用于存储逻辑关系为“一对一”的数据。 和顺序表不同同,使用链表存储数据,不强制要求数据在内存中集中存储,各个元素可以分散存储在内存中。 二丶特点 特点:内存不连…

DolphinScheduler集群部署问题(趟坑)总结

目录 官方文档 官方项目地址 问题解决 官方文档 DolphinScheduler | 文档中心 (apache.org) 官方项目地址 部署及使用过程中的问题可以参见项目Issue:Issues apache/dolphinscheduler GitHub GitHub - apache/dolphinscheduler at 3.2.2-release 问题解决 1、JVM在运…

Simple RPC - 05 从零开始设计一个客户端(下)_ 依赖倒置和SPI

文章目录 Pre概述依赖倒置原则与解耦设计与实现1. 定义接口来隔离调用方与实现类2. 实现类DynamicStubFactory3. 调用方与实现类的解耦 依赖注入与SPI的解耦依赖注入SPI(Service Provider Interface) 总结 Pre Simple RPC - 01 框架原理及总体架构初探 …

网络编程:OSI协议,TCP/IP协议,IP地址,UDP编程

目录 国际网络通信协议标准: 1.OSI协议: 2.TCP/IP协议模型: 应用层 : 传输层: 网络层: IPV4协议 IP地址 IP地址的划分: 公有地址 私有地址 MA…

dotnet常用命令详解

命令预览 基础命令 new:创建项目 restore:恢复依赖 build:编译项目 publish:生成项目需要的文件准备发布项目 run:运行项目 test:测试项目 vstest:从指定的程序集中运行测试 pack&#…

升级阿里云linux服务器上的php版本

查看已安装的php软件包 [rootiZbp13pl2v34qj0thwq9aiZ ~]# rpm -qa|grep php php74-php-common-7.4.26-1.el7.remi.x86_64 oniguruma5php-6.9.7.1-1.el7.remi.x86_64 php74-php-gd-7.4.26-1.el7.remi.x86_64 php74-php-opcache-7.4.26-1.el7.remi.x86_64 php74-php-json-7.4.2…

记录|Git工具——下载GitHub项目

目录 前言一、Step 1. 下载Git二、Step2. 用Git Bash 下载到本地更新时间 前言 参考文章: 1、如何使用Git将Github项目拉到本地 2、git 安装、创建仓库、上传项目、克隆下载、常用命令 – 一篇文章总结(适用github / gitee) 3、Git的使用【入…

政策驱动,科技引领,漫途信息化监测方案守护农村饮水安全!

近日,山西省人民政府正式发布《山西省农村供水高质量发展规划》,明确到2030年,全面实现农村24小时供水,县域农村饮水安全标准化建设达标率力争达到80%,基本实现农村供水城市化、城乡供水均等化。 现阶段部分地区受…

ArcGIS简单介绍

ArcGIS体系结构 (1)GIS Server 宿主各种GIS资源,将他们封装为服务提供给客户端应用。GIS Server分为两部分:Server Object Manager(SOM)和Server Object Containers(SOCs)。一个SO…

Java语言程序设计——篇十三(4)

🌿🌿🌿跟随博主脚步,从这里开始→博主主页🌿🌿🌿 欢迎大家:这里是我的学习笔记、总结知识的地方,喜欢的话请三连,有问题可以私信🌳🌳&…

仪表板展示|DataEase看中国:2024巴黎奥运会中国体育代表团战绩报告

背景介绍 北京时间2024年8月12日凌晨,巴黎奥运会闭幕。在本届奥运会中,我们不仅见证了许多新世界纪录的诞生,更看到了中国体育的强大实力与无限潜力。中国运动健儿们卓越的表现和顽强的拼搏精神,不但让国人为之自豪,也…

Windows 11 Build 27686 上手体验:2TB FAT32、更好的沙盒等功能

Windows 11 Build 27686 现已在 Insider Program 的 Canary 频道发布,其中包含一些有趣的内容。该版本确认了微软更改 FAT32 大小限制的计划,并将其大小限制从 32GB 提高到 2TB。与此同时,沙盒也得到了改进。让我们来详细了解一下此次更新。 …