OpenCV学习(7) 分水岭算法(1)

http://www.cnblogs.com/mikewolf2002/p/3304118.html

OpenCV学习(7) 分水岭算法(1)

        分水岭算法主要用于图像分段,通常是把一副彩色图像灰度化,然后再求梯度图,最后在梯度图的基础上进行分水岭算法,求得分段图像的边缘线。

        下面左边的灰度图,可以描述为右边的地形图,地形的高度是由灰度图的灰度值决定,灰度为0对应地形图的地面,灰度值最大的像素对应地形图的最高点。

ima1 (2)ima2

我们可以自己编程实现灰度图的地形图显示,工程FirstOpenCV6就实现了简单的这个功能,比如上边的灰度图,显示为:

image

对灰度图的地形学解释,我们我们考虑三类点

1. 局部最小值点,该点对应一个盆地的最低点,当我们在盆地里滴一滴水的时候,由于重力作用,水最终会汇聚到该点。注意:可能存在一个最小值面,该平面内的都是最小值点。

2. 盆地的其它位置点,该位置滴的水滴会汇聚到局部最小点。

3. 盆地的边缘点,是该盆地和其它盆地交接点,在该点滴一滴水,会等概率的流向任何一个盆地。

image

       假设我们在盆地的最小值点,打一个洞,然后往盆地里面注水,并阻止两个盆地的水汇集,我们会在两个盆地的水汇集的时刻,在交接的边缘线上(也即分水岭线),建一个坝,来阻止两个盆地的水汇集成一片水域。这样图像就被分成2个像素集,一个是注水盆地像素集,一个是分水岭线像素集。

      下面的gif图很好的演示了分水岭算法的效果:

lpe1 (1)ima3 (1)

     

     在真实图像中,由于噪声点或者其它干扰因素的存在,使用分水岭算法常常存在过度分割的现象,这是因为很多很小的局部极值点的存在,比如下面的图像,这样的分割效果是毫无用处的。

ima7ima7b

      为了解决过度分割的问题,可以使用基于标记(mark)图像的分水岭算法,就是通过先验知识,来指导分水岭算法,以便获得更好的图像分段效果。通常的mark图像,都是在某个区域定义了一些灰度层级,在这个区域的洪水淹没过程中,水平面都是从定义的高度开始的,这样可以避免一些很小的噪声极值区域的分割。

      下面的gif图很好的演示了基于mark的分水岭算法过程:

ima4lpe2ima5

      上面的过度分段图像,我们通过指定mark区域,可以得到很好的分段效果:

 

ima8ima9

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
分水岭算法是一种在图像处理中常用的图像分割算法,它基于图像中的灰度和梯度信息,将图像分割成不同的区域。该算法的目标是将图像中的前景和背景分开,同时保留物体的边缘和细节。 在OpenCV中,可以使用函数cv2.watershed()实现分水岭算法。该函数接受一个灰度图像和标记图像作为输入,并将分割结果存储在标记图像中。标记图像中的像素值表示不同的区域,-1表示边界。 分水岭算法的处理流程如下: 1. 将原始图像转换为灰度图像。 2. 对灰度图像进行预处理,例如平滑和二值化,以便更好地识别前景和背景。 3. 创建一个空的标记图像,初始化为0。 4. 根据预处理后的图像,确定前景和背景的种子点。 5. 使用cv2.connectedComponents()函数将种子点标记为不同的区域,并将其存储在标记图像中。 6. 调用cv2.watershed()函数进行分水岭算法处理,将分割结果存储在标记图像中。 7. 可选步骤:根据需要进一步处理分割结果,例如绘制边界或提取特定区域的像素值。 请注意,分水岭算法需要一些预处理步骤和参数调整,以确保得到满意的分割结果。因此,在实际使用时,可能需要根据具体情况进行调整和优化。 参考资料: opencv-python——通过cv2.distanceTransform()函数将距离转换成热力图 OpenCV学习三十五:distanceTransform 距离变换函数 OPENCV自学记录(6)——连通域处理函数CV2.CONNECTEDCOMPONENTSWITHSTATS()和CV2.CONNECTEDCOMPONENTS() OpenCV3学习(7.2)——图像分割之二(分水岭算法watershed) opencv进阶学习笔记14:分水岭算法 实现图像分割图像分割之分水岭算法python opencv入门 分水岭算法(29)<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [OpenCV-分水岭算法](https://blog.csdn.net/qq_43951094/article/details/120801731)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [【OpenCV】- 分水岭算法](https://blog.csdn.net/qq_44859533/article/details/126436001)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值