一种基于单张图像的去雾算法研究
最后更新于:2022-04-01 06:36:58
对于图像去雾,这个研究内容,CSDN 中[33184777](http://my.csdn.net/laviewpbt)博友曾做了大量的研究,也写出了很多不错的博文,比如:[http://blog.csdn.net/laviewpbt/article/details/38711727](http://blog.csdn.net/laviewpbt/article/details/38711727)
令人深受启发。今天在网络上闲逛的时候,发现了一篇2014年的论文Fast Single-Image Defogging,基本上是暗通道的理论,不过算法比较简单,效果还行,特分享一下!
这篇论文中描述的具体过程如下:
1,去雾模型:
![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2015-12-30_56837de4d087a.jpg)
这个模型应该不用过多介绍了,目前大部分去雾算法都是根据这个模型进行的,这里依旧是基于暗通道理论,已知原始图像I(x),求取清晰图像J(x),未知参数A和t(x)
2,去雾过程图解:
![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2015-12-30_56837de4e317b.jpg)
当然这个图解是论文中的,至于效果的实现,本人并没有看到这么好的效果,不知作者做了什么优化。
3,实现2的具体步骤:
3.1 估计大气光A
大气光A的计算,这篇论文依然采用的是何凯明《[Single Image Haze Removal Using Dark Channel Prior](http://files.cnblogs.com/Imageshop/SingleImageHazeRemovalUsingDarkChannelPrior.rar)》中的计算方法,这里不再累赘。
3.2计算Transmission map
![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2015-12-30_56837de4f3f8e.jpg)
这个y实际上就是一个局部窗口欧米伽内的像素,假设窗口半径为r,那么,min I(y)实际上就是用以r为半径的窗口,对R,G,B通道分别进行最小值滤波,然后选择R,G,B通道的滤波结果的最小值作为Mcoarse(x);
3.3计算Fine map
这一步实际上是为了保留图像边缘,也就是保边滤波作用,比如双边滤波之类,为了达到保边作用,又要兼顾速度问题,作者直接使用了原始图像R,G,B通道的最小值
![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2015-12-30_56837de50d991.jpg)
3.4计算M(x)
这一步,实际上是对Mcoarse进行了重定义,或者是修正:
![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2015-12-30_56837de51b824.jpg)
对Mcoarse重新进行了一定半径窗口内的最大值滤波,然后取结果和Mfine(x)的最小值;
3.5计算t(x)
![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2015-12-30_56837de529d63.jpg)
其中w是一个0到1之间的数值;
3.6计算清晰图像J(x)
![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2015-12-30_56837de5376e1.jpg)
其中t0是个很小的常量,防止分母为0;
以上就是整个论文的计算过程了,看起来很简单,对于最小值最大值滤波,已有实时算法,这里不再累赘,大家可以到[33184777](http://my.csdn.net/laviewpbt)的主页看一下,介绍的相当详细。
![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2015-12-30_56837de544fd6.jpg)![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2015-12-30_56837de560cce.jpg)
![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2015-12-30_56837de59f06e.jpg)
![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2015-12-30_56837de5c3474.jpg)
![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2015-12-30_56837de60d4de.jpg)
![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2015-12-30_56837de62a21d.jpg)
![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2015-12-30_56837de66f396.jpg)![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2015-12-30_56837de6826e9.jpg)
对于基本没有雾的图像,本人也做了测试(分别是原图和效果图):
![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2015-12-30_56837de6aae6a.jpg)![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2015-12-30_56837de6e0622.jpg)
![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2015-12-30_56837de7123a5.jpg)![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2015-12-30_56837de732fff.jpg)
上面所有效果图,测试参数都是:滤波半径9,w=0.8,最后放上本人的代码,由于代码未进行优化,也没有使用实时滤波算法,因此,速度较慢,本人只是为了看下去雾效果而已,有兴趣的可以自己优化。
总体来看,效果还可以,没有发生颜色偏色,过渡失真之类,对于其他算法的效果,大家可以参考[33184777](http://my.csdn.net/laviewpbt)的博文。
代码地址:[http://download.csdn.net/detail/trent1985/7851061](http://download.csdn.net/detail/trent1985/7851061)
最后,分享一个专业的图像处理网站(微像素),里面有很多源代码下载:
[http://www.zealpixel.com/portal.php](http://www.zealpixel.com/portal.php)