一种强化的基于局部直方图裁剪均衡化的对比度调节算法。

在很久前实现对比度受限的自适应直方图均衡化时,就曾经想过对该算法进行一定程度的扩展,之后使用自动对比度和自动色阶代替直方图均衡化也提出了新的算法,也达到了不错的效果。本文进一步对该算法进行一定程度的扩展和补充优化。

一、本文算法的概述

根据选取的优化的水平和垂直网格数,将图像切分成一个一个的子块,然后统计每个子块的直方图信息,并和原图整体的直方图信息进行某种混合,对于彩色图像,为了避免不同通道之间处理后变化过于不协调,还增加了各通道直方图与亮度通道直方图的信息合成,然后对合成后的直方图进行直方图裁剪和均衡化的,获取各子块新的映射直方图,为了避免新的映射表中的数据有较大的奇点或噪音,对映射表的数据进行多点取样,然后使用样条插值算法对取样点进行插值,或者对新的映射表进行一定程度的高斯模糊,得到一张较为平滑的映射表。最后使用类似CLAHE算法中的双线性插值对每个子块之间的映射表进行插值得到新的像素值。本方法计算量小,速度很快,对映射表进行平滑插值或高斯模糊能有效的抑制对比度调整时产生的噪声,防止了信息的过度放大造成图片失真,是一种高效并且效果突出的对比度增强算法。

二、算法过程详解

1、水平和垂直网格数的确定

类似于CALHE算法,对网格的合理选取也会对本算法的结果产生重要的影响,过多的网格数会使得计算量显著加大,过少的网格数使得结果趋于接近整体的直方图均衡化,一般情况下,可选择8*8个网格,这里可以通过以下原则来简单的做个优化:图像的亮度的均方差越小,即整幅图像的明暗比较一致,使用较多的网格数,比如8*8,否则使用较少的网格,比如4*4。这是因为当图像明暗较为一致时,各小块的直方图数据差异不会很大,而如果明暗不一致,选择较小的块,各块之间的直方图信息差异可能很大,会造成插值时出现明显的瑕疵。

2、按规定的网格数划分图像,并获取每块的直方图信息HistB,HistG,HistR。

3、获取全图的直方图数据HistgramB,HistgramG,HistgramR以及亮度直方图HistgramL。

其中亮度定义为:  Lightness = (R*19595 + G*38469 + B*7472) >> 16

4、对子块直方图和全局直方图进行融合,如下代码所示:

HistB[Index] = (HistB[Index] * Adaptation + (100- Adaptation) * HistgramB[Index]) /100;

HistG[Index]= (HistG[Index] * Adaptation + (100- Adaptation) * HistgramG[Index]) /100;

HistR[Index]= (HistR[Index] * Adaptation + (100- Adaptation) * HistgramR[Index]) /100;

HistL[Index]= (HistL[Index] * Adaptation + (100- Adaptation) * HistgramL[Index]) /100;

其中Adaptation为融合因子,其有效范围为[0,100],当取值越小时,全局直方图其主导作用,效果越接近普通的直方图均衡。

5、对上述融合后的结果再次和亮度直方图进行融合,融合过程如下所示:

HistB[Index] = (HistB[Index] * Correction + (100- Correction) * HistL[Index]) /100;

HistG[Index]= (HistG[Index] * Correction + (100- Correction) * HistL[Index]) /100;

HistR[Index]= (HistR[Index] * Correction + (100- Correction) * HistL[Index]) /100;

其中Correction为颜色校正因子,其有效范围为[0,100],当取值越大时,各通道之间越独立,效果越接近普通的直方图均衡。

上述代码中Index表示直方图色阶的索引范围,有效值[0,Bins – 1],Bins为直方图的数量,8位时为256。

6、按照CALHE的方式对直方图进行裁剪,之后对裁剪的直方图进行均衡化得到每个小块的映射表。

7、局部均衡化后映射表的平滑。

1)  将映射表的 Bins取K等份,得到每等份数据对应的映射表值,构成K个二维坐标点序列,亦可以根据直方图的累计数据,把累计数据平均分为K等分,得到K个二维序列点。

2)根据K个二维坐标点,使用样条插值算法拟合出一条过各个取样点的平滑映射曲线。

你可能感兴趣的:(一种强化的基于局部直方图裁剪均衡化的对比度调节算法。)