0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

二值图像分析的典型案例

OpenCV学堂 ? 来源:OpenCV学堂 ? 2023-12-06 10:54 ? 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

最近一直有人向我提问很多二值图像分析相关的问题,特别选择了两个典型的轮廓分析问题。进行分析与编码实现与演示,废话不多说,先看第一个问题。

问题一

描述如下:

想找到工具盘中间缺少的几个点,统计出可以看到的工件数目

仔细分析图像发现,中间都毫无另外的有个白色很亮的圆圈,这个给了我两个思路

可以通过霍夫变换检测圆来提取到

可以通过二值图像分析来提取 + 轮廓分析来提取到这些点

得到这些轮廓点之后通过分析整个轮廓区域得到倾斜角度,进行纠偏,然后通过X与Y投影进行分割,得到每个零件的中心位置坐标,根据每一行的间隔设置阈值,从而实现缺少部分部分的标出与件数统计,确定了这样的思路以后,我就开始了写代码。代码实现是基于轮廓分析的思路,因为这个方法,用的阈值比较少,有利于算法稳定性检测。演示各部输出。二值化处理之后(形态学处理):

轮廓发现与校正角度之后

投影分析与统计结果如下:

此外基于霍夫也是可以尝试的,霍夫的二值化效果也比较好,显示如下:

感兴趣的同学可以自己继续尝试下去。

问题二

描述如下:

如何统计下图中的对象个数,原图如下

看到这个图像之后,个人觉得解决十分简单,基于最外层轮廓发现即可,无需树形结构与层次分析,集合图像形态学分析或者距离变换就可以得到,最终代码的运行结果如下:

代码

问题1的代码如下(已经添加各步骤注释了):

src=cv.imread("D:/images/zsxq/zsxq_01.jpg")
cv.imshow("input",src)

#二值化处理
gray=cv.cvtColor(src,cv.COLOR_BGR2GRAY)
se=cv.getStructuringElement(cv.MORPH_RECT,(3,3))
dst=cv.morphologyEx(gray,cv.MORPH_GRADIENT,se)
ret,binary=cv.threshold(dst,0,255,cv.THRESH_OTSU|cv.THRESH_BINARY)

#形态学处理
se=cv.getStructuringElement(cv.MORPH_ELLIPSE,(5,5))
binary=cv.morphologyEx(binary,cv.MORPH_OPEN,se)
se=cv.getStructuringElement(cv.MORPH_ELLIPSE,(10,10))
binary=cv.morphologyEx(binary,cv.MORPH_CLOSE,se)
cv.imshow("binary",binary)

#轮廓分析
contours,hireachy=cv.findContours(binary,cv.RETR_EXTERNAL,cv.CHAIN_APPROX_SIMPLE)
result=np.zeros_like(binary)
total=0
forcntinrange(len(contours)):
area=cv.contourArea(contours[cnt])
ifarea

问题2的完整代码如下:

importcv2ascv
importnumpyasnp

src=cv.imread("D:/images/zsxq/zsxq_02.jpg")
cv.imshow("input",src)
src=cv.GaussianBlur(src,(3,3),0)
gray=cv.cvtColor(src,cv.COLOR_BGR2GRAY)
edge=cv.Canny(src,50,100)

se=cv.getStructuringElement(cv.MORPH_ELLIPSE,(10,10))
binary=cv.morphologyEx(edge,cv.MORPH_CLOSE,se)
contours,hireachy=cv.findContours(binary,cv.RETR_EXTERNAL,cv.CHAIN_APPROX_SIMPLE)
count=0
forcntinrange(len(contours)):
area=cv.contourArea(contours[cnt])
ifarea

审核编辑:汤梓红

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 算法
    +关注

    关注

    23

    文章

    4716

    浏览量

    95759
  • 代码
    +关注

    关注

    30

    文章

    4906

    浏览量

    71028
  • 二值图像
    +关注

    关注

    0

    文章

    14

    浏览量

    8865

原文标题:二值图像分析案例精选

