OpenCV直方图与直方图均衡化
一、图像直方图基础
1. 什么是图像直方图?
图像直方图是图像处理中最基本且重要的统计工具之一,它用图形化的方式表示图像中像素强度的分布情况。对于数字图像,直方图描述了每个可能的像素强度值(0-255)在图像中出现的频率。
直方图能够直观地展示图像的:
- 对比度
- 亮度分布
- 动态范围
- 颜色分布(对于彩色图像)
2. 直方图的重要性
直方图分析在图像处理中有广泛应用:
- 图像增强
- 图像分割
- 目标检测
- 颜色校正
- 图像质量评估
二、OpenCV中的直方图计算
OpenCV提供了cv2.calcHist()
函数来计算直方图,下面我们详细介绍其使用方法。
1. 基本直方图计算
import cv2
import numpy as np
from matplotlib import pyplot as plt# 读取图像
img = cv2.imread('image.jpg', 0) # 以灰度模式读取# 计算直方图
hist = cv2.calcHist([img], [0], None, [256], [0, 256])# 使用Matplotlib显示直方图
plt.figure()
plt.title("Grayscale Histogram")
plt.xlabel("Bins")
plt.ylabel("# of Pixels")
plt.plot(hist)
plt.xlim([0, 256])
plt.show()
2. 彩色图像直方图
img = cv2.imread('image.jpg')# 分离颜色通道
channels = cv2.split(img)
colors = ('b', 'g', 'r')plt.figure()
plt.title("Color Histogram")
plt.xlabel("Bins")
plt.ylabel("# of Pixels")# 计算并绘制每个通道的直方图
for (chan, color) in zip(channels, colors):hist = cv2.calcHist([chan], [0], None, [256], [0, 256])plt.plot(hist, color=color)plt.xlim([0, 256])plt.show()
3. 直方图参数详解
cv2.calcHist()
函数参数说明:
images
:输入图像列表(用方括号括起来)channels
:要计算直方图的通道索引mask
:可选掩模,只计算掩模区域的直方图histSize
:直方图的bin数量ranges
:像素值范围
三、直方图均衡化
1. 为什么需要直方图均衡化?
当图像直方图分布不均匀时(如集中在某一段),图像可能会显得过亮、过暗或对比度不足。直方图均衡化通过重新分配像素强度值,使直方图均匀分布在整个范围内,从而增强图像对比度。
2. 直方图均衡化原理
直方图均衡化的数学基础是:
- 计算原始图像的累积分布函数(CDF)
- 将CDF映射到新的强度值
- 重新分配像素值
3. OpenCV实现
全局直方图均衡化
# 读取灰度图像
img = cv2.imread('low_contrast.jpg', 0)# 直方图均衡化
equ = cv2.equalizeHist(img)# 显示结果
cv2.imshow('Original', img)
cv2.imshow('Equalized', equ)
cv2.waitKey(0)
cv2.destroyAllWindows()# 比较直方图
plt.figure(figsize=(10, 5))plt.subplot(121)
plt.hist(img.ravel(), 256, [0, 256])
plt.title('Original Histogram')plt.subplot(122)
plt.hist(equ.ravel(), 256, [0, 256])
plt.title('Equalized Histogram')plt.show()
自适应直方图均衡化(CLAHE)
全局直方图均衡化可能会过度增强噪声,CLAHE(对比度受限自适应直方图均衡化)通过将图像分成小块并分别均衡化来解决这个问题。
# 创建CLAHE对象
clahe = cv2.createCLAHE(clipLimit=2.0, tileGridSize=(8, 8))# 应用CLAHE
cl1 = clahe.apply(img)# 显示结果
cv2.imshow('Original', img)
cv2.imshow('CLAHE', cl1)
cv2.waitKey(0)
cv2.destroyAllWindows()
参数说明:
clipLimit
:对比度限制阈值tileGridSize
:图像分块大小
四、直方图比较
OpenCV提供了cv2.compareHist()
函数来比较两个直方图的相似度,常用于图像匹配。
1. 直方图比较方法
OpenCV支持四种比较方法:
- 相关性(CV_COMP_CORREL)
- 卡方(CV_COMP_CHISQR)
- 直方图相交(CV_COMP_INTERSECT)
- 巴氏距离(CV_COMP_BHATTACHARYYA)
2. 实现示例
# 读取两张图像
img1 = cv2.imread('image1.jpg', 0)
img2 = cv2.imread('image2.jpg', 0)# 计算直方图
hist1 = cv2.calcHist([img1], [0], None, [256], [0, 256])
hist2 = cv2.calcHist([img2], [0], None, [256], [0, 256])# 归一化直方图
hist1 = cv2.normalize(hist1, hist1).flatten()
hist2 = cv2.normalize(hist2, hist2).flatten()# 比较直方图
methods = [("Correlation", cv2.HISTCMP_CORREL),("Chi-Squared", cv2.HISTCMP_CHISQR),("Intersection", cv2.HISTCMP_INTERSECT),("Bhattacharyya", cv2.HISTCMP_BHATTACHARYYA)
]for (name, method) in methods:result = cv2.compareHist(hist1, hist2, method)print(f"{name}: {result}")
五、实际应用案例
1. 图像增强
def enhance_image(image_path):# 读取图像img = cv2.imread(image_path, 0)# CLAHE增强clahe = cv2.createCLAHE(clipLimit=2.0, tileGridSize=(8, 8))enhanced = clahe.apply(img)# 显示结果plt.figure(figsize=(10, 5))plt.subplot(121)plt.imshow(img, cmap='gray')plt.title('Original')plt.subplot(122)plt.imshow(enhanced, cmap='gray')plt.title('Enhanced')plt.show()return enhanced
2. 基于直方图的图像检索
def image_search(query_img_path, dataset_dir, top_k=5):# 读取查询图像query_img = cv2.imread(query_img_path, 0)query_hist = cv2.calcHist([query_img], [0], None, [256], [0, 256])query_hist = cv2.normalize(query_hist, query_hist).flatten()# 初始化结果列表results = []# 遍历数据集for image_name in os.listdir(dataset_dir):image_path = os.path.join(dataset_dir, image_name)image = cv2.imread(image_path, 0)# 计算直方图并比较hist = cv2.calcHist([image], [0], None, [256], [0, 256])hist = cv2.normalize(hist, hist).flatten()distance = cv2.compareHist(query_hist, hist, cv2.HISTCMP_CORREL)results.append((image_name, distance))# 按相似度排序results.sort(key=lambda x: x[1], reverse=True)return results[:top_k]
六、性能优化与注意事项
-
直方图bin数量:bin数量越多,直方图越精确,但计算量也越大。一般256个bin足够用于8位图像。
-
直方图归一化:在比较直方图前,务必进行归一化处理,消除图像大小的影响。
-
彩色图像处理:对于彩色图像,可以分别处理每个通道,或转换为HSV等颜色空间后再处理。
-
CLAHE参数调整:
clipLimit
和tileGridSize
需要根据具体图像调整,过大可能导致过度增强,过小则效果不明显。 -
内存考虑:处理高分辨率图像时,直方图计算可能消耗较多内存,可以考虑降低bin数量或缩小图像。
七、总结
直方图是图像处理中最基础也最强大的工具之一。通过本文的学习,你应该已经掌握了:
- 如何计算和可视化图像直方图
- 直方图均衡化的原理与实现
- CLAHE自适应均衡化技术
- 直方图比较方法及应用
- 实际应用案例
直方图分析为图像处理提供了量化的评估手段,而直方图均衡化则是改善图像质量的有效方法。掌握这些技术将为你的计算机视觉项目奠定坚实基础。
相关文章:
OpenCV直方图与直方图均衡化
一、图像直方图基础 1. 什么是图像直方图? 图像直方图是图像处理中最基本且重要的统计工具之一,它用图形化的方式表示图像中像素强度的分布情况。对于数字图像,直方图描述了每个可能的像素强度值(0-255)在图像中出现…...
7-15 计算圆周率
π131352!3573!⋯357⋯(2n1)n!⋯ 输入格式: 输入在一行中给出小于1的阈值。 输出格式: 在一行中输出满足阈值条件的近似圆周率,输出到小数点后6位。 输入样例: 0.01输出样例: 3.132157 我的代码 #i…...
Mosaic数据增强技术
Mosaic 数据增强技术是一种在计算机视觉领域广泛应用的数据增强方法。下面是Mosaic 数据增强技术原理的详细介绍 一、原理 Mosaic 数据增强是将多张图像(通常是 4 张)按照一定的规则拼接在一起,形成一张新的图像。在拼接过程中,会…...

