【cv智能检测】图像识别对产品中形状不合格的残次品的智能检测

2023-11-10 20:59

本文主要是介绍【cv智能检测】图像识别对产品中形状不合格的残次品的智能检测,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

CV对图像中产品的质量进行检测

检测原理:

	对图像进行系列操作完成图像的拆分,然后通过构建图像中物体的外接圆,并通过图像面积和外接圆面积的比值是否大于预先定义的阈值,来确定物品形状是不是残次品。

检测过程:

在这里插入图片描述

核心代码:

import cv2
from cv.basic.imsw import show,show2
import numpy as np
#读取图像
img = cv2.imread('img1/cutobj.jpg')
#预先处理步骤
gray = cv2.cvtColor(img,cv2.COLOR_BGR2GRAY)
#图像二值化
ret,thresh = cv2.threshold(gray,0,255,cv2.THRESH_BINARY+cv2.THRESH_OTSU)
#开运算核定义
kernel = cv2.getStructuringElement(cv2.MORPH_CROSS,(3,3))
#形态学开运算
op=cv2.morphologyEx(thresh,cv2.MORPH_OPEN,kernel,iterations=1)
#距离变换确定前景点,大于3为前景
dist_tf = cv2.distanceTransform(op,cv2.DIST_L2,3)
ret,fore = cv2.threshold(dist_tf,0.3*dist_tf.max(),255,0)
#把前景fore去噪
kernel=np.ones((3,3),np.uint8)
op2 = cv2.morphologyEx(fore,cv2.MORPH_OPEN,kernel)
#把去噪后的图像恢复数组图np.array()
op2 = np.array(op2,np.uint8)
#对图像进行精确提取轮廓
contours,_ = cv2.findContours(op2,cv2.RETR_TREE,cv2.CHAIN_APPROX_SIMPLE)
#进行缺陷检测
count=0
good=0
font=cv2.FONT_HERSHEY_COMPLEX
for cnt in contours:(x,y),ras=cv2.minEnclosingCircle(cnt)center = (int(x),int(y))ras = int(ras)circle_img = cv2.circle(op2,center,ras,(255,255,255),1)area_circle = 3.14*ras*rasarea = cv2.contourArea(cnt)#通过轮廓面积和外接圆面积比大于阈值0.5证明没有缺陷,1百分百完美。if area/area_circle>=0.5:img=cv2.putText(img,'OK',center,font,1,(255,255,255),2)good+=1else:img = cv2.putText(img, 'bad', center, font, 1, (255, 255, 255), 2)count += 1
img = cv2.putText(img,('total={},OK={}'.format(count,good)),(20,30),font,1,(255,255,255),)
show(img)

结果输出

左图为源图,右图为结果图
在这里插入图片描述

这篇关于【cv智能检测】图像识别对产品中形状不合格的残次品的智能检测的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/385205

相关文章

使用Python实现IP地址和端口状态检测与监控

《使用Python实现IP地址和端口状态检测与监控》在网络运维和服务器管理中,IP地址和端口的可用性监控是保障业务连续性的基础需求,本文将带你用Python从零打造一个高可用IP监控系统,感兴趣的小伙... 目录概述:为什么需要IP监控系统使用步骤说明1. 环境准备2. 系统部署3. 核心功能配置系统效果展

基于Python打造一个智能单词管理神器

《基于Python打造一个智能单词管理神器》这篇文章主要为大家详细介绍了如何使用Python打造一个智能单词管理神器,从查询到导出的一站式解决,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 项目概述:为什么需要这个工具2. 环境搭建与快速入门2.1 环境要求2.2 首次运行配置3. 核心功能使用指

Python实现word文档内容智能提取以及合成

《Python实现word文档内容智能提取以及合成》这篇文章主要为大家详细介绍了如何使用Python实现从10个左右的docx文档中抽取内容,再调整语言风格后生成新的文档,感兴趣的小伙伴可以了解一下... 目录核心思路技术路径实现步骤阶段一:准备工作阶段二:内容提取 (python 脚本)阶段三:语言风格调

使用Python实现表格字段智能去重

《使用Python实现表格字段智能去重》在数据分析和处理过程中,数据清洗是一个至关重要的步骤,其中字段去重是一个常见且关键的任务,下面我们看看如何使用Python进行表格字段智能去重吧... 目录一、引言二、数据重复问题的常见场景与影响三、python在数据清洗中的优势四、基于Python的表格字段智能去重

Spring AI集成DeepSeek三步搞定Java智能应用的详细过程

《SpringAI集成DeepSeek三步搞定Java智能应用的详细过程》本文介绍了如何使用SpringAI集成DeepSeek,一个国内顶尖的多模态大模型,SpringAI提供了一套统一的接口,简... 目录DeepSeek 介绍Spring AI 是什么?Spring AI 的主要功能包括1、环境准备2

Spring AI与DeepSeek实战一之快速打造智能对话应用

《SpringAI与DeepSeek实战一之快速打造智能对话应用》本文详细介绍了如何通过SpringAI框架集成DeepSeek大模型,实现普通对话和流式对话功能,步骤包括申请API-KEY、项目搭... 目录一、概述二、申请DeepSeek的API-KEY三、项目搭建3.1. 开发环境要求3.2. mav

Python3脚本实现Excel与TXT的智能转换

《Python3脚本实现Excel与TXT的智能转换》在数据处理的日常工作中,我们经常需要将Excel中的结构化数据转换为其他格式,本文将使用Python3实现Excel与TXT的智能转换,需要的可以... 目录场景应用:为什么需要这种转换技术解析:代码实现详解核心代码展示改进点说明实战演练:从Excel到

Python如何实现PDF隐私信息检测

《Python如何实现PDF隐私信息检测》随着越来越多的个人信息以电子形式存储和传输,确保这些信息的安全至关重要,本文将介绍如何使用Python检测PDF文件中的隐私信息,需要的可以参考下... 目录项目背景技术栈代码解析功能说明运行结php果在当今,数据隐私保护变得尤为重要。随着越来越多的个人信息以电子形

java图像识别工具类(ImageRecognitionUtils)使用实例详解

《java图像识别工具类(ImageRecognitionUtils)使用实例详解》:本文主要介绍如何在Java中使用OpenCV进行图像识别,包括图像加载、预处理、分类、人脸检测和特征提取等步骤... 目录前言1. 图像识别的背景与作用2. 设计目标3. 项目依赖4. 设计与实现 ImageRecogni

SpringBoot使用Apache Tika检测敏感信息

《SpringBoot使用ApacheTika检测敏感信息》ApacheTika是一个功能强大的内容分析工具,它能够从多种文件格式中提取文本、元数据以及其他结构化信息,下面我们来看看如何使用Ap... 目录Tika 主要特性1. 多格式支持2. 自动文件类型检测3. 文本和元数据提取4. 支持 OCR(光学