![视觉大数据智能分析算法实战](https://wfqqreader-1252317822.image.myqcloud.com/cover/579/47216579/b_47216579.jpg)
2.2 雾天图像增强方法
2.2.1 全局直方图增强
图像直方图是对数字图像进行灰度分布的统计,可从分布曲线的视角反映出图像的整体灰度分布。例如,Uint8类型的数字图像矩阵,其默认的灰度级为0~28-1即0~255,在MATLAB中可通过imhist函数进行直接绘制,关键代码如下。
![](https://epubservercos.yuewen.com/31DDB8/26580980701213406/epubprivate/OEBPS/Images/Figure-P35_4824.jpg?sign=1739246225-LdIXho70xg7JjUf9o0FS2VbkbXBF0IVI-0-25db208f3c6b0364597e84b6a127c623)
运行后,可得到原图像及对应的直方图分布,分别如图2-1和图2-2所示。
![](https://epubservercos.yuewen.com/31DDB8/26580980701213406/epubprivate/OEBPS/Images/Figure-P36_4828.jpg?sign=1739246225-UQprq44wY2pi0bnI1JFweeqOwQeEzhCe-0-ee4430eff822b0e899322a70baadb4ee)
图2-1 原图像
![](https://epubservercos.yuewen.com/31DDB8/26580980701213406/epubprivate/OEBPS/Images/Figure-P36_4832.jpg?sign=1739246225-qA7M6jQzeqc76Dkvo57pMewfh4h1P7MT-0-9ed59ccb368a44c972f13a69704aa2bd)
图2-2 直方图分布
如图2-1所示,原图像整体呈现偏暗的特点,且存在部分细节模糊的情况。同时,从图2-2的直方图分布可以发现,图像的灰度总体集中在[75,150]的灰度范围内,这也正是图像整体偏暗的原因之一。本节通过调整图像的直方图来观察是否能改善图像的可视化效果,为此考虑进行直方图均衡化方法来调整图像整体的直方图分布,进而提高图像的整体清晰度。
直方图均衡化的基本思想是将原始的灰度统计直方图变换为均匀分布的形式,覆盖整体的灰度级提高图像整体的灰度范围,达到增强效果。假设某数字图像矩阵为f(x,y),像素总数为N,灰度级范围为[0,L],例如L=255表示Uint8类型的数字图像,令rk表示灰度级、nk表示此灰度级的像素个数,则直方图P(rk)计算公式为:
![](https://epubservercos.yuewen.com/31DDB8/26580980701213406/epubprivate/OEBPS/Images/Figure-P36_5092.jpg?sign=1739246225-46fwCwxyAhPeCjrqNtwF1LbB2Smtx2Dx-0-083085c0342cac5ef1353729e6d627c6)
直方图均衡化是指对原图像经图像变换得到新的灰度图像,且其直方图为呈现均匀分布的特点。为此,需要对原图像中像素个数不均匀的区域进行拓宽或缩减处理,具体就是将像素数目偏多的灰度级进行拓宽,而对像素数目偏少的灰度级进行缩减,进而达到均匀化分布的目标。直方图均衡化的基本步骤如下。
(1)计算原图像直方图。
(2)计算灰度映射表。
(3)执行查表变换,利用灰度映射表计算原图像的像素得到新的像素值。
在MATLAB中可通过histeq函数进行直方图均衡化,关键代码如下。
![](https://epubservercos.yuewen.com/31DDB8/26580980701213406/epubprivate/OEBPS/Images/Figure-P37_5093.jpg?sign=1739246225-huHmfoUQTlWQKri5e3u14tMGNwhlbFj7-0-030d28c8de0765fde6067cf618d9b56f)
运行后可得到直方图均衡化后的图像及对应的直方图分布,如图2-3和图2-4所示。
![](https://epubservercos.yuewen.com/31DDB8/26580980701213406/epubprivate/OEBPS/Images/Figure-P37_4843.jpg?sign=1739246225-15RHDioIdNZtQ7no2Wx0Mm7V8H6lbvIF-0-447a64b96419046aba27fa23d4637ab1)
图2-3 直方图均衡化后的图像
![](https://epubservercos.yuewen.com/31DDB8/26580980701213406/epubprivate/OEBPS/Images/Figure-P37_4847.jpg?sign=1739246225-L9UZKBu8k5KhHOvtFR5SjyoIL1Pm71R7-0-15b1a584a07136ab9699c8af65830b10)
图2-4 处理后的直方图分布
如图2-3所示,经直方图均衡化处理后的图像虽然在右上角的较暗区域存在一定的模糊,但相对于原图(图2-1)在可视化效果上具有了较高的清晰度,整体呈现出明显的亮度改观,达到了较为明显的增强效果。如图2-4所示,经直方图均衡化处理后的直方图分布相对于原直方图(图2-2)呈现出均衡化分布的特点,这也是直方图均衡化处理的直观显示。
因此,可对雾天图像采用全局直方图均衡化进行增强,并对比增强前后的直方图分布情况。考虑到灰度图与彩色图在图像矩阵维度上的不同,可直接采用R、G、B三通道遍历计算的方式进行处理,关键代码如下所示。
![](https://epubservercos.yuewen.com/31DDB8/26580980701213406/epubprivate/OEBPS/Images/Figure-P37_5094.jpg?sign=1739246225-d8UwNat0hEG3hXexm0AjIvSeSgbqniTc-0-a2735e7690147303120f011d70c0f429)
运行后,可得到对雾天图像进行直方图均衡化前后的图像及对应的直方图分布,如图2-5所示。经全局直方图均衡化处理后,雾天图像得到了一定的改善,且处理后的直方图呈现出明显的均衡分布特点。但是,使用全局直方图增强后的图像出现了较为明显的失真问题,例如图像内的树木区域就出现了偏暗的情况,这也正是此方法的不足之处。
![](https://epubservercos.yuewen.com/31DDB8/26580980701213406/epubprivate/OEBPS/Images/Figure-P38_4854.jpg?sign=1739246225-b7pOsxdkqVYU6yJp3dJyTQHtdVi7vemv-0-3824af83a236a482ca68fafd7aec6e8c)
图2-5 雾天图像进行直方图均衡化处理的前后对比
2.2.2 CLAHE增强
限制对比度的自适应直方图均衡(Contrast Limited Adaptive Histogram Equalization,CLAHE)是一种自适应局部增强方法。通过全局直方图进行去雾增强,往往会面临局部细节失真等问题,因此需要考虑引入局部自适应的直方图均衡方法。CLAHE方法主要特点是其具有对比度限幅的约束,可以对局部区域使用对比度限幅来提高增强效果,突出细节信息。此外,CLAHE方法利用插值来提高计算效率,并能有效地控制灰度值集中的均衡化增强,降低噪声干扰。
在MATLAB中可通过adapthisteq函数进行直方图均衡化,关键代码如下。
![](https://epubservercos.yuewen.com/31DDB8/26580980701213406/epubprivate/OEBPS/Images/Figure-P38_5095.jpg?sign=1739246225-ZxNZaPfQZUOD5ip0vepcVm47QMXeFuIm-0-18a0003d3d595c8957d1e5f4b8be83fb)
运行后,可得到CLAHE方法处理后的图像及对应的直方图分布,如图2-6和图2-7所示。
![](https://epubservercos.yuewen.com/31DDB8/26580980701213406/epubprivate/OEBPS/Images/Figure-P39_4862.jpg?sign=1739246225-RTejdEsTMO9pGN0nXEUCfJtGDSWVr3QI-0-de91b6c5880027652b70fce3e6d734a7)
图2-6 CLAHE方法处理后图像
![](https://epubservercos.yuewen.com/31DDB8/26580980701213406/epubprivate/OEBPS/Images/Figure-P39_4866.jpg?sign=1739246225-5DGzenJT4STpBqOSciXLZrpMGRfaj1Od-0-9fb7fa411c3dbdb28ad6b82820866d00)
图2-7 处理后直方图分布
如图2-6所示,经CLAHE方法处理后的图像在整体上呈现出明显的增强效果,并且直方图分布维持了原有的宏观趋势,在局部细节的处理上也比全局直方图的增强图(图2-3)具有较为清晰的改进。
因此,可对雾天图像采用CLAHE方法进行增强,对比增强前后的直方图分布情况。考虑到灰度图与彩色图在图像矩阵维度上的不同,可直接采用R、G、B三通道遍历计算的方式进行处理,关键代码如下所示。
![](https://epubservercos.yuewen.com/31DDB8/26580980701213406/epubprivate/OEBPS/Images/Figure-P39_5096.jpg?sign=1739246225-1eRlM5Mwsh2vOPn85wLCq2506vi9S5zP-0-8a9520a1172a26cc99790fd28dba8703)
运行后,可得到对雾天图像进行CLAHE方法处理前后的图像及对应的直方图分布,如图2-8所示。经CLAHE方法处理后,雾天图像得到了明显的改善,且处理后的直方图保持了原直方图的分布态势并进行了一定的拓展。相比于图2-5(a)所示的全局直方图增强效果,CLAHE方法处理后的图像不存在失真问题,取得了良好的去雾效果。
2.2.3 Retinex增强
Retinex由Retina(视网膜)+Cortex(大脑皮层)合成,所以也称为“视网膜大脑皮层”理论。Retinex是基于人类视觉系统的颜色恒常性色彩理论,即物体的颜色具有一致性的特点,由物体对长波(红色)、中波(绿色)、短波(蓝色)光线的反射能力决定,不受光照非均匀性的影响,呈现颜色恒常性的特点。Retinex增强方法可以平衡图像灰度动态范围压缩、图像边缘增强和图像颜色恒常三个指标,进而可将其应用于雾天图像的自适应增强。
Retinex方法可将图像f(x,y)分解为反射图s(x,y)和低频亮度图的乘积l(x,y),通过将亮度图的低频消除,可以保留高频边缘信息,进而达到图像增强的效果,其处理流程如图2-9所示。对Retinex增强流程进行简化,关键步骤总结如下。
![](https://epubservercos.yuewen.com/31DDB8/26580980701213406/epubprivate/OEBPS/Images/Figure-P40_4875.jpg?sign=1739246225-9EnEOULnOEyDf13mssiB8i3ZhnOfGwAe-0-4ddbbb6a369242a47c6deaa10eeb4907)
图2-8 雾天图像进行CLAHE处理的前后对比
(1)图像LOG计算,将原图f(x,y)分解为反射部分s(x,y)×低频亮度部分l(x,y)。
(2)消除低频亮度部分,保留高频反色部分,得到r(x,y)。
(3)图像EXP计算,并进行自适应滤波输出。
![](https://epubservercos.yuewen.com/31DDB8/26580980701213406/epubprivate/OEBPS/Images/Figure-P40_4879.jpg?sign=1739246225-b6ZXZPmR26DSAzFJLfg6w8uTB2OTnCOx-0-c314fa0dc27c487dcca5a28fd5dbe56d)
图2-9 Retinex增强流程
低频亮度部分l(x,y)可以通过高斯低通滤波进行计算,假设滤波器g(x,y)定义如下:
![](https://epubservercos.yuewen.com/31DDB8/26580980701213406/epubprivate/OEBPS/Images/Figure-P41_5098.jpg?sign=1739246225-oMNYgsjPIbnUTxof27ONHOyt7noSK27Z-0-ad579c0dbc7339b43630c7970cd46de3)
其中,σ为高斯环绕尺度,可作为参数进行调整。将其应用于原图做卷积计算,即可得到亮度分量公式如下:
![](https://epubservercos.yuewen.com/31DDB8/26580980701213406/epubprivate/OEBPS/Images/Figure-P41_5100.jpg?sign=1739246225-AA0MYTK0UkZVOamysT5obLEbAi2Ed4Ec-0-e82a535f8805db8897006a95bd7a318c)
最后,消除低频分量,保留高频分量,公式如下:
![](https://epubservercos.yuewen.com/31DDB8/26580980701213406/epubprivate/OEBPS/Images/Figure-P41_5102.jpg?sign=1739246225-FnldYwHkXdNWVtyb0vi9D052vpHajH4K-0-5dc52dc2a3d4cf1fca9ec60645b9c0f0)
根据Retinex增强的关键步骤,可针对雾天图像按R、G、B三通道循环的方法进行简化计算,关键代码如下所示。
![](https://epubservercos.yuewen.com/31DDB8/26580980701213406/epubprivate/OEBPS/Images/Figure-P41_4896.jpg?sign=1739246225-37Gbz7cnN59XBJ5irtPh7ORvoZlnGMZ2-0-ce426c8e273970a25cea9393a8bf3c86)
运行后,可得到对雾天图像进行Retinex增强,处理前后的图像及对应的直方图分布,如图2-10所示。
![](https://epubservercos.yuewen.com/31DDB8/26580980701213406/epubprivate/OEBPS/Images/Figure-P3_2936.jpg?sign=1739246225-ZiHCjzQLMMzlc9wKDLeYCsqnwsj1aaLk-0-e7ed4bf5ad578a97b7e3e69148d88d72)
图2-10 雾天图像进行Retinex增强处理的前后对比
![](https://epubservercos.yuewen.com/31DDB8/26580980701213406/epubprivate/OEBPS/Images/Figure-P4_2939.jpg?sign=1739246225-683P8Bc1tGB7ydtJMAfPgYbWADDYKjVs-0-b70a092a0af161b02795cf51f0f3d9ae)
图2-10 续
经Retinex增强处理后,雾天图像得到了明显的改善,且处理后的直方图保持了原直方图的波峰走势并进行了更加深入的拓展。相比于全局直方图增强、CLAHE增强的处理效果,Retinex增强处理处理后的图像不存在失真问题,也能保证图像整体的色彩分布,取得了良好的去雾效果。