当前位置: 首页 > news >正文

北京通州马桥网站建设梧州房地产信息网官网

北京通州马桥网站建设,梧州房地产信息网官网,安庆专业网站建设公,设计在线中国简介#xff1a;本文深入探讨 OpenCV 中的模板匹配技术。详细介绍构建输入图像与模板图像的步骤#xff0c;包括读取、截取、滤波与存储等操作。剖析 cv2.matchTemplate 语法及其参数含义#xff0c;阐述不同匹配方法下结果值的意义。同时讲解 cv2.minMaxLoc 语法#xff0… 简介本文深入探讨 OpenCV 中的模板匹配技术。详细介绍构建输入图像与模板图像的步骤包括读取、截取、滤波与存储等操作。剖析 cv2.matchTemplate 语法及其参数含义阐述不同匹配方法下结果值的意义。同时讲解 cv2.minMaxLoc 语法并通过代码示例展示单模板匹配查找最小值与最大值的实现过程以及多模板匹配的完整步骤涵盖阈值设定、解的获取与标记绘制等助您全面掌握 OpenCV 模板匹配要点提升图像处理能力。 如果你觉得本文对你的OpenCV模板匹配学习有所帮助请帮我点赞收藏 关注我会持续创作更多的OpenCV相关的博文帮助你我共同进步。 OpenCV 模板匹配全解析从单模板到多模板的实战指南 模板匹配构建输入图像 与模板图像 cv2.matchTemplate语法cv2.minMaxLoc语法单模板匹配查找最小值单模板匹配最大值多模版匹配致谢 模板匹配 是指把模板图像与输入进行比对滑动遍历所有像素找到相似的。 在OpenCV中使用模板匹配分成两种一种是单模版匹配一种是多模板匹配。在本次的代码中使用了pig.JPG图像进行实验大家可以复制图片然后跟自己的代码放在同一个文件夹下运行 构建输入图像 与模板图像 模板图像构建的思路如下: 第一步把这个pig.JPG图像使用cv2.imread读取到项目文件中 第二步选择猪猪的眼睛对应的那部分np数组的索引 第三步使用高斯滤波对这部分进行平滑处理 第四步使用cv2.imwrite函数将做好的模板部分保存到pig_eye.JPG中 这里使用高斯滤波的目的是为了不让截取的图片和原图一模一样 import cv2 import numpy as np img cv2.imread(pig.JPG) # print(img.shape) img img[300:400,220:370] img cv2.GaussianBlur(img,(5,5),0) r cv2.imwrite(eye.JPG,img) cv2.imshow(eye,img) cv2.waitKey() cv2.destroyAllWindows()构建输入图像是为了可以实现验证多模板匹配的效果 第一步读取pig.JPG图片的shape 第二步构建一个两倍宽度的全0数组 第三步将图片复制到数组中 第四步展示复制效果 import cv2 import numpy as np img cv2.imread(pig.JPG) height,width,channels img.shape empty np.zeros((height,2*width,channels),dtype np.uint8) empty[0:height,0:width] img empty[0:height,width:width*2] img r cv2.imwrite(moudle.JPG,empty) cv2.imshow(moudle,empty) cv2.waitKey() cv2.destroyAllWindows()cv2.matchTemplate语法 result 返回值是由每个位置比较结果构成的一个结果集 他的尺寸是 输入图像 - 模板图像1 无论是宽还是高都一样 cv2.matchTemplateimage输入图像templ模板图像method匹配方法mask通常使用默认值 仅支持TM_SQDIFF 和 TM_CCORR_NORMED 对于参数method而言分两种情况 若值为cv2.TM_SQDIFF和cv2.TM_SQDIFF_NORMED时result值越低匹配效果越好若值为cv2.TM_CCORR和cv2.TM_CCORR_NORMED和cv2.TM-CCOEFF和cv2.TM-CCOEFF_NORMED时值越大匹配效果越好 cv2.minMaxLoc语法 minVal 返回的最小值,maxVal 返回的最大值,minLoc最小值的位置,maxLoc最大值的位置 cv2.minMaxLoc( 数组) 单模板匹配查找最小值 第一步cv2.matchTemplate选择method 第二步把筛选结果放入cv2.minMaxLoc函数进行找最小值得位置 第三步这个位置是模板匹配的左上角根据宽高还原 第四步使用cv2.rectangle画白色标记没用过没关系看代码一眼就明白了 import cv2 import numpy as np import matplotlib.pyplot as plt img cv2.imread(pig.JPG,0) template cv2.imread(eye.JPG,0) # 获取模板图像的宽度和高度 th,tw template.shape[::] # 匹配获得结果 result cv2.matchTemplate(img,template,cv2.TM_SQDIFF) # 找到最小值就是结果最好的位置 minVal,_,minLoc,_ cv2.minMaxLoc(result) # 左上角坐标 topLeft minLoc # 右下角坐标 bottomRight topLeft[0]tw,topLeft[1]th # 画框 需要左上角右下角 灰度值范围 和框的宽度 cv2.rectangle(img,topLeft,bottomRight,255,2)plt.subplot(121) plt.imshow(template,cmap gray) plt.title(template_image) plt.axis(off)plt.subplot(122) plt.imshow(img,cmap gray) plt.title(result) plt.axis(off)单模板匹配最大值 只要你读懂了上一个例子这里只需要修改method参数和选最大值就解决了直接上代码 import cv2 import numpy as np import matplotlib.pyplot as plt img cv2.imread(pig.JPG,0) template cv2.imread(eye.JPG,0) # 获取模板图像的宽度和高度 th,tw template.shape[::] # 匹配获得结果 result cv2.matchTemplate(img,template,cv2.TM_CCOEFF) # 找到最大值就是结果最好的位置 _,maxVal,_,maxLoc cv2.minMaxLoc(result) # 左上角坐标 topLeft maxLoc # 右下角坐标 bottomRight topLeft[0]tw,topLeft[1]th # 画框 需要左上角右下角 灰度值范围 和框的宽度 cv2.rectangle(img,topLeft,bottomRight,255,2)plt.subplot(121) plt.imshow(template,cmap gray) plt.title(template_image) plt.axis(off)plt.subplot(122) plt.imshow(img,cmap gray) plt.title(result) plt.axis(off)多模版匹配 多模板匹配会有多个解所以需要按照下面这个步骤去解决问题 第一步cv2.matchTemplate选择method 第二步把筛选结果放入np.where(阈值)函数进行找所有满足阈值的解 第三步使用 for in zip的方式把解中的结果找出来 第四步找左上角坐标与 右下角坐标 第五步使用使用cv2.rectangle画白色标记 import cv2 import numpy as np import matplotlib.pyplot as plt img cv2.imread(moudle.JPG,0) template cv2.imread(eye.JPG,0) # 获取模板图像的宽度和高度 th,tw template.shape[::] # 匹配获得结果 result cv2.matchTemplate(img,template,cv2.TM_CCOEFF_NORMED)# 设置阈值 threshold 0.9 # 把筛选结果放入np.where(阈值)函数进行找所有满足阈值的解 loc np.where(resultthreshold)# 使用 for in zip的方式把解中的结果找出来 for pt in zip(*loc[::-1]):# 左上角坐标topLeft pt# 右下角坐标bottomRight topLeft[0]tw,topLeft[1]th# 画框 需要左上角右下角 灰度值范围 和框的宽度cv2.rectangle(img,topLeft,bottomRight,255,2)plt.subplot(121) plt.imshow(template,cmap gray) plt.title(template_image) plt.axis(off)plt.subplot(122) plt.imshow(img,cmap gray) plt.title(result) plt.axis(off)致谢 本文参考了一些博主的文章博取了他们的长处也结合了我的一些经验对他们表达诚挚的感谢使我对 OpenCV模板匹配 有更深入的了解也推荐大家去阅读一下他们的文章。纸上学来终觉浅明知此事要躬行 OpenCV第十章——模板匹配
http://www.yingshimen.cn/news/41760/

