【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构建智能BAT文件生成器的完美解决方案

《使用Python构建智能BAT文件生成器的完美解决方案》这篇文章主要为大家详细介绍了如何使用wxPython构建一个智能的BAT文件生成器,它不仅能够为Python脚本生成启动脚本,还提供了完整的文... 目录引言运行效果图项目背景与需求分析核心需求技术选型核心功能实现1. 数据库设计2. 界面布局设计3

Linux系统性能检测命令详解

《Linux系统性能检测命令详解》本文介绍了Linux系统常用的监控命令(如top、vmstat、iostat、htop等)及其参数功能,涵盖进程状态、内存使用、磁盘I/O、系统负载等多维度资源监控,... 目录toppsuptimevmstatIOStatiotopslabtophtopdstatnmon

Python办公自动化实战之打造智能邮件发送工具

《Python办公自动化实战之打造智能邮件发送工具》在数字化办公场景中,邮件自动化是提升工作效率的关键技能,本文将演示如何使用Python的smtplib和email库构建一个支持图文混排,多附件,多... 目录前言一、基础配置:搭建邮件发送框架1.1 邮箱服务准备1.2 核心库导入1.3 基础发送函数二、

C++ 检测文件大小和文件传输的方法示例详解

《C++检测文件大小和文件传输的方法示例详解》文章介绍了在C/C++中获取文件大小的三种方法,推荐使用stat()函数,并详细说明了如何设计一次性发送压缩包的结构体及传输流程,包含CRC校验和自动解... 目录检测文件的大小✅ 方法一:使用 stat() 函数(推荐)✅ 用法示例:✅ 方法二:使用 fsee

OpenCV实现实时颜色检测的示例

《OpenCV实现实时颜色检测的示例》本文主要介绍了OpenCV实现实时颜色检测的示例,通过HSV色彩空间转换和色调范围判断实现红黄绿蓝颜色检测,包含视频捕捉、区域标记、颜色分析等功能,具有一定的参考... 目录一、引言二、系统概述三、代码解析1. 导入库2. 颜色识别函数3. 主程序循环四、HSV色彩空间

基于Python实现智能天气提醒助手

《基于Python实现智能天气提醒助手》这篇文章主要来和大家分享一个实用的Python天气提醒助手开发方案,这个工具可以方便地集成到青龙面板或其他调度框架中使用,有需要的小伙伴可以参考一下... 目录项目概述核心功能技术实现1. 天气API集成2. AI建议生成3. 消息推送环境配置使用方法完整代码项目特点

JavaScript实战:智能密码生成器开发指南

本文通过JavaScript实战开发智能密码生成器,详解如何运用crypto.getRandomValues实现加密级随机密码生成,包含多字符组合、安全强度可视化、易混淆字符排除等企业级功能。学习密码强度检测算法与信息熵计算原理,获取可直接嵌入项目的完整代码,提升Web应用的安全开发能力 目录

利用Python实现Excel文件智能合并工具

《利用Python实现Excel文件智能合并工具》有时候,我们需要将多个Excel文件按照特定顺序合并成一个文件,这样可以更方便地进行后续的数据处理和分析,下面我们看看如何使用Python实现Exce... 目录运行结果为什么需要这个工具技术实现工具的核心功能代码解析使用示例工具优化与扩展有时候,我们需要将

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

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

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

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