GpuGeek 网络加速:破解 AI 开发中的 “最后一公里” 瓶颈
摘要: 网络延迟在AI开发中常被忽视,却严重影响效率。GpuGeek通过技术创新,提供学术资源访问和跨国数据交互的加速服务,助力开发者突破瓶颈。 目录 一、引言:当算力不再稀缺,网络瓶颈如何破局? …...
Sigmoid与Softmax:从二分类到多分类的深度解析
Sigmoid与Softmax:从二分类到多分类的深度解析 联系 函数性质:二者都是非线性函数 ,也都是指数归一化函数,可将输入值映射为0到1之间的实数 ,都能把输出转化成概率分布的形式,在神经网络中常作为激活函数使用。Softmax是Sigmoid的推广:从功能角度看,Softmax函数可视为…...
容器编排利器-k8s入门指南
Kubernetes(K8s)入门指南:容器编排利器 什么是 Kubernetes? Kubernetes(常简称为K8s)是一个开源的容器编排平台,由 Google 开源并交由云原生计算基金会(CNCF)管理。它可以帮助我们自动化部署、扩展和管理容器化应用程序。 为什么需要 Kubernetes? 在微服务架构盛行的今…...

C# DataGridView 选中所有复选框
问题描述 在程序中尝试选中所有复选框,但出现错误。如果单击顶部的完整选中/释放复选框,同时选中包含复选框的列,则选定区域不会改变。该如何解决? 上面的图片是点击完整版本之后的。 下面是本文的测试代码,函数 dat…...
C#学习第23天:面向对象设计模式
什么是设计模式? 定义:设计模式是软件开发中反复出现的特定问题的解决方案。它们提供了问题的抽象描述和解决方案。目的:通过提供成熟的解决方案,设计模式可以加快开发速度并提高代码质量。 常见的设计模式 设计模式通常分为三大…...
LineBasicMaterial
LineBasicMaterial 描述 用于绘制纯色线条的基础材质,支持颜色、线宽和纹理映射。常用于THREE.Line或THREE.LineSegments几何体。 构造函数 (Constructor) 构造函数参数描述LineBasicMaterial(parameters?: Object)parameters定义材质外观的对象,可…...

