【python】OpenCV—Histogram Matching(9.2)

2024-06-10 09:52

本文主要是介绍【python】OpenCV—Histogram Matching(9.2),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在这里插入图片描述

学习来自OpenCV基础(17)基于OpenCV、scikit-image和Python的直方图匹配

文章目录

  • 直方图匹配介绍
  • scikit-image 中的直方图匹配
  • 小试牛刀
  • 风格迁移

直方图匹配介绍

直方图匹配(Histogram Matching)是一种图像处理技术,旨在将一张图像的像素值分布调整到与另一张图像的像素值分布相匹配。这种技术在图像增强、颜色校正等任务中非常有用。以下是关于直方图匹配的详细解释:

在这里插入图片描述

一、定义与原理

定义: 直方图匹配又称为直方图规定化,是一种通过调整图像的像素值分布,使两张图像的直方图尽可能相似的图像增强方法。

原理: 基于直方图变换,通过调整图像的像素值,使得两张图像的直方图在形状和分布上尽可能一致。这通常涉及到将输入图像的像素值映射到输出图像的像素值,以实现两者之间的分布匹配

二、一般步骤

计算累积分布函数(CDF): 首先,计算原始图像和目标图像的直方图的累积分布函数(CDF)。CDF表示了从最小值到当前值的像素数占总像素数的比例。

像素值映射: 根据累积分布函数的关系,将原始图像的像素值映射到目标直方图的像素值。这个映射过程是直方图匹配的关键步骤。

应用映射函数: 对原始图像的所有像素应用映射函数,得到匹配后的图像。

三、数学表示

假设我们有一个输入图像 I I I 和一个目标图像 T T T,我们希望将输入图像的像素值映射到输出图像的像素值。这可以表示为:

O ( x , y ) = round ( T I ⋅ I ( x , y ) ) O(x, y) = \text{round}\left(\frac{T}{I} \cdot I(x, y)\right) O(x,y)=round(ITI(x,y))

其中, O ( x , y ) O(x, y) O(x,y) 是输出图像中的像素值, I ( x , y ) I(x, y) I(x,y) 是输入图像中的像素值, T T T 是目标图像的像素值范围。函数 round \text{round} round 将结果四舍五入到最近的整数。

四、应用场景

图像增强: 当图像的对比度较低或细节不明显时,可以使用直方图匹配来增强图像的视觉效果。

颜色校正: 当图像受到光照条件的影响或者摄像设备的色彩偏差时,可以使用直方图匹配来校正颜色。

风格迁移: 在计算机视觉中,可以使用直方图匹配来实现图像的风格迁移,将一个图像的风格应用于另一个图像。

五、注意事项

在进行直方图匹配时,需要注意不同图像之间的直方图可能具有不同的范围和分布,因此需要进行适当的归一化和调整。

直方图匹配可能无法完全消除图像之间的差异,因为它仅考虑了像素值的分布,而忽略了像素之间的空间关系

对于某些特定的应用场景,可能需要结合其他图像处理技术来进一步提高匹配效果。

scikit-image 中的直方图匹配

skimage.exposure.match_histograms 是 scikit-image 库中用于直方图匹配的一个函数。该函数用于将一个图像的直方图与另一个图像的直方图相匹配,从而实现图像亮度和对比度的调整。以下是该函数的中文文档,包含其功能描述、参数说明和示例。

skimage.exposure.match_histograms

一、功能描述:

该函数将源图像的直方图与目标图像的直方图进行匹配,从而改变源图像的像素值,使其直方图与目标图像的直方图尽可能相似。这在图像处理中常用于增强图像的对比度或使不同图像之间的亮度和对比度更加一致。

二、参数说明:

source: ndarray 类型,输入图像,即需要进行直方图匹配的源图像。

template: ndarray 类型,目标图像,即源图像直方图要匹配的目标。

multichannel: bool 类型,可选参数,默认为 False。如果为 True,则对多通道图像进行独立匹配。这要求源图像和目标图像具有相同数量的通道。

三、返回值:

matched:ndarray 类型,与源图像形状相同的数组,其中包含了匹配后的像素值。

小试牛刀

from skimage import exposure
import matplotlib.pyplot as plt
import argparse
import cv2# 构造参数解析器并解析参数
ap = argparse.ArgumentParser()
ap.add_argument("-s", "--source", required=True, help="Path to the input source image")
ap.add_argument("-r", "--reference", required=True, help="Path to the input reference image")
args = vars(ap.parse_args())# 加载源和参考图像
print("[INFO] Loading source and reference images...")
src = cv2.imread(args["source"])
ref = cv2.imread(args["reference"])# 确定我们是否执行多通道直方图匹配,然后执行直方图匹配本身
print("[INFO] Performing histogram matching...")
multi = True if src.shape[-1] > 1 else Falsematched = exposure.match_histograms(src, ref, multichannel=multi)
# This was in skimage.transform between 0.14.2. It was moved to skimage.exposure with 0.16.0.# cv2.imwrite("matched.jpg", matched)# 显示输出图像
cv2.imshow("Source", src)
cv2.imshow("Reference", ref)
cv2.imshow("Matched", matched)
cv2.waitKey(0)# 构造一个图形来显示应用直方图匹配前后每个通道的直方图图
(fig, axs) = plt.subplots(nrows=3, ncols=3, figsize=(8, 8))# 循环遍历源图像、参考图像和输出匹配图像
for (i, image) in enumerate((src, ref, matched)):# 转换图像从BGR到RGB通道顺序image = cv2.cvtColor(image, cv2.COLOR_BGR2RGB)# 按RGB顺序循环通道名称for (j, color) in enumerate(("red", "green", "blue")):# 计算当前通道的直方图并绘制它(hist, bins) = exposure.histogram(image[..., j], source_range="dtype")axs[j, i].plot(bins, hist/hist.max())# 计算当前通道的累积分布函数并绘制它(cdf, bins) = exposure.cumulative_distribution(image[..., j])axs[j, i].plot(bins, cdf)# 将当前图形的y轴标签设置为当前颜色通道的名称axs[j, 0].set_ylabel(color)# 设置轴标题
axs[0, 0].set_title("Source")
axs[0, 1].set_title("Reference")
axs[0, 2].set_title("Matched")# 显示输出图
plt.tight_layout()
plt.show()

