当前位置: 首页 > news >正文

Python数字图像处理:直方图均衡化

直方图均衡化(Histogram Equalization)是一种通过调整图像灰度分布来增强图像对比度的经典方法,尤其在处理低对比度或光照不均匀的图像时效果显著。本文深入解析其数学原理,并提供手动实现OpenCV优化方案的完整代码,结合实际应用场景展示其核心价值。

1. 直方图均衡化原理

(1) 核心目标
  • 问题:图像灰度集中在狭窄范围 → 细节模糊。
  • 解决方案:将原始直方图变换为均匀分布,扩展动态范围。
(2) 数学推导
  1. 概率密度函数(PDF)
    统计各灰度级频数:

  1. 累积分布函数(CDF)

映射到新的灰度级,使新直方图接近均匀分布。

2. 手动实现直方图均衡化

(2.1) 灰度图像处理
import cv2
import numpy as np
import matplotlib.pyplot as plt

# 解决中文显示问题
plt.rcParams['font.sans-serif'] = ['SimHei']  # 设置字体为黑体
plt.rcParams['axes.unicode_minus'] = False  # 解决负号显示问题

def manual_hist_equalize(image):
    if len(image.shape) == 3:
        image = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)
    hist = cv2.calcHist([image], [0], None, [256], [0, 256])
    hist_norm = hist.ravel() / hist.sum()  # 归一化得到PDF
    cdf = hist_norm.cumsum()               # 计算CDF
    cdf_normalized = (cdf * 255).astype(np.uint8)  # 线性映射到0-255
    return cdf_normalized[image]  # 应用映射

# 使用示例
img = cv2.imread('5.bmp', cv2.IMREAD_GRAYSCALE)

if img is None:
    print("错误:无法加载图像,请检查文件路径。")
else:
    equalized_manual = manual_hist_equalize(img)

    # 显示原始图像和直方图均衡化后的图像
    plt.figure(figsize=(10, 5))

    plt.subplot(1, 2, 1)
    plt.title('原始图像')  # 中文标题
    plt.imshow(img, cmap='gray')

    plt.subplot(1, 2, 2)
    plt.title('手动直方图均衡化图像')  # 中文标题
    plt.imshow(equalized_manual, cmap='gray')

    plt.show()

(2.2) 关键步骤解析
步骤功能代码实现
统计直方图计算各灰度级像素数量cv2.calcHist
归一化PDF转换为概率分布hist_norm = hist / total
计算CDF累加概率密度,生成映射函数cdf = np.cumsum(hist_norm)
应用映射将原图灰度替换为CDF对应值equalized = cdf[original]

3. OpenCV高效实现

import cv2
import numpy as np
import matplotlib.pyplot as plt

# 解决中文显示问题
plt.rcParams['font.sans-serif'] = ['SimHei']  # 设置字体为黑体
plt.rcParams['axes.unicode_minus'] = False  # 解决负号显示问题

# 灰度图直方图均衡化
def gray_hist_equalize(image):
    if len(image.shape) == 3:
        image = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)
    equalized = cv2.equalizeHist(image)
    return equalized

# 彩色图直方图均衡化
def color_hist_equalize(image):
    # 将图像转换为 YCrCb 色彩空间
    ycrcb = cv2.cvtColor(image, cv2.COLOR_BGR2YCrCb)
    # 对 Y 通道进行直方图均衡化
    ycrcb[:, :, 0] = cv2.equalizeHist(ycrcb[:, :, 0])
    # 转换回 BGR 色彩空间
    equalized = cv2.cvtColor(ycrcb, cv2.COLOR_YCrCb2BGR)
    return equalized

# 加载图像
img = cv2.imread('5.bmp')

if img is None:
    print("错误:无法加载图像,请检查文件路径。")
else:
    # 灰度图处理
    gray_img = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
    gray_equalized = gray_hist_equalize(img)

    # 彩色图处理
    color_equalized = color_hist_equalize(img)

    # 将 BGR 图像转换为 RGB 图像(matplotlib 使用 RGB 格式)
    img_rgb = cv2.cvtColor(img, cv2.COLOR_BGR2RGB)
    color_equalized_rgb = cv2.cvtColor(color_equalized, cv2.COLOR_BGR2RGB)

    # 使用 matplotlib 显示图像
    plt.figure(figsize=(15, 10))

    # 显示原始图像
    plt.subplot(2, 2, 1)
    plt.imshow(img_rgb)
    plt.title('原始彩色图像')
    plt.axis('off')

    # 显示原始灰度图像
    plt.subplot(2, 2, 2)
    plt.imshow(gray_img, cmap='gray')
    plt.title('原始灰度图像')
    plt.axis('off')

    # 显示灰度直方图均衡化图像
    plt.subplot(2, 2, 4)
    plt.imshow(gray_equalized, cmap='gray')
    plt.title('灰度直方图均衡化图像')
    plt.axis('off')

    # 显示彩色直方图均衡化图像
    plt.subplot(2, 2, 3)
    plt.imshow(color_equalized_rgb)
    plt.title('彩色直方图均衡化图像')
    plt.axis('off')

    # 显示图像
    plt.tight_layout()
    plt.show()
http://www.dtcms.com/a/43466.html

相关文章:

  • 歌曲分类和流行度预测
  • 需求和开发模型
  • 旁挂组网双机热备负载分担
  • ubuntu离线安装nvidia-container-runtime
  • c++信息学第一阶段练习题
  • 在 MySQL 中,删除数据库和表后,自动递增的值通常会被重置为初始值,一般是 1。但如果自动递增不为零,可能有以下原因及解决办法:
  • 深入探索Python机器学习算法:监督学习(线性回归,逻辑回归,决策树与随机森林,支持向量机,K近邻算法)
  • IO和NIO
  • 每日学习Java之一万个为什么?[MySQL面试篇]
  • OAK相机的抗震性测试
  • BIM模型+GIS信息的融合加载(纯Threejs方案)
  • 【AI-41】网格搜索和随机搜索相结合的策略
  • ⭐算法OJ⭐位操作实战【计数】(C++ 实现)
  • 深度学习-9.简单循环神经网络
  • YOLOv5 + SE注意力机制:提升目标检测性能的实践
  • Distilling the Knowledge in a Neural Network(提炼神经网络中的知识)
  • 15.13 AdaLoRA自适应权重矩阵微调:动态秩调整的智能革命
  • 双机热备旁挂组网实验
  • < 自用文儿 > Gobuster 暴力扫描工具与 SecLists 安全测试词表集合
  • VMware虚拟机配置桥接网络
  • 【前端基础】Day 5 CSS浮动
  • 力扣——颜色分类
  • 【prometheus】Pushgateway安装和使用
  • QT——c++界面编程库
  • yolov8,yolo11,yolo12 服务器训练到部署全流程 笔记
  • 鸿蒙ArkTs开发,后台触发数据变化后更新页面 UI事件
  • 【折线图 Line】——1
  • 影刀RPA中级案例总结
  • 运维Apache面试题及参考答案
  • 17 款电脑压缩工具详解及下载指南(2025 年最新版)