AB Download Manager v1.5.8 开源免费下载工具
下载文件是我们日常工作和生活中经常进行的操作。面对动辄数十GB的4K影片、设计素材包或开发工具,传统浏览器的单线程下载如同"涓涓细流",非常影响我们的效率和体验。 那么,一款高效且易用的下载工具至关重要。今天就让我们解锁这…...
react-native中createContext的使用
在 React Native 中,createContext 是一个非常强大的工具,用于在组件树中共享状态,避免了逐层传递 props 的繁琐。以下是对 createContext 的详细解释以及一个完整的示例。 详细解释 createContext 是 React 提供的一个函数,用于…...

深度剖析:Dify+Sanic+Vue+ECharts 搭建 Text2SQL 项目 sanic-web 的 Debug 实战
目录 项目背景介绍sanic-web Dify\_service handle\_think\_tag报错NoneType问题描述debug Dify调用不成功,一直转圈圈问题描述debug 前端markdown格式只显示前5页问题描述debug1. 修改代码2.重新构建1.1.3镜像3.更新sanic-web/docker/docker-compose.yaml4. 重新部…...

学习51单片机02
吐血了,板子今天才到,下午才刚开始学的,生气了,害我笔记都断更了一天。。。。 紧接上文...... 如何将HEX程序烧写到程序? Tips:HEX 文件是一种常用于单片机等嵌入式系统的文件格式,它包含了程序的机器码…...

麒麟服务器操作系统安装 MySQL 8 实战指南
往期好文连接:统信UOS/麒麟KYLINOS安装JDBC驱动包 Hello,大家好啊,今天给大家带来一篇麒麟服务器操作系统上安装 MySQL 8 的文章,欢迎大家分享点赞,点个在看和关注吧!MySQL 作为主流开源数据库之一&#x…...

