Opencv+Python识别PCB板图片的步骤


Posted in Python onJanuary 07, 2021

任务要求:

基于模板匹配算法识别PCB板型号

使用工具:

Python3、OpenCV

使用模板匹配算法,模板匹配是一种最原始、最基本的模式识别方法,研究某一特定对象物的图案位于图像的什么地方,进而识别对象物,模板匹配具有自身的局限性,主要表现在它只能进行平行移动,即原图像中的匹配目标不能发生旋转或大小变化。

事先准备好待检测PCB与其对应的模板:

Opencv+Python识别PCB板图片的步骤

子模版:

Opencv+Python识别PCB板图片的步骤

基本流程如下:

1、在整个图像区域发现与给定子图像匹配的小块区域

2、选取模板图像T(给定的子图像)

3、另外需要一个待检测的图像——源图像S

4、工作方法:在检测图像上,从左到右,从上到下计算模板图像与重叠, 子图像的匹配度,匹配程度越大,两者相同的可能性就越大。

OpenCV提供了6种模板匹配算法:

平方差匹配法CV_TM_SQDIFF;

归一化平方差匹配法CV_TM_SQDIFF_NORMED;

相关匹配法CV_TM_CCORR;

归一化相关匹配法CV_TM_CCORR_NORMED;

相关系数匹配法CV_TM_CCOEFF;

归一化相关系数匹配法CV_TM_CCOEFF_NORMED;

后面经过实验,我们主要是从以上的六种中选择了归一化相关系数匹配法CV_TM_CCOEFF_NORMED,基本原理公式为:

 代码部分展示:

import cv2
import numpy as np
from matplotlib import pyplot as plt

#读取检测图像
img = cv2.imread('img8.bmp', 0)
#读取模板图像
template1=cv2.imread('moban1.bmp', 0)
template2=......
#建立模板列表
template=[template1,template2,template3,template4]
# 模板匹配:归一化相关系数匹配方法
res1=cv2.matchTemplate(img, template1, cv2.TM_CCOEFF_NORMED)
res2=cv2.matchTemplate(......)
#提取相关系数
min_val1, max_val1, min_loc1, max_loc1 =cv2.minMaxLoc(res1)
min_val2, ......

#相关系数对比(max_val),越接近1,匹配程度越高
max_val=[1-max_val1,1-max_val2,1-max_val3,1-max_val4]
j=max_val.index(min(max_val))

#根据提取的相关系数得出对应匹配程度最高的模板
h, w = template[j].shape[:2]  # 计算模板图像的高和宽 rows->h, cols->w
pes=cv2.matchTemplate(img, template[j], cv2.TM_CCOEFF_NORMED) #模板匹配
in_val, ax_val, in_loc, ax_loc =cv2.minMaxLoc(pes)

#在原图中框出模板匹配的位置
left_top = ax_loc  # 左上角
right_bottom = (left_top[0] + w, left_top[1] + h)  # 右下角
cv2.rectangle(img, left_top, right_bottom, 255, 2) # 画出矩形位置
#绘制模板图像
plt.subplot(121), plt.imshow(template[j], cmap='gray')
plt.title('pcb type'),plt.xticks([]), plt.yticks([])
#绘制检测图像
plt.subplot(122), plt.imshow(img, cmap='gray')
plt.title('img'), plt.xticks([]), plt.yticks([])
plt.show()

实验结果:

Opencv+Python识别PCB板图片的步骤

需要完整代码以及图片素材的,请留下评论可与博主进行联系。

以上就是Opencv+Python识别PCB板图片的步骤的详细内容,更多关于Opencv+Python识别PCB板的资料请关注三水点靠木其它相关文章!

