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的Tornado框架中的日志的方法
May 02 Python
python中urlparse模块介绍与使用示例
Nov 19 Python
用tensorflow搭建CNN的方法
Mar 05 Python
Python实现多线程的两种方式分析
Aug 29 Python
用Python和WordCloud绘制词云的实现方法(内附让字体清晰的秘笈)
Jan 08 Python
Python字符串通过'+'和join函数拼接新字符串的性能测试比较
Mar 05 Python
详解python中的hashlib模块的使用
Apr 22 Python
Python中的十大图像处理工具(小结)
Jun 10 Python
python将print输出的信息保留到日志文件中
Sep 27 Python
python导入不同目录下的自定义模块过程解析
Nov 18 Python
解决Pytorch 加载训练好的模型 遇到的error问题
Jan 10 Python
10个python3常用排序算法详细说明与实例(快速排序,冒泡排序,桶排序,基数排序,堆排序,希尔排序,归并排序,计数排序)
Mar 17 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
PHP5 字符串处理函数大全
2010/03/23 PHP
php中url传递中文字符,特殊危险字符的解决方法
2013/08/17 PHP
php实现按照权重随机排序数据的方法
2015/01/09 PHP
Yii2中设置与获取别名的函数(setAlias和getAlias)用法分析
2016/07/25 PHP
php微信公众平台开发(一) 配置接口
2016/12/06 PHP
Thinkphp 中 distinct 的用法解析
2016/12/14 PHP
微信小程序 弹幕功能简单实例
2017/02/14 Javascript
easyui-edatagrid.js实现回车键结束编辑功能的实例
2017/04/12 Javascript
vue侧边栏动态生成下级菜单的方法
2018/09/07 Javascript
vue-cli脚手架搭建的项目去除eslint验证的方法
2018/09/29 Javascript
vue中的v-if和v-show的区别详解
2019/09/01 Javascript
如何在Vue中抽离接口配置文件
2019/10/31 Javascript
JavaScript函数重载操作实例浅析
2020/05/02 Javascript
不管你的Python报什么错,用这个模块就能正常运行
2018/09/14 Python
Python从单元素字典中获取key和value的实例
2018/12/31 Python
Django中的cookie和session
2019/08/27 Python
Python Tkinter Entry和Text的添加与使用详解
2020/03/04 Python
pytorch读取图像数据转成opencv格式实例
2020/06/02 Python
解决阿里云邮件发送不能使用25端口问题
2020/08/07 Python
CSS3等相关属性制作分页导航实现代码
2012/12/24 HTML / CSS
阿迪达斯印度官方商城:adidas India
2017/03/26 全球购物
Linux内核的同步机制是什么?主要有哪几种内核锁
2016/07/11 面试题
Final类有什么特点
2012/04/25 面试题
总经理助理岗位职责
2013/11/08 职场文书
求职信范文英文版
2014/01/05 职场文书
新护士岗前培训制度
2014/02/02 职场文书
党支部换届选举方案
2014/05/08 职场文书
优秀本科毕业生自荐信
2014/07/04 职场文书
2014年党的群众路线教育实践活动整改措施(个人版)
2014/09/25 职场文书
离婚财产分配协议书
2014/10/21 职场文书
2015年推普周活动方案
2015/05/06 职场文书
喋血孤城观后感
2015/06/08 职场文书
小学语文的各类谚语(70首)
2019/08/15 职场文书
竞聘演讲报告:基本写作有哪些?附开头范文
2019/10/16 职场文书
2019年农民幸福观调查的实践感悟
2019/12/19 职场文书
Python3.8官网文档之类的基础语法阅读
2021/09/04 Python