0

0

OpenCV 图像压缩完整指南

王林

王林

发布时间:2024-08-20 17:57:03

|

580人浏览过

|

来源于dev.to

转载

图像压缩是计算机视觉中的一项关键技术,它使我们能够更有效地存储和传输图像,同时保持视觉质量。理想情况下,我们希望拥有最佳质量的小文件。然而,我们必须做出权衡并决定哪个更重要。

本教程将教授使用 opencv 进行图像压缩,涵盖理论和实际应用。最后,您将了解如何为计算机视觉项目(或您可能拥有的任何其他项目)成功压缩照片。

什么是图像压缩?

图像压缩正在减小图像的文件大小,同时保持可接受的视觉质量水平。有两种主要的压缩类型:

  1. 无损压缩:保留所有原始数据,允许精确的图像重建。
  2. 有损压缩: 丢弃一些数据以获得更小的文件大小,可能会降低图像质量。

为什么要压缩图像?

如果正如我们经常听到的那样“磁盘空间很便宜”,那么为什么还要压缩图像呢?在小范围内,图像压缩并不重要,但在大范围内,它至关重要。

例如,如果您的硬盘上有一些图像,您可以压缩它们并保存几兆字节的数据。当硬盘驱动器以 tb 为单位时,这不会产生太大影响。但如果您的硬盘上有 100,000 张图像怎么办?一些基本的压缩可以节省实时时间和金钱。从性能的角度来看,是一样的。如果您的网站包含大量图像,并且每天有 10,000 人访问您的网站,那么压缩就很重要。

这就是我们这样做的原因:

  • 减少存储要求:在同一空间中存储更多图像
  • 更快的传输:非常适合网络应用程序和带宽受限的场景
  • 提高处理速度:较小的图像加载和处理速度更快

图像压缩背后的理论

图像压缩技术利用两种类型的冗余:

  1. 空间冗余:相邻像素之间的相关性
  2. 颜色冗余:相邻区域颜色值的相似度

空间冗余利用了大多数自然图像中相邻像素往往具有相似值的事实。这会产生平滑的过渡。许多照片“看起来很真实”,因为从一个区域到另一个区域有一种自然的流动。当相邻像素具有截然不同的值时,您会得到“嘈杂”的图像。像素发生了变化,通过将像素分组为单一颜色,使这些过渡变得不那么“平滑”,从而使图像更小。

OpenCV 图像压缩完整指南

颜色冗余,另一方面,重点关注图像中的相邻区域如何经常共享相似的颜色。想象一下蓝天或绿地——图像的大部分可能具有非常相似的颜色值。它们也可以组合在一起并制成单一颜色以节省空间。

OpenCV 图像压缩完整指南

opencv 提供了用于处理这些想法的可靠工具。例如,opencv 的 cv2.inpaint() 函数利用空间冗余,使用附近像素的信息填充图片中缺失或损坏的区域。 opencv 允许开发人员使用 cv2.cvtcolor() 在多个关于颜色冗余的颜色空间之间转换图像。这作为许多压缩技术中的预处理步骤可能会有所帮助,因为某些颜色空间在编码特定类型的图像时比其他颜色空间更有效。

我们现在将测试这个理论的一些内容。我们来玩一下吧。

动手实践图像压缩

让我们探索如何使用 opencv 的 python 绑定来压缩图像。写下此代码或复制它:

您也可以在这里获取源代码

import cv2
import numpy as np

def compress_image(image_path, quality=90):
    # read the image
 img = cv2.imread(image_path)
    
    # encode the image with jpeg compression
 encode_param = [int(cv2.imwrite_jpeg_quality), quality]
 _, encoded_img = cv2.imencode('.jpg', img, encode_param)
    
    # decode the compressed image
 decoded_img = cv2.imdecode(encoded_img, cv2.imread_color)
    
    return decoded_img

# example usage
original_img = cv2.imread('original_image.jpg')
compressed_img = compress_image('original_image.jpg', quality=50)

