分水岭算法(Watershed algorithm)与OpenCV实现

本文介绍了分水岭算法在图像分割中的应用,强调了预处理和区域合并的重要性。通过OpenCV的C++实现,详细讲解了如何使用cvtColor()转换灰度图,findContours()获取标记图层,以及watershed()函数进行分割。虽然该算法可能导致过分割,但可通过后期处理减少这种影响。
摘要由CSDN通过智能技术生成

前言

         分水岭算法主要用于图像的分割!

         这个算法需要输入一个灰度图,在接下来的洪水漫堤过程中,相邻的积水盆地之间的分水岭便慢慢构建起来。一般情况下,这会引起过分割,尤其是具有噪声的图像。

         图像必须要预处理,以消除噪声;分割结果必须要基于一些根据进行区域合并,以减小过分割造成的影响!

技术
         假设我们要将下面这幅图像进行分割,需要几步?分三步,第一步,冰箱门打开,第二步。。。打住,- -| 进入正题,我们要用OpenCV来实现,不就一步么?调用那个watershed函数不就行了?实际上,可没那么简单!且听我细细道来 ~-~!




OpenCV实现了一个基于标记图层的分水岭算法,所谓基于标记图层,就是不用手动选择种子点了,直接输入一个包含标记点(种子点)的图像即可。函数原型如下:

C++: void watershed(InputArray image, InputOutputArray markers)

其中,image代表输入图像(必须是8-bit3通道图像࿰

评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值