文章出处:【微信号:CVSCHOOL,微信公众号:OpenCV学堂】欢迎添加关注!文章转载请注明出处。

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    基于FPGA的图像的膨胀算法的实现

    1 背景知识图像(Binary Image)是指将图像上的每一个像素只有两种可能的取值或灰度等级状态,人们经常用黑白、B&W、单色图像
    发表于 08-14 09:08

    基于图像分块的局部阈值化方法

    针对目前局部阈值化结果存在目标虚假或断裂的缺陷,提出了一种基于图像分块的局部阈值化方法。首先,将
    发表于 05-04 11:10

    一种有效的文本图像化方法

    针对一般文本图像化方法--全局阈值法和局部阈值法所存在的不足,提出了一种整体与局部相结合的化方法,该方法根据文本
    发表于 06-11 09:08 ?13次下载

    岩石节理图像的细化

    分析岩石节理图片,细化是关键的一步,它是分析节理拓扑结构的基础。由于节理图片噪声大,节理内部有空洞等特点,直接用现有细化算法得到的结果中存在大量毛刺和并
    发表于 07-08 08:35 ?7次下载

    基于大津法的图像分块化算法

    本文对灰度图像化的方法进行研究,提出了一种新的以大津法为基础的图像分块化方法。通过对采集
    发表于 08-04 09:25 ?48次下载

    基于Legendre矩的多阈值图像重构算法

    基于Legendre矩的多阈值图像重构算法:首先介绍Legendre正交矩及其逆变换;然后根据Legendre矩逆变换的特点,采用一种新的方法—— 多阁法对重构的
    发表于 10-26 11:34 ?15次下载

    基于边界特征的图像化方法应用研究

    基于边界特征的图像化方法应用研究:边界特征是图像的重要信息,阈值是区分图像象素点的主要依据。研究了基于
    发表于 11-08 16:28 ?26次下载

    图像目标邻域点法边界跟踪算法

    分析图像识别中常用的轮廓跟踪算法,并指出其缺点。在提出目标邻域点概念的基础上,提供一种对
    发表于 05-25 15:02 ?40次下载
    <b class='flag-5'>二</b><b class='flag-5'>值</b><b class='flag-5'>图像</b>目标邻域点法边界跟踪算法

    基于图像分块的局部阈值化方法

    针对目前局部阈值化结果存在目标虚假或断裂的缺陷,提出了一种基于图像分块的局部阈值化方法。首先,将
    发表于 12-05 17:11 ?4次下载
    基于<b class='flag-5'>图像</b>分块的局部阈值<b class='flag-5'>二</b><b class='flag-5'>值</b>化方法

    图像 FPGA腐蚀算法解析

    图像的腐蚀算法过程中我们使用图像3x3图像
    发表于 03-21 11:14 ?5626次阅读
    <b class='flag-5'>二</b><b class='flag-5'>值</b><b class='flag-5'>图像</b> FPGA腐蚀算法解析

    机器视觉的图像化详细分析

    传统的机器视觉通常包括两个步骤——预处理和物体检测。而沟通者的桥梁则是图像分割(Image Segmentation)[1]。图像分割通过简化或改变图像的表示形式,使得
    的头像 发表于 06-16 09:22 ?1.1w次阅读

    LabVIEW:如何显示化后的图像

    LabVIEW中常见的图像预处理操作化的结果比较特殊,图像实际上也是一种U8
    的头像 发表于 12-06 09:40 ?1.1w次阅读

    图像分析最常见的方式

    图像分析最常见的一个主要方式就是轮廓发现与轮廓分析,其中轮廓发现的目的是为轮廓分析做准备,经
    的头像 发表于 08-12 10:45 ?1492次阅读

    OpenCV图像分析

    图像分析最常见的一个主要方式就是轮廓发现与轮廓分析,其中轮廓发现的目的是为轮廓分析做准备,经
    的头像 发表于 10-20 12:25 ?879次阅读

    图像连通区域的标记原理

    图像是一种由黑白两色组成的图像,其像素只有两种可能,分别对应黑色和白色。在
    的头像 发表于 01-05 14:28 ?1469次阅读