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

相关文章

Python中你不知道的gzip高级用法分享

《Python中你不知道的gzip高级用法分享》在当今大数据时代,数据存储和传输成本已成为每个开发者必须考虑的问题,Python内置的gzip模块提供了一种简单高效的解决方案,下面小编就来和大家详细讲... 目录前言:为什么数据压缩如此重要1. gzip 模块基础介绍2. 基本压缩与解压缩操作2.1 压缩文

Python设置Cookie永不超时的详细指南

《Python设置Cookie永不超时的详细指南》Cookie是一种存储在用户浏览器中的小型数据片段,用于记录用户的登录状态、偏好设置等信息,下面小编就来和大家详细讲讲Python如何设置Cookie... 目录一、Cookie的作用与重要性二、Cookie过期的原因三、实现Cookie永不超时的方法(一)

MySQL中查找重复值的实现

《MySQL中查找重复值的实现》查找重复值是一项常见需求,比如在数据清理、数据分析、数据质量检查等场景下,我们常常需要找出表中某列或多列的重复值,具有一定的参考价值,感兴趣的可以了解一下... 目录技术背景实现步骤方法一:使用GROUP BY和HAVING子句方法二:仅返回重复值方法三:返回完整记录方法四:

Python内置函数之classmethod函数使用详解

《Python内置函数之classmethod函数使用详解》:本文主要介绍Python内置函数之classmethod函数使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录1. 类方法定义与基本语法2. 类方法 vs 实例方法 vs 静态方法3. 核心特性与用法(1编程客

IDEA中新建/切换Git分支的实现步骤

《IDEA中新建/切换Git分支的实现步骤》本文主要介绍了IDEA中新建/切换Git分支的实现步骤,通过菜单创建新分支并选择是否切换,创建后在Git详情或右键Checkout中切换分支,感兴趣的可以了... 前提:项目已被Git托管1、点击上方栏Git->NewBrancjsh...2、输入新的分支的

Python函数作用域示例详解

《Python函数作用域示例详解》本文介绍了Python中的LEGB作用域规则,详细解析了变量查找的四个层级,通过具体代码示例,展示了各层级的变量访问规则和特性,对python函数作用域相关知识感兴趣... 目录一、LEGB 规则二、作用域实例2.1 局部作用域(Local)2.2 闭包作用域(Enclos

Python实现对阿里云OSS对象存储的操作详解

《Python实现对阿里云OSS对象存储的操作详解》这篇文章主要为大家详细介绍了Python实现对阿里云OSS对象存储的操作相关知识,包括连接,上传,下载,列举等功能,感兴趣的小伙伴可以了解下... 目录一、直接使用代码二、详细使用1. 环境准备2. 初始化配置3. bucket配置创建4. 文件上传到os

关于集合与数组转换实现方法

《关于集合与数组转换实现方法》:本文主要介绍关于集合与数组转换实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、Arrays.asList()1.1、方法作用1.2、内部实现1.3、修改元素的影响1.4、注意事项2、list.toArray()2.1、方

使用Python实现可恢复式多线程下载器

《使用Python实现可恢复式多线程下载器》在数字时代,大文件下载已成为日常操作,本文将手把手教你用Python打造专业级下载器,实现断点续传,多线程加速,速度限制等功能,感兴趣的小伙伴可以了解下... 目录一、智能续传:从崩溃边缘抢救进度二、多线程加速:榨干网络带宽三、速度控制:做网络的好邻居四、终端交互

Python中注释使用方法举例详解

《Python中注释使用方法举例详解》在Python编程语言中注释是必不可少的一部分,它有助于提高代码的可读性和维护性,:本文主要介绍Python中注释使用方法的相关资料,需要的朋友可以参考下... 目录一、前言二、什么是注释?示例:三、单行注释语法:以 China编程# 开头,后面的内容为注释内容示例:示例:四