# display results
cv2.imshow('original', original_img)
cv2.imshow('compressed', compressed_img)
cv2.waitkey(0)
cv2.destroyallwindows()

# calculate compression ratio
original_size = original_img.nbytes
compressed_size = compressed_img.nbytes
compression_ratio = original_size / compressed_size
print(f"compression ratio: {compression_ratio:.2f}")

此示例包含一个 compress_image 函数,该函数采用两个参数:

  • 图片路径(图片所在的位置)
  • 质量(所需图像的质量)

然后,我们将原始图像加载到original_img中。然后,我们将同一图像压缩 50% 并将其加载到新实例压缩图像中。

然后我们将显示原始图像和压缩图像,以便您可以并排查看它们。

然后我们计算并显示压缩比。

此示例演示了如何在 opencv 中使用 jpeg 压缩来压缩图像。质量参数控制文件大小和图像质量的权衡。

让我们运行它:

OpenCV 图像压缩完整指南

最初查看图像时,您发现几乎没有什么区别。然而,放大后你会发现质量的差异:

OpenCV 图像压缩完整指南

关闭窗口并查看文件后,我们可以看到文件的大小急剧减小:

OpenCV 图像压缩完整指南

另外,如果我们进一步降低,我们可以将质量更改为10%

compressed_img = compress_image('sampleimage.jpg', quality=10)

结果更加剧烈:

OpenCV 图像压缩完整指南

文件大小结果也更加剧烈:

OpenCV 图像压缩完整指南

您可以非常轻松地调整这些参数,并在质量和文件大小之间达到所需的平衡。

Sora
Sora

Sora是OpenAI发布的一种文生视频AI大模型,可以根据文本指令创建现实和富有想象力的场景。

下载

评估压缩质量

为了评估压缩的影响,我们可以使用以下指标:

  1. 均方误差(mse)

均方误差 (mse) 衡量两个图像之间的差异程度。当您压缩图像时,mse 可以帮助您确定压缩图像与原始图像相比发生了多少变化。

它通过对两个图像中相应像素的颜色之间的差异进行采样、对这些差异进行平方并求平均值来实现此目的。结果是一个数字:较低的 mse 意味着压缩图像更接近原始图像。相比之下,更高的 mse 意味着质量损失更明显。

这里有一些 python 代码来衡量:

def calculate_mse(img1, img2):
    return np.mean((img1 - img2) ** 2)

mse = calculate_mse(original_img, compressed_img)
print(f"mean squared error: {mse:.2f}")

这是我们的演示图像压缩的样子:

OpenCV 图像压缩完整指南

  1. 峰值信噪比(psnr)

峰值信噪比(psnr)是衡量压缩后图像质量下降程度的指标。这通常是肉眼可见的,但它指定了一个设定值。它将原始图像与压缩图像进行比较,并将差异表示为比率。

psnr 值越高,意味着压缩后的图像质量更接近原始图像,表明质量损失更少。 psnr 越低意味着退化越明显。 psnr 通常与 mse 一起使用,psnr 提供了一个更易于解释的量表,其中越高越好。

这是一些测量这一点的 python 代码:

def calculate_psnr(img1, img2):
 mse = calculate_mse(img1, img2)
    if mse == 0:
        return float('inf')
 max_pixel = 255.0
    return 20 * np.log10(max_pixel / np.sqrt(mse))

psnr = calculate_psnr(original_img, compressed_img)
print(f"psnr: {psnr:.2f} db")

这是我们的演示图像压缩的样子:

OpenCV 图像压缩完整指南

“观察”压缩后的图像以确定质量是否良好;然而,在大规模上,让脚本执行此操作是设置标准并确保图像遵循这些标准的更简单的方法。

让我们看看其他一些技巧:

先进的压缩技术

对于更高级的压缩,opencv 支持各种算法:

  1. png 压缩:

