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< 55:
        continue
    rrt = cv.minAreaRect(contours[cnt])
    cx, cy = rrt[0]
    cv.circle(result, (np.int32(cx), np.int32(cy)), 5, (255), -1)
    total += 1

# 几何纠偏
h, w = result.shape
pts = []
for row in range(h):
    for col in range(w):
        pv = result[row, col]
        if pv == 255:
            pts.append((col, row))

pts = np.array(pts)
rrt = cv.minAreaRect(pts)
print(rrt)
M = cv.getRotationMatrix2D(((w-1)/2.0,(h-1)/2.0),rrt[2],1)
dst = cv.warpAffine(result,M,(w,h))
src = cv.warpAffine(src,M,(w,h))

# Y方向投影
tbins = y_split(dst)

# X 方向投影
print("y-step", tbins)
for i in range(0, len(tbins), 1):
    if i == 0:
        roi = dst[0:tbins[i], 0:w]
        src_roi = src[0:tbins[i], 0:w, :]
        x_projection(roi, src_roi)
        cv.imshow("roi", roi)
        cv.waitKey(0)
    if i == len(tbins)-1:
        roi = dst[tbins[i]:h-1, 0:w]
        src_roi = src[tbins[i]:h-1, 0:w, :]
        x_projection(roi, src_roi)
        cv.imshow("roi", roi)
        cv.waitKey(0)
    if 0 < i < (len(tbins)-1):
        roi = dst[tbins[i-1]:tbins[i] - 1, 0:w]
        src_roi = src[tbins[i-1]:tbins[i] - 1, 0:w,:]
        x_projection(roi, src_roi)
        cv.imshow("roi", roi)
        cv.waitKey(0)

# 显示结果
cv.imshow("result", result)
cv.imshow("dst", dst)
cv.putText(src, "numbers: " + str(total), (50, 50), cv.FONT_HERSHEY_SIMPLEX, 1.0, (0, 0, 255), 2)
cv.imshow("detection", src)

cv.waitKey(0)
cv.destroyAllWindows()

问题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< 100:
        continue
    count += 1
    rrt = cv.minAreaRect(contours[cnt])

    # rotated rectangle
    box = cv.boxPoints(rrt)
    box = np.intp(box)
    cv.drawContours(src, [box], 0, (255, 0, 0), 2)

cv.imshow("binary", binary)
cv.imshow("result", src)
cv.waitKey(0)
cv.destroyAllWindows()

审核编辑:汤梓红

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

    关注

    23

    文章

    4455

    浏览量

    90756
  • 代码
    +关注

    关注

    30

    文章

    4555

    浏览量

    66771
  • 二值图像
    +关注

    关注

    0

    文章

    14

    浏览量

    8685

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

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

收藏 人收藏

    评论

    相关推荐

    求labview图像化处理的程序

    谁可以给个图像化处理的程序,通过阈值分割来实现化的???
    发表于 01-15 09:22

    labview 图像阈值分割 得不到化图

    如题新手刚上路 想实现图像阈值分割 得到图像运行结果:化图全黑麻烦高手看看哪里出错了。
    发表于 04-10 21:47

    数字图像处理的时候,化是边缘是断开的??

    我在做数字图像处理的时候,化是边缘是断开的,我怎么帮边缘链接成封闭的。。。。。
    发表于 08-26 14:08

    将RGB各频域内的图像相加减后化处理的图像

    保存化后的图像为什么是黑色的
    发表于 04-19 14:05

    【创龙TMS320C6748开发板试用】图像处理----图像

    本帖最后由 wwwming0329 于 2015-12-16 13:21 编辑 一、何为图像图像
    发表于 12-15 16:06

    labview中有没有对图像采集后进行实时化的方法?

    求助:labview中有没有对图像采集后进行实时化的方法,也就是对正在采集的图像进行化而
    发表于 04-06 10:43

    通过matlab对化矩阵图像还原显示

    `通过OV7670采集图像,然后单片机将读到的图像数据,通过串口转化成矩阵,复制成一个文本文件,内容如下,现在想通过matlab对该图像
    发表于 05-24 15:00

    为什么 图像化模板不能 匹配 ,或者匹配出错 ?

    本 人做 图像处理,做到了缺陷匹配 ,用模板图片格式是 8位的png格式 ,而待检测的图是化的,匹配时显示出错,把模板改成进制的,显示错误,什么原因 ?
    发表于 07-23 15:56

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

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

    基于图像处理的PCB自动检测系统的设计与研究(第部分)

    存在的典型的缺陷有:短路、断路、凸起、凹陷、空洞等。  缺陷获取后,并不能确定缺陷类型,还需要进行缺陷识别。缺陷识别是根据各种缺陷的不同特征来判断。常用的描述图像特征有直方图统计特征、纹理特征、
    发表于 09-13 16:36

    图像后分割粘连的区域如何分割

    `图像粘连后如果是圆形的物体可以使用分水岭或找圆进行分割。如果是其它形状如椭圆或图中形状如何分割请教高手帮忙`
    发表于 03-31 22:46

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

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

    图像化的分类方法

    十三种基于直方图的图像全局化算法原理 实现 代码及效果
    发表于 08-06 14:29

    图像中的圆怎么求圆的半径

    图像中的圆,怎么求圆的半径,这图的数据已经放在以为一维数组里了
    发表于 03-16 04:38

    快速图像连通域标记算法有哪几个环节?特点是什么?

    怎么实现图像连通体检测?快速图像连通域标记算法有哪几个环节?特点是什么?
    发表于 04-08 06:49