python 实现工业生成批号的旋转

2023-10-30 17:41

本文主要是介绍python 实现工业生成批号的旋转,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

问题提出:流水线的旋转批号  进行识别 ,识别的基础就是对图片进行旋转到上方,这样有助于ocR识别

面对这个问题,提出的思路是 提出一个正确的图案,使用sift匹配 输入图案与模版的特征图,生成匹配好的特征对,然后根据特征独取出坐标 ,对坐标进行欧式聚类计算,形成n个距离,使用方差来判定是否正确匹配

为了更好的处理特征对,对图片 形态学处理,找出字符的外接矩形框 

最后截图 并保存,

下面给出部分主要代码:

1、图片输入 并计算sift特征

sift = cv2.xfeatures2d.SURF_create()kp1, des1 = sift.detectAndCompute(img1_gray, None)kp2, des2 = sift.detectAndCompute(imgRot, None)# BFmatcher with default parmsbf = cv2.BFMatcher(cv2.NORM_L2)matches = bf.knnMatch(des1, des2, k = 2) goodMatch = []                 #利用sift算子 进行筛选匹配for m,n in matches:if m.distance < 0.6*n.distance:#可以调节的参数  特征点匹配约束  数字越小 效果越精确goodMatch.append(m)p1 = [kpp.queryIdx for kpp in goodMatch]   #解析出 相似的一对 点的坐标p2 = [kpp.trainIdx for kpp in goodMatch]   post1 = np.int32([kp1[pp].pt for pp in p1])#    post2 = np.int32([kp2[pp].pt for pp in p2]) + (w1, 0)post2 = np.int32([kp2[pp].pt for pp in p2])list=[]for (x1, y1), (x2, y2) in zip(post1, post2):
#        print(x1,y1,x2,y2)p1=np.array([x1,y1])           #利用相似对应点 距离相同的原理,利用距离方差大小判断 是否旋转到合理的角度p2=np.array([x2 ,y2 ])p3=p2-p1p4=math.hypot(p3[0],p3[1])list.append(p4)listvar=np.var(list)ave=listvar/len(list)

2、其中不断旋转图片,使其符合筛选需要

le=imgRot.shape[1]l1=int(le/2-150)l2=int(le/2+150)imgR=imgRot[l1:l2,l1:l2]gray = cv2.cvtColor(imgR, cv2.COLOR_BGR2GRAY)(_, thresh) = cv2.threshold(gray, 100, 255, cv2.THRESH_BINARY)closed = cv2.erode(thresh, None, iterations = 12)closed1=255-closed# find the contours in the thresholded image, then sort the contours# by their area, keeping only the largest onecnts = cv2.findContours(closed1.copy(), cv2.RETR_EXTERNAL,cv2.CHAIN_APPROX_SIMPLE)cnts = imutils.grab_contours(cnts)c = sorted(cnts, key = cv2.contourArea, reverse = True)[0]# compute the rotated bounding box of the largest contourrect = cv2.minAreaRect(c)box_origin = cv2.cv.BoxPoints(rect) if imutils.is_cv2() else cv2.boxPoints(rect)box1 = np.int0(box_origin)cv2.drawContours(imgR, [box1], -1, (0,255,0), 3)cv2.imshow("Image", imgR)cv2.waitKey(0)

3、最终裁剪图片下面把涉及到的函数贴一下

def imagecrop(image,box):xs = [x[1] for x in box]ys = [x[0] for x in box]cropimage = image[min(xs):max(xs),min(ys):max(ys)] cv2.imwrite('cropimage2.png',cropimage)return cropimage
def Nrotate(angle,valuex,valuey,pointx,pointy):angle = (angle/180)*math.pivaluex = np.array(valuex)valuey = np.array(valuey)nRotatex = (valuex-pointx)*math.cos(angle) - (valuey-pointy)*math.sin(angle) + pointxnRotatey = (valuex-pointx)*math.sin(angle) + (valuey-pointy)*math.cos(angle) + pointyreturn (nRotatex, nRotatey)
#顺时针旋转
def Srotate(angle,valuex,valuey,pointx,pointy):angle = (angle/180)*math.pivaluex = np.array(valuex)valuey = np.array(valuey)sRotatex = (valuex-pointx)*math.cos(angle) + (valuey-pointy)*math.sin(angle) + pointxsRotatey = (valuey-pointy)*math.cos(angle) - (valuex-pointx)*math.sin(angle) + pointyreturn (sRotatex,sRotatey)
#将四个点做映射
def rotatecordiate(angle,rectboxs,pointx,pointy):output = []for rectbox in rectboxs:if angle>0:output.append(Srotate(angle,rectbox[0],rectbox[1],pointx,pointy))else:output.append(Nrotate(-angle,rectbox[0],rectbox[1],pointx,pointy))return outputdef rotate_bound_white_bg(image, angle):# grab the dimensions of the image and then determine the# center(h, w) = image.shape[:2](cX, cY) = (w // 2, h // 2)# grab the rotation matrix (applying the negative of the# angle to rotate clockwise), then grab the sine and cosine# (i.e., the rotation components of the matrix)# -angle位置参数为角度参数负值表示顺时针旋转; 1.0位置参数scale是调整尺寸比例(图像缩放参数),建议0.75M = cv2.getRotationMatrix2D((cX, cY), -angle, 1.0)cos = np.abs(M[0, 0])sin = np.abs(M[0, 1]) # compute the new bounding dimensions of the imagenW = int((h * sin) + (w * cos))nH = int((h * cos) + (w * sin)) # adjust the rotation matrix to take into account translationM[0, 2] += (nW / 2) - cXM[1, 2] += (nH / 2) - cY # borderValue 缺失背景填充色彩,此处为白色,可自定义return cv2.warpAffine(image, M, (nW, nH),borderValue=(0,0,0))# borderValue 缺省,默认是黑色(0, 0 , 0)# return cv2.warpAffine(image, M, (nW, nH)) 

