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查找第k小元素代码分享
Dec 18 Python
Python爬虫设置代理IP的方法(爬虫技巧)
Mar 04 Python
Python中pillow知识点学习
Apr 30 Python
selenium+python 对输入框的输入处理方法
Oct 11 Python
python xlwt如何设置单元格的自定义背景颜色
Sep 03 Python
Django框架反向解析操作详解
Nov 28 Python
tensorflow 实现打印pb模型的所有节点
Jan 23 Python
Python class的继承方法代码实例
Feb 14 Python
openCV提取图像中的矩形区域
Jul 21 Python
Scrapy基于scrapy_redis实现分布式爬虫部署的示例
Sep 29 Python
详解Python类和对象内容
Jun 22 Python
Python GUI编程之tkinter 关于 ttkbootstrap 的使用详解
Mar 03 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 Zip解压 文件在线解压缩的函数代码
2010/05/26 PHP
深入理解用mysql_fetch_row()以数组的形式返回查询结果
2013/06/05 PHP
php中array_unshift()修改数组key注意事项分析
2016/05/16 PHP
PHP Class SoapClient not found解决方法
2018/01/20 PHP
javascript flash下fromCharCode和charCodeAt方法使用说明
2008/01/12 Javascript
JavaScript cookie的设置获取删除详解
2014/02/11 Javascript
js实现鼠标悬停图片上时滚动文字说明的方法
2015/02/17 Javascript
Three.js学习之正交投影照相机
2016/08/01 Javascript
JS数组排序方法实例分析
2016/12/16 Javascript
前端构建工具之gulp的语法教程
2017/06/12 Javascript
微信小程序页面滑动屏幕加载数据效果
2020/11/16 Javascript
关于axios不能使用Vue.use()浅析
2018/01/12 Javascript
React组件中的this的具体使用
2018/02/28 Javascript
node版本管理工具n包使用教程详解
2018/11/09 Javascript
JS/HTML5游戏常用算法之路径搜索算法 A*寻路算法完整实例
2018/12/14 Javascript
原生js实现公告滚动效果
2021/01/10 Javascript
小程序两种滚动公告栏的实现方法
2019/09/17 Javascript
盘点提高 Python 代码效率的方法
2014/07/03 Python
Python设置默认编码为utf8的方法
2016/07/01 Python
Python、PyCharm安装及使用方法(Mac版)详解
2017/04/28 Python
Python异常处理操作实例详解
2018/05/10 Python
python实现Flappy Bird源码
2018/12/24 Python
Python设计模式之状态模式原理与用法详解
2019/01/15 Python
python 基于TCP协议的套接字编程详解
2019/06/29 Python
Python队列RabbitMQ 使用方法实例记录
2019/08/05 Python
解决Numpy中sum函数求和结果维度的问题
2019/12/06 Python
浅析rem和em和px vh vw和% 移动端长度单位
2016/04/28 HTML / CSS
NFL欧洲商店(德国):NFL Europe Shop DE
2018/11/03 全球购物
SheIn沙特阿拉伯:女装在线
2020/03/23 全球购物
建筑装饰学院室内设计专业个人自我评价
2013/12/07 职场文书
十岁生日家长答谢词
2014/01/17 职场文书
《散步》教学反思
2014/03/02 职场文书
双语教学实施方案
2014/03/23 职场文书
销售顾问工作计划书
2014/08/15 职场文书
2015年元旦促销方案书
2014/12/09 职场文书
2015年人民调解工作总结
2015/05/18 职场文书