AWS EC2 微服务 金丝雀发布(Canary Release)方案
为什么需要实现金丝雀发布? 在当前项目的工程实践中, 已经有了充分的单元测试, 预发布环境测试, 但是还是会在线上环境出现非预期的情况, 导致线上事故, 因此, 为了提升服务质量, 需要线上能够有一个预验证的机制. 如何实现金丝雀发布? 使用AWS code deploy方案 AWS code…...
力扣-78.子集
给你一个整数数组 nums ,数组中的元素 互不相同 。返回该数组所有可能的子集(幂集)。 解集 不能 包含重复的子集。你可以按 任意顺序 返回解集。 class Solution {List<List<Integer>> res new ArrayList<>();List<I…...

支持蓝牙5.0和2.4G私有协议芯片-PHY6222
PHY6222QC-W04C 是一款适用于蓝牙低功耗(BLE)5.2 应用的片上系统(SoC)。它搭载 ARM Cortex™-M0 32 位处理器,配备 64KB SRAM、512K Flash、96KB ROM、256 bit efuse ,以及超低功耗、高性能的多模式射频模块…...
Jenkins的流水线执行shell脚本执行jar命令后项目未启动未输出日志问题处理
现象 在流水线里配置了启动脚本例如,nohup java -jar xxx.jar >nohup.out 2>&1 & 但是在服务器发现服务并未启动,且nohup日志里没输出日志,这样的原因是jenkins在执行完脚本后,就退出了这个进程。 解决 在启动脚本执行jar命令的上一步…...
在 Visual Studio Code (VSCode) 中配置 MCP(Model Context Protocol)
前提条件 安装 VSCode:确保已安装最新版本的 VSCode(建议使用 1.99 或以上版本,支持 MCP)。安装 GitHub Copilot 扩展:MCP 通常与 GitHub Copilot 的代理模式(Agent Mode)结合使用,…...

图像锐化调整
一、背景介绍 之前找多尺度做对比度增强时候,发现了一些锐化相关算法,正好本来也要整理锐化,这里就直接顺手对之前做过的锐化大概整理了下,方便后续用的时候直接抓了。 这里整理的锐化主要是两块:一个是参考论文&#…...
我设计的一个安全的 web 系统用户密码管理流程
作为一名有多年经验的前端,在刚开始学习web后端的时候,就对如何设计一个安全的 web 系统用户密码管理流程有很多疑问。之前自己也实践过几种方法,但一直觉得不是十分安全。 我们知道,用户在注册或登录界面填写的密码是明文的&…...
Vue.js---计算属性computed和lazy
4.6 计算属性computed和lazy 懒执行的effect:一般的effect一下子就执行了,但是懒加载effect是等需要的时候才会执行 这时我们通过在options中添加lazy属性来达到目的 function effect (fn , options {}) {const effectFn () > {// 调用clearup函数…...

找客户的app
找客户的 app 在竞争激烈的商业环境中,找客户的 APP 成为企业拓展业务的利器。 微拓客 APP,集智能获客、营销素材、客户管理于一体。支持关键词、附近客源等多方式采集,覆盖 300 行业;一键采集客源,一键导出到通讯录…...
HarmonyOS学习
个人简介 👨💻个人主页: 魔术师 📖学习方向: 主攻前端方向,正逐渐往全栈发展 🚴个人状态: 研发工程师,现效力于政务服务网事业 🇨🇳人生格言&…...

金融合规革命:R²AIN SUITE 如何重塑银行业务智能
一、市场发展背景与核心驱动因素 信息过载:单家银行年均新增监管文件大量增加,人工解读效率极低。 客户体验升级:高净值客户期待“724小时专业级响应”,但客户经理难以实时掌握数百款产品动态。 风险防控:传…...
Spring 框架核心机制深度解析【AI模型互搏生成】
Spring 框架核心机制深度解析(玩转开源代码) 一、Bean 生命周期全流程剖析 1.1 核心生命周期阶段 以下是 Spring Bean 生命周期核心阶段的配图,结合实际流程图示清晰展现每一步执行顺序及扩展点挂载位置。 🧬Spring Bean 生命周…...
Linux信号的保存
Linux系统中信号的保存涉及内核为每个进程维护的数据结构,确保信号在产生后、处理前被正确记录和管理。以下是详细的解释: 1. 信号的基本概念 信号(Signal):用于通知进程发生了特定事件的异步通知机制,如…...

论文阅读:Self-Collaboration Code Generation via ChatGPT
地址:Self-Collaboration Code Generation via ChatGPT 摘要 尽管大型语言模型(LLMs)在代码生成能力方面表现出色,但在处理复杂任务时仍存在挑战。在现实软件开发中,人类通常通过团队协作来应对复杂任务,…...

2025年PMP 学习十五 第10章 项目资源管理
2025年PMP 学习十五 第10章 项目资源管理 序号过程过程组1规划沟通管理规划2管理沟通执行3监控沟通监控 项目沟通管理包括为确保项目的信 息及时且恰当地规划、收集、生成、发布、存储、检索、管理、控制、监 警和最终处理所需的过程; 项目经理绝大多数时间都用于与…...

如何使用易路iBuilder智能体平台快速安全深入实现AI HR【实用帖】
随着企业组织经营对降本、增效、提质的需求日益迫切,越来越多企业启动人力资源数智化转型战略。而在AI战略实际推进过程中,企业组织往往在选型、搭建、使用、管控等问题上面临困惑: 如何快速、低成本接入AI能力,实现人力资源管理…...