均值滤波计算_【从零学习OpenCV 4】均值滤波

点击上方“ 小白学视觉 ”,选择“ 星标 ”公众号

重磅干货,第一时间送达

214348a0e21629a17d695661d9afa290.png

经过几个月的努力,小白终于完成了市面上第一本OpenCV 4入门书籍《从零学习OpenCV 4》。为了更让小伙伴更早的了解最新版的OpenCV 4,小白与出版社沟通,提前在公众号上连载部分内容,请持续关注小白。

我们在测量数据时,往往会多次测量最后求取所有数据的平均值作为最终结果,均值滤波的思想和测量数据时多次测量求取平均值的思想一致。均值滤波将滤波器内所有的像素值都看作中心像素值的测量,将滤波器内所有的像数值的平均值作为滤波器中心处图像像素值。滤波器内的每个数据表示对应的像素在决定中心像素值的过程中所占的权重,由于滤波器内所有的像素值在决定中心像素值的过程中占有相同的权重,因此滤波器内每个数据都相等。均值滤波的优点是在像素值变换趋势一致的情况下,可以将受噪声影响而突然变化的像素值修正到接近周围像素值变化的一致性下。但是这种滤波方式会缩小像素值之间的差距,使得细节信息变得更加模糊,滤波器范围越大,变模糊的效果越明显。

OpenCV 4中提供了blur()函数用于实现图像的均值滤波,该函数的函数原型在代码清单5-8中给出。

代码清单5-8 blur()函数原型void cv::blur(InputArray  src,                 OutputArray  dst,                 Size  ksize,                 Point  anchor = Point(-1,-1),                 int  borderType = BORDER_DEFAULT                  )
  • 待均值滤波的图像,图像的数据类型必须是CV_8U、CV_16U、CV_16S、CV_32F和CV_64F这五种数据类型之一。

  • dst:均值滤波后的图像,与输入图像具有相同的尺寸和数据类型。
  • ksize:卷积核尺寸。
  • anchor:内核的基准点(锚点),其默认值为(-1,-1)代表内核基准点位于kernel的中心位置。基准点即卷积核中与进行处理的像素点重合的点,其位置必须在卷积核的内部。
  • borderType:像素外推法选择标志,取值范围在表3-5中给出,默认参数为BORDER_DEFAULT,表示不包含边界值倒序填充。

该函数的第一个参数为待滤波图像,可以是彩色图像也可以是灰度图像,甚至可以是保存成Mat类型的多维矩阵数据。第二个参数滤波后的图像,保持与输入图像相同的数据类型、尺寸以及通道数。第三个参数是滤波器的尺寸,输入滤波器的尺寸后函数会自动确定滤波器,其形式如式所示。

均值滤波计算_【从零学习OpenCV 4】均值滤波_第1张图片

函数的第四个参数为确定滤波器的基准点,默认状态下滤波器的几何中心就是基准点,不过也可以根据需求自由的调整,在均值滤波中调整基准点的位置主要影响图像外推的方向和外推的尺寸。第五个参数是图像外推方法选择标志,根据需求可以自由的选择。原图像边缘位置滤波计算过程需要使用到外推的像素值,但是这些像素值并不能真实反应图像像素值的变化情况,因此在滤波后的图像里边缘处的信息可能会出现巨大的改变,这属于正常现象。如果在边缘处有比较重要的信息,可以适当缩小滤波器尺寸、选择合适的滤波器基准点或者使用合适的图像外推算法。

为了更加了解均值滤波函数blur()的使用方法以及均值滤波的处理效果,在代码清单5-9中给出了利用不同尺寸的均值滤波器分别处理不含有噪声的图像、含有椒盐噪声的图像和含有高斯噪声的图像,处理结果在图5-10、图5-11、图5-12中给出。通过结果可以发现,滤波器的尺寸越大,滤波后图像变得越模糊。

