图 连通域的个数_连通域的原理与Python实现

本文介绍了二值图像分析中的连通域概念,包括4邻接和8邻接的区别,并详细讲解了Two-Pass算法和Seed-Filling算法,提供了这两种方法的Python实现。
摘要由CSDN通过智能技术生成

bf23dde4b93a7431a5f04abc62ea1014.png

二值图像连通域

二值图像分析最基础的也是最重要的方法之一就是连通域标记,它是所有二值图像分析的基础。它通过对二值图像中目标像素的标记,让每个单独的连通区域形成一个被标识的块,进一步的我们就可以获取这些块的轮廓、外接矩形、质心、不变矩等几何参数。
连通区域的定义一般有两种,分为4邻接和8邻接。下面这幅图中,如果考虑4邻接,则有3个连通域,8邻接则是2个连通域。

cf2c6d221c06d6b655d75421b73ba19e.png

从连通区域的定义可以知道,一个连通域是由具有相同像素值的相邻像素组成像素集合,因此,我们就可以通过这两个条件在图像中寻找连通区域,对于找到的每个连通域,我们赋予其一个唯一的标识( Label ),以区别其他连通域。

连通域分析的基本算法有两种: 1) Two-Pass 两遍扫描 2) Seed-Filling 种子填充法。

Two-Pass 算法

两遍扫描法( Two-Pass ),正如其名,指的就是通过扫描两遍图像,将图像中存在的所有连通域找出并标记。

(1)第一次扫描:
    访问当前像素 B(x,y) ,如果 B(x,y) == 1:
        a、如果 B(x,y) 的领域中标签值都为0,则赋予 B(x,y) 一个新的 label :
        label += 1, B(x,y) = label;
        b、如果B(x,y)的领域中有像素值 > 1的像素Neighbors:
    1)将Neighbors中的最小值赋予给 B(x,y) :
        B(x,y) = min{Neighbors
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值