如果需要可以下载我的完成程序,交流请联系哦

完整代码https://download.csdn.net/download/weixin_44576543/12594632

 

 

 

这篇关于python 实现工业生成批号的旋转的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Oracle查询优化之高效实现仅查询前10条记录的方法与实践

《Oracle查询优化之高效实现仅查询前10条记录的方法与实践》:本文主要介绍Oracle查询优化之高效实现仅查询前10条记录的相关资料,包括使用ROWNUM、ROW_NUMBER()函数、FET... 目录1. 使用 ROWNUM 查询2. 使用 ROW_NUMBER() 函数3. 使用 FETCH FI

Python脚本实现自动删除C盘临时文件夹

《Python脚本实现自动删除C盘临时文件夹》在日常使用电脑的过程中,临时文件夹往往会积累大量的无用数据,占用宝贵的磁盘空间,下面我们就来看看Python如何通过脚本实现自动删除C盘临时文件夹吧... 目录一、准备工作二、python脚本编写三、脚本解析四、运行脚本五、案例演示六、注意事项七、总结在日常使用

Java实现Excel与HTML互转

《Java实现Excel与HTML互转》Excel是一种电子表格格式,而HTM则是一种用于创建网页的标记语言,虽然两者在用途上存在差异,但有时我们需要将数据从一种格式转换为另一种格式,下面我们就来看看... Excel是一种电子表格格式,广泛用于数据处理和分析,而HTM则是一种用于创建网页的标记语言。虽然两

Java中Springboot集成Kafka实现消息发送和接收功能

《Java中Springboot集成Kafka实现消息发送和接收功能》Kafka是一个高吞吐量的分布式发布-订阅消息系统,主要用于处理大规模数据流,它由生产者、消费者、主题、分区和代理等组件构成,Ka... 目录一、Kafka 简介二、Kafka 功能三、POM依赖四、配置文件五、生产者六、消费者一、Kaf

Python将大量遥感数据的值缩放指定倍数的方法(推荐)

《Python将大量遥感数据的值缩放指定倍数的方法(推荐)》本文介绍基于Python中的gdal模块,批量读取大量多波段遥感影像文件,分别对各波段数据加以数值处理,并将所得处理后数据保存为新的遥感影像... 本文介绍基于python中的gdal模块,批量读取大量多波段遥感影像文件,分别对各波段数据加以数值处

python管理工具之conda安装部署及使用详解

《python管理工具之conda安装部署及使用详解》这篇文章详细介绍了如何安装和使用conda来管理Python环境,它涵盖了从安装部署、镜像源配置到具体的conda使用方法,包括创建、激活、安装包... 目录pytpshheraerUhon管理工具:conda部署+使用一、安装部署1、 下载2、 安装3

Python进阶之Excel基本操作介绍

《Python进阶之Excel基本操作介绍》在现实中,很多工作都需要与数据打交道,Excel作为常用的数据处理工具,一直备受人们的青睐,本文主要为大家介绍了一些Python中Excel的基本操作,希望... 目录概述写入使用 xlwt使用 XlsxWriter读取修改概述在现实中,很多工作都需要与数据打交

使用Python实现在Word中添加或删除超链接

《使用Python实现在Word中添加或删除超链接》在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能,本文将为大家介绍一下Python如何实现在Word中添加或... 在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能。通过添加超

MybatisGenerator文件生成不出对应文件的问题

《MybatisGenerator文件生成不出对应文件的问题》本文介绍了使用MybatisGenerator生成文件时遇到的问题及解决方法,主要步骤包括检查目标表是否存在、是否能连接到数据库、配置生成... 目录MyBATisGenerator 文件生成不出对应文件先在项目结构里引入“targetProje

windos server2022里的DFS配置的实现

《windosserver2022里的DFS配置的实现》DFS是WindowsServer操作系统提供的一种功能,用于在多台服务器上集中管理共享文件夹和文件的分布式存储解决方案,本文就来介绍一下wi... 目录什么是DFS?优势:应用场景:DFS配置步骤什么是DFS?DFS指的是分布式文件系统(Distr