您可以将图像转换为png格式,这有很多优点。使用以下代码行,您可以根据需要将压缩设置为 0 到 9。 0 表示不进行任何压缩,9 表示最大。请记住,png 是一种“无损”格式,因此即使在最大压缩下,图像也应保持完整。最大的权衡是文件大小和压缩时间。

这是使用 opencv 进行 png 压缩的代码:

cv2.imwrite('compressed.png', img, [cv2.imwrite_png_compression, 9])

这是我们的结果:

OpenCV 图像压缩完整指南

注意:有时您可能会注意到 png 文件实际上尺寸更大,就像在本例中一样。这取决于图像的内容。

  1. webp 压缩:

您还可以将图像转换为 .webp 格式。这是一种越来越流行的新型压缩方法。多年来我一直在博客上的图像上使用这种压缩。

在下面的代码中,我们可以将图像写入 webp 文件,并将压缩级别设置为 0 到 100。这与 png 的比例相反,因为 0,因为我们设置的是 quality 而不是 compression。这个微小的区别很重要,因为设置为 0 是可能的最低质量,文件大小较小且损失很大。 100是最高质量,这意味着大文件具有最好的图像质量。

这是实现这一目标的 python 代码:

cv2.imwrite('compressed.webp', img, [cv2.IMWRITE_WEBP_QUALITY, 80])

这是我们的结果:

OpenCV 图像压缩完整指南

这两种技术非常适合压缩大量数据。您可以编写脚本来自动压缩数千或数十万张图像。

结论

图像压缩非常棒。它在很多方面对于计算机视觉任务至关重要,尤其是在节省空间或提高处理速度时。当您想要减少硬盘空间或节省带宽时,计算机视觉之外还有许多用例。图像压缩有很大帮助。

通过理解其背后的理论并应用它,您可以在您的项目中做一些强大的事情。

请记住,有效压缩的关键是找到减小文件大小和保持应用程序可接受的视觉质量之间的最佳点。

感谢您的阅读,如果您有任何意见或问题,请随时与我们联系!

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
页面置换算法
页面置换算法

页面置换算法是操作系统中用来决定在内存中哪些页面应该被换出以便为新的页面提供空间的算法。本专题为大家提供页面置换算法的相关文章,大家可以免费体验。

497

2023.08.14

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

38

2026.03.10

Kotlin Android模块化架构与组件化开发实践
Kotlin Android模块化架构与组件化开发实践

本专题围绕 Kotlin 在 Android 应用开发中的架构实践展开,重点讲解模块化设计与组件化开发的实现思路。内容包括项目模块拆分策略、公共组件封装、依赖管理优化、路由通信机制以及大型项目的工程化管理方法。通过真实项目案例分析,帮助开发者构建结构清晰、易扩展且维护成本低的 Android 应用架构体系,提升团队协作效率与项目迭代速度。

83

2026.03.09

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

97

2026.03.06

Rust内存安全机制与所有权模型深度实践
Rust内存安全机制与所有权模型深度实践

本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

223

2026.03.05

PHP高性能API设计与Laravel服务架构实践
PHP高性能API设计与Laravel服务架构实践

本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

458

2026.03.04

AI安装教程大全
AI安装教程大全

2026最全AI工具安装教程专题:包含各版本AI绘图、AI视频、智能办公软件的本地化部署手册。全篇零基础友好,附带最新模型下载地址、一键安装脚本及常见报错修复方案。每日更新,收藏这一篇就够了,让AI安装不再报错!

169

2026.03.04

Swift iOS架构设计与MVVM模式实战
Swift iOS架构设计与MVVM模式实战

本专题聚焦 Swift 在 iOS 应用架构设计中的实践,系统讲解 MVVM 模式的核心思想、数据绑定机制、模块拆分策略以及组件化开发方法。内容涵盖网络层封装、状态管理、依赖注入与性能优化技巧。通过完整项目案例,帮助开发者构建结构清晰、可维护性强的 iOS 应用架构体系。

246

2026.03.03

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.5万人学习

Django 教程
Django 教程

共28课时 | 4.9万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号