前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >C++ OpenCV图像均值偏移滤波

C++ OpenCV图像均值偏移滤波

作者头像
Vaccae
发布2019-07-24 13:21:25
1.3K0
发布2019-07-24 13:21:25
举报
文章被收录于专栏:微卡智享微卡智享

前言

在图像分割的过程中,我们可以利用均值偏移算法的这个特性,实现彩色图像分割,均值漂移算法是一种通用的聚类算法,它的基本原理是:对于给定的一定数量样本,任选其中一个样本,以该样本为中心点划定一个圆形区域,求取该圆形区域内样本的质心,即密度最大处的点,再以该点为中心继续执行上述迭代过程,直至最终收敛。

Opencv中对应的均值偏移函数是pyrMeanShiftFiltering。这个函数是图像在色彩层面的平滑滤波,它可以中和色彩分布相近的颜色,平滑色彩细节,侵蚀掉面积较小的颜色区域,所以在Opencv中它的后缀是滤波“Filter”,而不是分割“segment”。

函数API

void pyrMeanShiftFiltering( InputArray src, OutputArray dst, double sp, double sr, int maxLevel=1, TermCriteria termcrit=TermCriteria( TermCriteria::MAX_ITER+TermCriteria::EPS,5,1) );

参数说明:

src:输入图像,8位,三通道的彩色图像,并不要求必须是RGB格式,HSV、YUV等Opencv中的彩色图像格式均可;


dst:输出图像,跟输入src有同样的大小和数据格式;


sp: 定义的漂移物理空间半径大小;


sr: 定义的漂移色彩空间半径大小;


maxLevel:定义金字塔的最大层数;


termcrit:定义的漂移迭代终止条件,可以设置为迭代次数满足终止,迭代目标与中心点偏差满足终止,或者两者的结合;


pyrMeanShiftFiltering函数的执行过程是这样的: 1. 迭代空间构建: 以输入图像上src上任一点P0为圆心,建立物理空间上半径为sp,色彩空间上半径为sr的球形空间,物理空间上坐标2个—x、y,色彩空间上坐标3个—R、G、B(或HSV),构成一个5维的空间球体。 其中物理空间的范围x和y是图像的长和宽,色彩空间的范围R、G、B分别是0~255。 2. 求取迭代空间的向量并移动迭代空间球体后重新计算向量,直至收敛: 在1中构建的球形空间中,求得所有点相对于中心点的色彩向量之和后,移动迭代空间的中心点到该向量的终点,并再次计算该球形空间中所有点的向量之和,如此迭代,直到在最后一个空间球体中所求得的向量和的终点就是该空间球体的中心点Pn,迭代结束。 3. 更新输出图像dst上对应的初始原点P0的色彩值为本轮迭代的终点Pn的色彩值,如此完成一个点的色彩均值漂移。 4. 对输入图像src上其他点,依次执行步骤1,、2、3,遍历完所有点位后,整个均值偏移色彩滤波完成,这里忽略对金字塔的讨论。


代码实现

我们再新建一个项目名为opencv--Matting,按照配置属性(VS2017配置OpenCV通用属性),然后在源文件写入#include和main方法.

我们显示一下源图


物理空间半径sp=10,色彩空间半径sr=10时色彩滤波效果:

运行效果我们看一下


上面一看感觉没有什么太大变化,我们改一下参数看看效果

物理空间半径sp=50,色彩空间半径sr=50时色彩滤波效果:

我们再运行一下看看

这样一看上面右图就非常明显了


物理空间半径sp=10,色彩空间半径sr=100时色彩滤波效果:

运行的效果

可以看到对比上图的还有一些白的亮点,在这里面基本都看不到了。


-END-

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2018-11-26,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 微卡智享 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档