相关文章:

  • 企业手机端网站源码下载海外电商平台有哪些
  • 零六年自助建设网站建设造价信息网站
  • 长沙定制网站小学生小发明小制作大全
  • 百度商桥代码怎么加到网站上做网站主要学什么软件
  • 怎样做违法网站宜春网站制作公司
  • 加强网站建设的做招商网站
  • 南昌seo网站设计网页升级紧急通知 直接跳转中
  • 网站内容丰富收费的网站怎么做
  • 用文件传输协议登录网站中企动力销售怎么样
  • 肇庆专业网站建设服务近期新冠感染情况
  • 怎么在网站做支付端口对接网站带数据库下载
  • 网站开发 兼职项目用什么l软件做网站了
  • 简单做图网站官方网站平台有哪些
  • 做拍卖网站有哪些温州注册网络公司价格多少
  • wordpress模板用法青岛网站seo优化
  • 在韩国申请网站域名需要什么凡科网做网站好吗
  • 网站页面设计原则wordpress同步微博插件
  • 做国外有那些网站比较好的网络营销相关工作岗位
  • 做旅行攻略的网站好稼禾建设集团网站
  • 忘记网站后台用户名wordpress中国风
  • 制作网站的专业公司企业网站数防泄露怎么做
  • wordpress网站地图自动更新德阳公司网站建设
  • 电视台网站建设报告西部数码 成品网站
  • 免费网站建设工具网站后台 设计
  • 做网站什么语言最好企业策划书3000字
  • 国外做兼职网站设计seo关键词优化软件官网
  • 网站备案幕布照片尺寸沧州瑞智网站建设
  • 企业门户网站建设优势网站建设使用的基本技术
  • emlog做企业网站爱站网seo工具包
  • 东阳市网站建设国外网站后台模板下载