一、双边滤波原理

双边滤波(Bilateral Filter)是非线性滤波中的一种。这是一种结合图像的空间邻近度与像素值相似度的处理办法。在滤波时,该滤波方法同时考虑空间临近信息与颜色相似信息,在滤除噪声、平滑图像的同时,又做到边缘保存。

双边滤波采用了两个高斯滤波的结合。一个负责计算空间邻近度的权值,也就是常用的高斯滤波器原理。而另一个负责计算像素值相似度的权值。在两个高斯滤波的同时作用下,就是双边滤波。

opencv python 双边滤波 opencv双边滤波原理_c++


如上图所示,双边滤波的图像边缘信息被较好的保留,而高斯滤波的边缘信息则十分模糊。

二、双边滤波公式

opencv python 双边滤波 opencv双边滤波原理_opencv python 双边滤波_02

S(i, j):指以 (i, j) 为中心的 (2N+1)x(2N+1) 的大小的范围;
f(k, l):(多个) 输入点;
w(i, j, k, l):代表经过两个高斯函数计算出的值(这里还不是权值)
g(i, j):输出点;

上述公式我们进行转化,假设公式中 w(i,j,k,l) 为 m,则有
opencv python 双边滤波 opencv双边滤波原理_c++_03
opencv python 双边滤波 opencv双边滤波原理_计算机视觉_04,则有
opencv python 双边滤波 opencv双边滤波原理_opencv python 双边滤波_05

此时可以看到,这明显是图像矩阵与核的卷积运算了。其中 m1/M 代表的第一个点(或最后一个点,看后面如何实现)的权值,而图像矩阵与核通过卷积算子作加权和,最终得到输出值。
接下来我们来讨论最关键的w(i, j, k, l), ws为空间临近高斯函数,wr为像素值相似度高斯函数
opencv python 双边滤波 opencv双边滤波原理_图像处理_06 opencv python 双边滤波 opencv双边滤波原理_图像处理_07 opencv python 双边滤波 opencv双边滤波原理_c++_08 可以看到,对于 opencv python 双边滤波 opencv双边滤波原理_opencv_09 来说,这就是普通的高斯滤波函数,其代入的坐标,opencv python 双边滤波 opencv双边滤波原理_opencv python 双边滤波_10 是程序输入值,该函数是在空间临近度上计算的。而 opencv python 双边滤波 opencv双边滤波原理_c++_11 是计算像素值相似度(颜色空间),注意,这就是高斯函数代入坐标值,opencv python 双边滤波 opencv双边滤波原理_opencv python 双边滤波_12 的上方是范数,在这里的值为 opencv python 双边滤波 opencv双边滤波原理_opencv_13 。也就是两个点像素值差值的绝对值的平方。其中,彩色图片计算差值时应将(i,j)点的RGB三通道值之和减去(k,l)点的RGB三通道值之和。这里是颜色空间计算,不能当成单通道,但是在最后矩阵卷积时,是单通道与权值相乘而不是三个通道之和。
总之,对于与模版中心点像素值相差较大的像素点来说,模板系数受高斯核的影响越小。反之,影响就越大。因此,对于不同种类的噪声点,可以联合调节 Ws和Wr的大小,使得双边滤波模版既能滤除掉图中的噪声点,又能较好地保存边缘信息。

三、bilateralFilter 函数

OpenCV还给出了简单的函数形式:

CV_EXPORTS_W void bilateralFilter( InputArray src, OutputArray dst, int d,
                                   double sigmaColor, double sigmaSpace,
                                   int borderType = BORDER_DEFAULT );

src : 原图, 8为整形或浮点型,单通道或者3通道;
dst : 与原图同样尺寸,但不能是原图;
d : 滤波核的直径;
sigmaColor : opencv python 双边滤波 opencv双边滤波原理_c++_14
sigmaSpace : opencv python 双边滤波 opencv双边滤波原理_opencv python 双边滤波_10
borderType : 用于设置图像边界元素的方式

双边滤波的效果(来自网络图片)

opencv python 双边滤波 opencv双边滤波原理_opencv python 双边滤波_16