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)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月13日 12:49:47
下一篇 2025年12月13日 12:49:59

相关推荐

  • 初学者如何开始使用 Django 序列化器

    如果您想了解程序员的终极谷物食品,其中 cocoa pebbles 是卫冕冠军?,那么您来对地方了。只是在开玩笑!今天我们将深入研究更好的东西:django serializers ?️ 它们会让你的数据处理比你最喜欢的谷物更顺畅!准备好应对了吗?我们走吧! ? 如果您一直致力于 django 开发…

    好文分享 2025年12月13日
    000
  • python爬虫入门教程 pdf python爬虫实战入门教程pdf下载步骤

    下载 Python 爬虫入门教程 PDF 步骤:在浏览器中搜索教程文件,例如 “python 爬虫入门教程 pdf”。选择一个网站,例如 TutorialsPoint。点击网站上的 “Download PDF” 按钮。选择保存文件的目标位置并点击 &#…

    2025年12月13日
    000
  • python爬虫实例教程PDF python网络爬虫实例教程pdf

    Python 网络爬虫实例教程 PDF 提供了一个分步指南,涵盖了以下步骤:理解网络爬取概念。安装和配置 Python 库(如 Requests)。获取 Web 页面并解析 HTML 响应(使用 BeautifulSoup)。导航 HTML 树结构并提取特定数据。处理常见的爬取问题(如重定向和错误)…

    2025年12月13日
    000
  • python3.4爬虫教程 pdf

    Python 3.4 爬虫教程 PDF 可从 [Python爬虫教程](https://morvanzhou.github.io/tutorials/scraping) 和 [电子工业出版社](https://www.ep.com.cn/product/4735/3611000009) 下载。教程内…

    2025年12月13日
    000
  • 使用scrapy爬虫视频教程

    使用 Scrapy 爬取视频教程指南:安装 Scrapy创建项目定义爬虫(提取视频链接)处理结果(存储提取的数据) 如何使用 Scrapy 爬虫视频教程 简介 Scrapy 是一款流行的 Python 爬虫框架,可用于从网页提取数据。本教程将指导你使用 Scrapy 爬取视频教程。 安装 Scrap…

    2025年12月13日
    000
  • python下载ftp文件进度条 python获取ftp上文件的下载进度条

    在 Python 中,可通过使用 FTPlib 模块的 retrbinary() 方法和回调函数实现 FTP 文件下载进度条:创建回调函数,计算下载进度并打印进度信息。在下载文件时,将回调函数作为 retrbinary() 方法的最后一个参数传递。回调函数将在下载过程中被调用,并提供已下载字节数、文…

    2025年12月13日
    000
  • python线程池下载进度条

    如何使用 Python 线程池实现文件下载进度条:创建线程池并设置最大工人数量;使用 tqdm 库初始化进度条并指定总进度;定义下载函数,下载文件并更新进度条;将下载任务提交给线程池;等待所有下载任务完成。 如何使用 Python 线程池实现文件下载进度条 引言使用线程池下载多个文件时,显示每个文件…

    2025年12月13日
    000
  • python线程池进度条下载 tqdm python下载进度条显示

    使用 Python 线程池可以加速下载任务,并行处理多个任务。具体实现步骤如下:创建线程池,管理多个线程并行处理任务。创建进度条,显示下载进度。使用线程池下载文件,并在任务中更新进度条。提交下载任务到线程池。等待所有任务完成。关闭进度条。 Python 线程池中的进度条下载 使用 Python 中的…

    2025年12月13日
    000
  • python 下载文件进度条 python3下载文件显示进度条

    要显示文件下载进度条,可以使用 requests 库和 tqdm 库:1. 安装所需库;2. 使用 requests 下载文件并计算总大小;3. 使用 tqdm 显示进度条,并按块大小更新。 如何在 Python 中显示文件下载进度条 直接回答:要显示文件下载进度条,可以使用 requests 库和…

    2025年12月13日
    000
  • python 文件下载进度条 Python下载进度条教程

    在 Python 中显示文件下载进度条可以使用 tqdm 库,具体步骤为:1. 安装 tqdm 库;2. 导入 tqdm 库;3. 设置进度条;4. 更新进度条;5. 完成下载。 如何在 Python 中显示文件下载进度条 开门见山:在 Python 中,可以使用 tqdm 库轻松实现文件下载进度条…

    2025年12月13日
    000
  • python制作下载进度条

    在 Python 中制作下载进度条,可以使用进度条库。步骤如下:安装进度条库:pip install progressbar。导入进度条模块:from progressbar import ProgressBar。创建进度条对象:progress_bar = ProgressBar()。设置进度条长…

    2025年12月13日
    000
  • python多线程拆分文件进度条

    使用 concurrent.futures 模块中的 ThreadPoolExecutor 可以轻松实现多线程文件拆分:计算每个 chunk 的大小。创建一个线程池。对于每个 chunk,创建一个拆分任务,并将其添加到 futures 列表中。获取每个任务的进度更新,并根据进度更新进度条。将每个 c…

    2025年12月13日
    000
  • python 多线程进度条如何并行

    Python 多线程可用来实现并行进度条。主要步骤包括:导入 threading 和 time 库;创建 ProgressBar 类管理进度条;创建线程函数 update_progress 不断更新进度条;创建并启动线程执行更新任务;在主线程中循环获取并显示进度。 如何使用 Python 多线程实现…

    2025年12月13日
    000
  • python多线程复制文件进度条 python多线程复制文件显示进度条

    要使用 Python 多线程复制文件并显示进度条:导入必要的库。定义复制文件函数。定义进度条函数。创建多线程。调用多线程函数。示例用法:src_dir = “源目录”dst_dir = “目标目录”copy_files(src_dir, dst_dir…

    2025年12月13日
    000
  • python多线程实现进度条

    如何使用 Python 多线程实现进度条?导入必要的模块。定义一个进度条函数。创建和启动一个线程来调用进度条函数。在主线程中运行需要跟踪进度的任务。等待线程结束。 如何使用 Python 多线程实现进度条 简介 多线程是一个强大的工具,可以用来提升代码的效率和响应能力。在 Python 中,我们可以…

    2025年12月13日
    000
  • Python多线程结合进度条

    Python 中结合多线程和进度条的实现方法如下:创建线程函数,执行耗时任务;创建新线程,将线程函数作为目标传递;使用第三方库创建进度条对象;在线程函数中定期更新进度条进度;启动线程。 Python 多线程结合进度条 如何实现? 在 Python 中,可以使用多线程结合进度条,以便在执行耗时任务的同…

    2025年12月13日
    000
  • 进度条Python解析 Python文本进度条解析

    Python 中使用 tqdm 库创建进度条:1. 安装 tqdm;2. 导入 tqdm;3. 创建进度条:tqdm.tqdm(范围, 描述);4. 自动更新进度条或手动更新(update());5. 自定义进度条外观和行为(unit、unit_scale、leave、ncols、position)…

    2025年12月13日
    000
  • python文本进度条代码解析 python文件进度条解析time

    在 Python 中实现文本进度条需要以下步骤:导入 time 模块以获取当前时间。设置进度条长度,并获取操作开始时间。循环进度条长度,计算进度百分比。使用 r 返回到行开头并打印格式化的进度条。强制刷新标准输出以显示进度条。模拟耗时的操作以代表实际处理过程。获取操作结束时间并打印完成信息,显示操作…

    2025年12月13日
    000
  • 进度条python插件 python插件进度条

    如何在 Python 中使用进度条插件?安装 tqdmpip install tqdm导入 tqdmimport tqdm创建进度条pbar = tqdm.tqdm(total=100)更新进度for i in range(100): pbar.update(1)关闭进度条pbar.close() …

    2025年12月13日
    000
  • 完整进度条python python完整进度条解析

    在 Python 中创建完整的进度条,步骤如下:导入 tqdm 库;使用 tqdm 类创建一个进度条,指定总任务数和进度条描述;通过更新进度条对象来反映任务进度;任务完成后关闭进度条。 如何在 Python 中创建完整进度条 在 Python 中创建完整的进度条可以帮助用户跟踪正在进行的任务的进度,…

    2025年12月13日
    000

发表回复

登录后才能评论
关注微信