局部直方图均衡化去雾算法

目录

[1. 引言](#1. 引言)

[2. 算法流程](#2. 算法流程)

[3. 代码](#3. 代码)

[4. 去雾效果](#4. 去雾效果)


1. 引言

局部直方图算法是一种基于块的图像去雾方法,它将图像分割为若干个块,并在每个块内计算块的局部直方图。通过对各个块的直方图进行分析和处理,该算法能够更好地适应图像中不同区域的光度差异和雾霾密度变化,从而提高去雾效果。然而,局部直方图算法在处理边缘区域和细节丰富的区域时存在一定的挑战,容易导致边缘锐化和细节损失。

局部直方图算法是在全局直方图算法的基础上进行改进而成的。该算法通过将图像划分为多个局部区域,并对每个局部区域进行直方图分析,从而实现对图像的局部去雾处理。与全局直方图算法相比,局部直方图算法更能够保留图像的细节信息,并在复杂场景下取得更好的去雾效果。但该算法的计算复杂度相对较高,对计算资源的要求也较大。

2. 算法流程

1.首先,将原始图像划分为多个重春的滑动窗口,窗口的尺寸可以根据需要进行选择。

2.对于每个窗口,分别对其RGB通道进行直方图均衡化,通过增加像素值的分布范围来增强图像的对比度。

3.将经过局部直方图均衡化处理后的每个窗口重新整合到新的图像中,得到一张经过局部直方图均衡化去雾处理后的图像。

3. 代码

python 复制代码
import cv2
import numpy as np


def clahe_dehaze(img, clip_limit=2.0, tile_grid_size=(8, 8)):
    # 转换为YCrCb色彩空间
    ycrcb = cv2.cvtColor(img, cv2.COLOR_BGR2YCrCb)
    # 分离通道
    channels = list(cv2.split(ycrcb))
    # 创建CLAHE对象
    clahe = cv2.createCLAHE(clipLimit=clip_limit, tileGridSize=tile_grid_size)
    # 对Y通道进行CLAHE
    channels[0] = clahe.apply(channels[0])
    # 合并通道
    ycrcb = cv2.merge(channels)
    # 转换回BGR色彩空间
    result = cv2.cvtColor(ycrcb, cv2.COLOR_YCrCb2BGR)
    return result

# 读取图像
im = cv2.imread('xue_foggy.png')
if im is None:
    raise FileNotFoundError("The image file was not found. Please check the path.")

# 使用CLAHE进行图像去雾
eq = clahe_dehaze(im)

# 显示原始图像和处理后的图像
cv2.imshow('Original Image', im)
cv2.imshow('CLAHE Dehazed Image', eq)
cv2.waitKey(0)
cv2.destroyAllWindows()

# 保存处理后的图像
cv2.imwrite('img_clahe_dehazed.png', eq)

4. 去雾效果

从效果对比图看出局部直方图均衡化算法可以显著改善雾天图像的对比度,提升视觉效果。通过对图像的局部区域应用直方图均衡化,能够有效处理不同区域的对比度变化。

相关推荐
jonyleek9 分钟前
如何搭建一套安全的,企业级本地AI专属知识库系统?从安装系统到构建知识体系,全流程!
人工智能·安全
小蒋的技术栈记录31 分钟前
网易大模型算法岗面经80道
算法
MQ_SOFTWARE43 分钟前
AI驱动的金融推理:Fin-R1模型如何重塑行业决策逻辑
人工智能·金融
Ress Matthew1 小时前
重塑优化建模与算法设计:2025年大模型(LLM)在优化领域的应用盘点 - 2
算法
找不到、了1 小时前
Java排序算法之<插入排序>
java·算法·排序算法
@蓝莓果粒茶1 小时前
LeetCode第350题_两个数组的交集II
c++·python·学习·算法·leetcode·职场和发展·c#
设计师小聂!1 小时前
力扣热题100----------53最大子数组和
java·数据结构·算法·leetcode
生医转码,四海为家1 小时前
零基础-动手学深度学习-6.6 卷积神经网络(LeNet)
人工智能·深度学习·cnn
无名工程师1 小时前
AI 学习过程中各阶段的学习重点、时间规划以及不同方向的选择与建议等内容
人工智能·学习
WXX_s2 小时前
【OpenCV篇】OpenCV——03day.图像预处理(2)
人工智能·python·opencv·学习·计算机视觉