OpenCV 图像压缩完整指南

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

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

什么是图像压缩?

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

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

为什么要压缩图像?

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

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

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

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

图像压缩背后的理论

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

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

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

OpenCV 图像压缩完整指南

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

OpenCV 图像压缩完整指南

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

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

动手实践图像压缩

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

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

import cv2import numpy as npdef 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 usageoriginal_img = cv2.imread('original_image.jpg')compressed_img = compress_image('original_image.jpg', quality=50)# display resultscv2.imshow('original', original_img)cv2.imshow('compressed', compressed_img)cv2.waitkey(0)cv2.destroyallwindows()# calculate compression ratiooriginal_size = original_img.nbytescompressed_size = compressed_img.nbytescompression_ratio = original_size / compressed_sizeprint(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 图像压缩完整指南

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

评估压缩质量

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

均方误差(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 图像压缩完整指南

峰值信噪比(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 支持各种算法:

png 压缩:

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

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

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

这是我们的结果:

OpenCV 图像压缩完整指南

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

webp 压缩:

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

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

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

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

这是我们的结果:

OpenCV 图像压缩完整指南

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

结论

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

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

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

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

以上就是OpenCV 图像压缩完整指南的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1349373.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
**如何让你的 React 应用程序更安全:综合指南**
上一篇 2025年12月13日 12:49:47
初学者如何开始使用 Django 序列化器
下一篇 2025年12月13日 12:49:59

相关推荐

  • Matplotlib 地图中多类型图例的创建与优化

    Matplotlib 地图中多类型图例的创建与优化Matplotlib 地图中多类型图例的创建与优化Matplotlib 地图中多类型图例的创建与优化Matplotlib 地图中多类型图例的创建与优化

    本教程旨在解决matplotlib地图可视化中,如何在一个图例中同时展示颜色块(如区域分类)和自定义标记(如特定兴趣点)的问题。文章详细介绍了当传统`patch`对象无法正确显示标记时,如何利用`matplotlib.lines.line2d`创建标记图例句柄,并将其与颜色块图例句柄合并,从而生成一…

    2026年5月10日 用户投稿
    100
  • 利用海象运算符简化条件赋值:Python教程与最佳实践

    本文旨在探讨Python中海象运算符(:=)在条件赋值场景下的应用。通过对比传统if/else语句与海象运算符,以及条件表达式,分析海象运算符在简化代码、提高可读性方面的优势与局限性。并通过具体示例,展示如何在列表推导式等场景下合理使用海象运算符,同时强调其潜在的复杂性及替代方案,帮助开发者更好地掌…

    2026年5月10日
    100
  • Debian syslog性能优化技巧有哪些

    提升Debian系统syslog (通常基于rsyslog)性能,关键在于精简配置和高效处理日志。以下策略能有效优化日志管理,提升系统整体性能: 精简配置,高效加载: 在rsyslog配置文件中,仅加载必要的输入、输出和解析模块。 使用全局指令设置日志级别和格式,避免不必要的处理。 自定义模板: 创…

    2026年5月10日
    000
  • RichHandler与Rich Progress集成:解决显示冲突的教程

    在使用rich库的`richhandler`进行日志输出并同时使用`progress`组件时,可能会遇到显示错乱或溢出问题。这通常是由于为`richhandler`和`progress`分别创建了独立的`console`实例导致的。解决方案是确保日志处理器和进度条组件共享同一个`console`实例…

    2026年5月10日
    000
  • 使用 Jupyter Notebook 进行探索性数据分析

    Jupyter Notebook通过单元格实现代码与Markdown结合,支持数据导入(pandas)、清洗(fillna)、探索(matplotlib/seaborn可视化)、统计分析(describe/corr)和特征工程,便于记录与分享分析过程。 Jupyter Notebook 是进行探索性…

    2026年5月10日
    000
  • Python命令怎样使用profile分析脚本性能 Python命令性能分析的基础教程

    使用Python的cProfile模块分析脚本性能最直接的方式是通过命令行执行python -m cProfile your_script.py,它会输出每个函数的调用次数、总耗时、累积耗时等关键指标,帮助定位性能瓶颈;为进一步分析,可将结果保存为文件python -m cProfile -o ou…

    2026年5月10日
    000
  • Python递归函数追踪与性能考量:以序列打印为例

    本文深入探讨了Python中一种递归打印序列元素的方法,并着重演示了如何通过引入缩进参数来有效追踪递归函数的执行流程和参数变化。通过实际代码示例,文章揭示了递归调用可能带来的潜在性能开销,特别是对调用栈空间的需求,以及Python默认递归深度限制可能导致的错误,为读者提供了理解和优化递归算法的实用见…

    2026年5月10日
    000
  • python中zip函数详解 python多序列压缩zip函数应用场景

    zip函数的应用场景包括:1) 同时遍历多个序列,2) 合并多个列表的数据,3) 数据分析和科学计算中的元素运算,4) 处理csv文件,5) 性能优化。zip函数是一个强大的工具,能够简化代码并提高处理多个序列时的效率。 在Python中,zip函数是一个非常有用的工具,它能够将多个可迭代对象打包成…

    2026年5月10日
    000
  • Python中怎样使用pymongo?

    在python中使用pymongo可以轻松地与mongodb数据库进行交互。1)安装pymongo:pip install pymongo。2)连接到mongodb:from pymongo import mongoclient; client = mongoclient(‘mongod…

    2026年5月10日
    000
  • Python 函数参数类型:如何使用可变参数和动态参数?

    python 中的参数类型:关键词参数、可变参数和动态参数 在 python 中,函数的参数可以分为以下几种类型: 关键词参数(kw)**:这些参数具有名称,并且在调用函数时明确指定。可变参数(*args):这些参数没有名称,允许函数接受任意数量的位置参数。它们将被收集到一个元组中。动态参数(kwa…

    2026年5月10日
    000
  • pycharm解析器怎么添加 解析器添加详细流程

    在pycharm中添加解析器的步骤包括:1) 打开pycharm并进入设置,2) 选择project interpreter,3) 点击齿轮图标并选择add,4) 选择解析器类型并配置路径,5) 点击ok完成添加。添加解析器后,选择合适的类型和版本,配置环境变量,并利用解析器的功能提高开发效率。 在…

    2026年5月10日
    000
  • python中numpy的用法

    NumPy是Python中用于科学计算的强大库,它提供了以下功能:多维数组处理矩阵运算快速傅里叶变换(FFT)线性代数随机数生成 NumPy在Python中的强大功能 NumPy是Python中用于科学计算的一个强大且灵活的库。它提供了用于处理多维数组和矩阵的一组高效工具,是数据分析和机器学习项目的…

    2026年5月10日
    100
  • python如何捕获所有类型的异常_python try except捕获所有异常的方法

    答案:捕获所有异常推荐使用except Exception as e,可捕获常规错误并记录日志,避免影响程序正常退出;需拦截系统信号时才用except BaseException as e。 在Python中,要捕获所有类型的异常,最常见且推荐的方法是使用 except Exception as e…

    2026年5月10日
    000
  • python中f怎么用

    f-字符串是 Python 3.6 中引入的格式化字符串语法糖,提供了简洁且安全的方式来插入表达式和变量。f-字符串以字符串前缀 f 为标志,使用大括号包含表达式或变量。f-字符串支持条件表达式和格式规范符,提供了更大的灵活性、安全性、可读性和易维护性。 在 Python 中使用 f-字符串 f-字…

    2026年5月10日
    100
  • 怎么在手机上把XML文件转换为PDF?

    不可能直接在手机上用单一应用完成 XML 到 PDF 的转换。需要使用云端服务,通过两步走的方式实现:1. 在云端转换 XML 为 PDF,2. 在手机端访问或下载转换后的 PDF 文件。 怎么在手机上把XML文件转换为PDF? 这问题问得好,比直接问“怎么转换”有深度多了!因为它触及了移动端环境的…

    2026年5月10日
    000
  • ReCAPTCHA V3低分处理策略:结合V3与V2实现智能风险控制与用户验证

    本文旨在解决ReCAPTCHA V3在低分情况下无法直接触发验证码挑战的问题。我们将探讨如何通过巧妙地结合ReCAPTCHA V3的无感评分机制与ReCAPTCHA V2的交互式挑战,实现一套既能有效阻挡机器人流量,又能最大限度减少对合法用户干扰的智能验证系统。文章将详细阐述其实现原理、前端与后端集…

    2026年5月10日
    100
  • Python正则表达式:处理数字不同情况的替换

    本文旨在帮助读者理解和解决在使用Python正则表达式进行数字替换时遇到的问题。通过具体示例,详细解释了如何正确匹配和替换不同格式的数字,避免常见的匹配陷阱,并提供可直接使用的代码示例。掌握这些技巧,能有效提高处理文本数据的效率和准确性。 在使用Python的re模块进行字符串替换时,正则表达式的编…

    2026年5月10日
    000
  • python的tuple什么意思

    元组是Python中一种有序、不可变的序列数据结构。用于存储相关数据,例如坐标、个人信息或枚举值。创建方式:圆括号(),元素以逗号,分隔。访问元素:索引运算符;遍历元素:for循环。 什么是Python中的Tuple? Tuple,中文称为元组,是Python中一种有序、不可变的序列数据结构。 特点…

    2026年5月10日
    000
  • Python官网用户调查的参与方式_Python官网反馈提交详细教程

    答案是通过访问Python官网新闻页面、邮件邀请链接或GitHub仓库提交反馈。具体为:访问官网查找用户调查公告,或点击邮件中的专属链接参与,在GitHub的cpython仓库提交技术建议,并注意如实填写问卷与保护隐私。 如果您希望参与Python官网的用户调查并提交反馈,可以通过官方指定的渠道完成…

    2026年5月10日
    000
  • 我有时使用 awk 而不是 Python 的四个原因

    Python 是一门强大的编程语言,但在某些特定场景下,Awk 的优势更为显著,尤其体现在可移植性、生命周期、代码简洁性和与其他工具的互操作性方面。 Python 脚本通常具有良好的可移植性,但并非总能在所有环境中完美运行,例如流行的 Docker 基础镜像 (如 Debian 和 Alpine)。…

    2026年5月10日
    000

发表回复

登录后才能评论
关注微信