代码清单5-9 myBlur.cpp图像均值滤波#include #include using namespace cv;using namespace std;int main(){  Mat equalLena = imread("equalLena.png", IMREAD_ANYDEPTH);  Mat equalLena_gauss = imread("equalLena_gauss.png", IMREAD_ANYDEPTH);  Mat equalLena_salt = imread("equalLena_salt.png", IMREAD_ANYDEPTH);  if (equalLena.empty() || equalLena_gauss.empty() || equalLena_salt.empty())  {    cout << "请确认图像文件名称是否正确" << endl;    return -1;  }  Mat result_3, result_9;  //存放不含噪声滤波结果,后面数字代表滤波器尺寸  Mat result_3gauss, result_9gauss;  //存放含有高斯噪声滤波结果,后面数字代表滤波器尺寸  Mat result_3salt, result_9salt;  //存放含有椒盐噪声滤波结果,后面数字代表滤波器尺寸  //调用均值滤波函数blur()进行滤波  blur(equalLena, result_3, Size(3, 3));  blur(equalLena, result_9, Size(9, 9));  blur(equalLena_gauss, result_3gauss, Size(3, 3));  blur(equalLena_gauss, result_9gauss, Size(9, 9));  blur(equalLena_salt, result_3salt, Size(3, 3));  blur(equalLena_salt, result_9salt, Size(9, 9));  //显示不含噪声图像  imshow("equalLena ", equalLena);  imshow("result_3", result_3);  imshow("result_9", result_9);  //显示含有高斯噪声图像  imshow("equalLena_gauss", equalLena_gauss);  imshow("result_3gauss", result_3gauss);  imshow("result_9gauss", result_9gauss);  //显示含有椒盐噪声图像  imshow("equalLena_salt", equalLena_salt);  imshow("result_3salt", result_3salt);  imshow("result_9salt", result_9salt);  waitKey(0);  return 0;}

均值滤波计算_【从零学习OpenCV 4】均值滤波_第2张图片

图5-10 myBlur.cpp程序中不含噪声图像均值滤波结果

均值滤波计算_【从零学习OpenCV 4】均值滤波_第3张图片

图5-12 myBlur.cpp程序中含高斯噪声图像均值滤波结果

从零学习OpenCV 4往期推荐

【从零学习OpenCV 4】Windows系统中安装OpenCV 4

【从零学习OpenCV 4】Ubuntu系统中安装OpenCV 4

【从零学习OpenCV 4】opencv_contrib扩展模块的安装

【从零学习OpenCV 4】Mat类介绍

【从零学习OpenCV 4】Mat类构造与赋值

【从零学习OpenCV 4】Mat类支持的运算

【从零学习OpenCV 4】这4种读取Mat类元素的的方法你都知道么?

【从零学习OpenCV 4】namedWindow函数&imshow函数的使用

【从零学习OpenCV 4】颜色模型与转换

【从零学习OpenCV 4】多通道分离与合并

【从零学习OpenCV 4】图像像素统计

【从零学习OpenCV 4】两图像间的像素操作

【从零学习OpenCV 4】图像二值化

【从零学习OpenCV 4】LUT查找表

【从零学习OpenCV 4】图像仿射变换

【从零学习OpenCV 4】图像透视变换

【从零学习OpenCV 4】极坐标变换

【从零学习OpenCV 4】绘制几何图形

【从零学习OpenCV 4】图像金字塔

【从零学习OpenCV 4】创建图像窗口滑动条

【从零学习OpenCV 4】鼠标响应

【从零学习OpenCV 4】图像直方图绘制

【从零学习OpenCV 4】直方图归一化

【从零学习OpenCV 4】直方图比较

【从零学习OpenCV 4】直方图均衡化

【从零学习OpenCV 4】直方图匹配

【从零学习OpenCV 4】图像卷积

【从零学习OpenCV 4】图像中添加椒盐噪声

【从零学习OpenCV 4】图像中添加高斯噪声

  ……

经过几个月的努力,市面上第一本OpenCV 4入门书籍《从零学习OpenCV 4》将于今年12月左右由人民邮电出版社发行。如果小伙伴觉得内容有帮助,希望到时候多多支持!

关注小白的小伙伴可以提前看到书中的内容,我们创建了学习交流群,欢迎各位小伙伴添加小白微信加入交流群,添加小白时请备注“学习OpenCV 4”。

均值滤波计算_【从零学习OpenCV 4】均值滤波_第4张图片

均值滤波计算_【从零学习OpenCV 4】均值滤波_第5张图片

你可能感兴趣的:(均值滤波计算)