运行

python matching.py -s source.jpg -r reference.jpg

输入的 source.jpg

在这里插入图片描述

输入的 reference.jpg

在这里插入图片描述

直方图 matching 的结果

在这里插入图片描述

看看绘制的 RGB 三通道的直方图(蓝色)以及各自通道上的累积分布函数曲线(橙色)的绘制

请添加图片描述

风格迁移

看了小试牛刀,立刻想到了风格迁移,试试

source 图片还是蒙娜丽莎

在这里插入图片描述

reference 图片换成星空

在这里插入图片描述

看看匹配后的结果

在这里插入图片描述

看看RGB各通道的直方图和累积分布函数曲线

在这里插入图片描述

这篇关于【python】OpenCV—Histogram Matching(9.2)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


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

相关文章

一文全面详解Python变量作用域

《一文全面详解Python变量作用域》变量作用域是Python中非常重要的概念,它决定了在哪里可以访问变量,下面我将用通俗易懂的方式,结合代码示例和图表,带你全面了解Python变量作用域,需要的朋友... 目录一、什么是变量作用域?二、python的四种作用域作用域查找顺序图示三、各作用域详解1. 局部作

Python主动抛出异常的各种用法和场景分析

《Python主动抛出异常的各种用法和场景分析》在Python中,我们不仅可以捕获和处理异常,还可以主动抛出异常,也就是以类的方式自定义错误的类型和提示信息,这在编程中非常有用,下面我将详细解释主动抛... 目录一、为什么要主动抛出异常?二、基本语法:raise关键字基本示例三、raise的多种用法1. 抛

Python基于微信OCR引擎实现高效图片文字识别

《Python基于微信OCR引擎实现高效图片文字识别》这篇文章主要为大家详细介绍了一款基于微信OCR引擎的图片文字识别桌面应用开发全过程,可以实现从图片拖拽识别到文字提取,感兴趣的小伙伴可以跟随小编一... 目录一、项目概述1.1 开发背景1.2 技术选型1.3 核心优势二、功能详解2.1 核心功能模块2.

基于Python实现一个简单的题库与在线考试系统

《基于Python实现一个简单的题库与在线考试系统》在当今信息化教育时代,在线学习与考试系统已成为教育技术领域的重要组成部分,本文就来介绍一下如何使用Python和PyQt5框架开发一个名为白泽题库系... 目录概述功能特点界面展示系统架构设计类结构图Excel题库填写格式模板题库题目填写格式表核心数据结构

Python使用smtplib库开发一个邮件自动发送工具

《Python使用smtplib库开发一个邮件自动发送工具》在现代软件开发中,自动化邮件发送是一个非常实用的功能,无论是系统通知、营销邮件、还是日常工作报告,Python的smtplib库都能帮助我们... 目录代码实现与知识点解析1. 导入必要的库2. 配置邮件服务器参数3. 创建邮件发送类4. 实现邮件

基于Python构建一个高效词汇表

《基于Python构建一个高效词汇表》在自然语言处理(NLP)领域,构建高效的词汇表是文本预处理的关键步骤,本文将解析一个使用Python实现的n-gram词频统计工具,感兴趣的可以了解下... 目录一、项目背景与目标1.1 技术需求1.2 核心技术栈二、核心代码解析2.1 数据处理函数2.2 数据处理流程

Python远程控制MySQL的完整指南

《Python远程控制MySQL的完整指南》MySQL是最流行的关系型数据库之一,Python通过多种方式可以与MySQL进行交互,下面小编就为大家详细介绍一下Python操作MySQL的常用方法和最... 目录1. 准备工作2. 连接mysql数据库使用mysql-connector使用PyMySQL3.

使用Python实现base64字符串与图片互转的详细步骤

《使用Python实现base64字符串与图片互转的详细步骤》要将一个Base64编码的字符串转换为图片文件并保存下来,可以使用Python的base64模块来实现,这一过程包括解码Base64字符串... 目录1. 图片编码为 Base64 字符串2. Base64 字符串解码为图片文件3. 示例使用注意

使用Python实现获取屏幕像素颜色值

《使用Python实现获取屏幕像素颜色值》这篇文章主要为大家详细介绍了如何使用Python实现获取屏幕像素颜色值,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 一、一个小工具,按住F10键,颜色值会跟着显示。完整代码import tkinter as tkimport pyau

python编写朋克风格的天气查询程序

《python编写朋克风格的天气查询程序》这篇文章主要为大家详细介绍了一个基于Python的桌面应用程序,使用了tkinter库来创建图形用户界面并通过requests库调用Open-MeteoAPI... 目录工具介绍工具使用说明python脚本内容如何运行脚本工具介绍这个天气查询工具是一个基于 Pyt