Python 相关文章推荐
python自动化工具日志查询分析脚本代码实现
Nov 26 Python
Python __setattr__、 __getattr__、 __delattr__、__call__用法示例
Mar 06 Python
Python中shapefile转换geojson的示例
Jan 03 Python
PyQt5+requests实现车票查询工具
Jan 21 Python
Python3按一定数据位数格式处理bin文件的方法
Jan 24 Python
python开头的coding设置方法
Aug 08 Python
python opencv实现证件照换底功能
Aug 19 Python
python Matplotlib数据可视化(2):详解三大容器对象与常用设置
Sep 30 Python
pycharm 2020.2.4 pip install Flask 报错 Error:Non-zero exit code的问题
Dec 04 Python
Python爬取科目四考试题库的方法实现
Mar 30 Python
Python的flask接收前台的ajax的post数据和get数据的方法
Apr 12 Python
python 用递归实现通用爬虫解析器
Apr 16 Python
Django使用django-simple-captcha做验证码的实现示例
Jan 07 #Python
python 实现百度网盘非会员上传超过500个文件的方法
Jan 07 #Python
Django权限控制的使用
Jan 07 #Python
详解Django关于StreamingHttpResponse与FileResponse文件下载的最优方法
Jan 07 #Python
Jupyter Notebook添加代码自动补全功能的实现
Jan 07 #Python
jupyter notebook更换皮肤主题的实现
Jan 07 #Python
基于 Python 实践感知器分类算法
Jan 07 #Python
You might like
使用PHP遍历文件夹与子目录的函数代码
2011/09/26 PHP
利用php+mcDropdown实现文件路径可在下拉框选择
2013/08/07 PHP
php微信开发之百度天气预报
2016/11/18 PHP
深入理解PHP中mt_rand()随机数的安全
2017/10/12 PHP
PHP仿tp实现mvc框架基本设计思路与实现方法分析
2018/05/23 PHP
laravel接管Dingo-api和默认的错误处理方式
2019/10/25 PHP
解析Jquery中如何把一段html代码动态写入到DIV中(实例说明)
2013/07/09 Javascript
Javascript实现获取窗口的大小和位置代码分享
2014/12/04 Javascript
DOM基础教程之使用DOM控制表格
2015/01/20 Javascript
原生JS实现LOADING效果
2015/03/16 Javascript
jQuery实现折叠、展开的菜单组效果代码
2015/09/16 Javascript
在 Express 中使用模板引擎
2015/12/10 Javascript
jQuery+ajax实现文章点赞功能的方法
2015/12/31 Javascript
JS工作中的小贴士之”闭包“与事件委托的”阻止冒泡“
2016/06/16 Javascript
浅谈JavaScript事件绑定的常用方法及其优缺点分析
2016/11/01 Javascript
zTree实现节点修改的实时刷新功能
2017/03/20 Javascript
js模拟支付宝密码输入框
2017/04/11 Javascript
微信小程序 http请求的session管理
2017/06/07 Javascript
JS 中document.write()的用法和清空的原因浅析
2017/12/04 Javascript
详解vue-router 命名路由和命名视图
2018/06/01 Javascript
javascript和php使用ajax通信传递JSON的实例
2018/08/21 Javascript
微信小程序登录对接Django后端实现JWT方式验证登录详解
2019/07/29 Javascript
如何实现echarts markline标签名显示自己想要的
2020/07/20 Javascript
原生js实现贪吃蛇游戏
2020/10/26 Javascript
js动态添加带圆圈序号列表的实例代码
2021/02/18 Javascript
[01:48]帕吉至宝加入游戏,遗迹战场现“千劫神屠”
2018/04/07 DOTA
Python字典操作简明总结
2015/04/13 Python
浅谈python多线程和队列管理shell程序
2015/08/04 Python
Python 逐行分割大txt文件的方法
2017/10/10 Python
python批量修改文件编码格式的方法
2018/05/31 Python
Python实现的爬取百度文库功能示例
2019/02/16 Python
pytorch程序异常后删除占用的显存操作
2020/01/13 Python
大学同学聚会邀请函
2014/01/19 职场文书
入党自我评价优缺点
2014/01/25 职场文书
人力管理专业毕业生求职信
2014/02/27 职场文书
乡镇机关党员民主评议表自我评价
2014/09/21 职场文书