广告
返回顶部
首页 > 资讯 > 操作系统 >opencv 案例05-基于二值图像分析(简单缺陷检测)
  • 250
分享到

opencv 案例05-基于二值图像分析(简单缺陷检测)

opencv人工智能计算机视觉目标检测 2023-08-30 14:08:05 250人浏览 安东尼
摘要

缺陷检测,分为两个部分,一个部分是提取指定的轮廓,第二个部分通过对比实现划痕检测与缺角检测。本次主要搞定第一部分,学会观察图像与提取图像ROI对象轮廓外接矩形与轮廓。 下面是基于二值图像分析的大致流程 读取图像将图像转换为灰度图,并对其进行

缺陷检测,分为两个部分,一个部分是提取指定的轮廓,第二个部分通过对比实现划痕检测与缺角检测。本次主要搞定第一部分,学会观察图像与提取图像ROI对象轮廓外接矩形与轮廓。

下面是基于二值图像分析的大致流程

  1. 读取图像
  2. 将图像转换为灰度图,并对其进行二值化处理。
# 图像二值化gray = cv.cvtColor(src, cv.COLOR_BGR2GRAY)ret, binary = cv.threshold(gray, 0, 255, cv.THRESH_BINARY_INV | 
  1. 进行形态学开运算以去除噪声和平滑图像。
cv.THRESH_OTSU)# 形态学开运算去除噪声和平滑图像se = cv.getStructuringElement(cv.MORPH_RECT, (3, 3), (-1, -1))binary = cv.morphologyEx(binary, cv.MORPH_OPEN, se)cv.imshow("binary", binary)

在这里插入图片描述

  1. 提取图像中的轮廓。
# 提取图像中的轮廓contours, hierarchy = cv.findContours(binary, cv.RETR_LIST, cv.CHaiN_APPROX_SIMPLE)
  1. 针对每个轮廓,计算其外接矩形,并根据一些条件绘制矩形和轮廓。
height, width = src.shape[:2]for c in range(len(contours)):    x, y, w, h = cv.boundingRect(contours[c])    area = cv.contourArea(contours[c])    # 根据条件过滤不符合要求的轮廓    if h > (height//2):        continue    if area < 150:        continue    cv.rectangle(src, (x, y), (x+w, y+h), (0, 0, 255), 1, 8, 0)    cv.drawContours(src, contours, c, (0, 255, 0), 2, 8)

整理示例:检测图片中的缺陷并将缺陷框选出来

原图:

在这里插入图片描述

代码如下:

import cv2 as cvsrc = cv.imread("que01.jpg")cv.namedWindow("input", cv.WINDOW_AUTOSIZE)cv.imshow("input", src)# 图像二值化gray = cv.cvtColor(src, cv.COLOR_BGR2GRAY)ret, binary = cv.threshold(gray, 0, 255, cv.THRESH_BINARY_INV | cv.THRESH_OTSU)# 形态学开运算去除噪声和平滑图像se = cv.getStructuringElement(cv.MORPH_RECT, (3, 3), (-1, -1))binary = cv.morphologyEx(binary, cv.MORPH_OPEN, se)cv.imshow("binary", binary)# 提取图像中的轮廓contours, hierarchy = cv.findContours(binary, cv.RETR_LIST, cv.CHAIN_APPROX_SIMPLE)height, width = src.shape[:2]for c in range(len(contours)):    x, y, w, h = cv.boundingRect(contours[c])    area = cv.contourArea(contours[c])    # 根据条件过滤不符合要求的轮廓    if h > (height//2):        continue    if area < 150:        continue    cv.rectangle(src, (x, y), (x+w, y+h), (0, 0, 255), 1, 8, 0)    cv.drawContours(src, contours, c, (0, 255, 0), 2, 8)cv.imshow("result", src)cv.imwrite("binary2.png", src)cv.waiTKEy(0)cv.destroyAllwindows()

运行结果如下:

在这里插入图片描述

示例2:
原图:

在这里插入图片描述

修改上面的图片路径地址运行看效果

在这里插入图片描述

对于明显的缺陷检测还是可以的,但是实际生产的缺陷肯定不是这么明显的,如下图:

在这里插入图片描述

后续讲解这类的缺陷该如何检测,敬请期待!!!!

来源地址:https://blog.csdn.net/hai411741962/article/details/132559908

--结束END--

本文标题: opencv 案例05-基于二值图像分析(简单缺陷检测)

本文链接: https://www.lsjlt.com/news/383053.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作