发布于2019-10-28 16:16 阅读(987) 评论(0) 点赞(0) 收藏(1)
模板匹配原理:(模式识别中最简单的一个识别方法,就是图像处理中最简单的)
模板匹配就是在整个图像区域发现与给定子图像匹配的小块区域;
模板匹配需要一个模板图图像T(给定的子图像);
需要一个待检测的图像——源图像S;
工作方法:在待检测图像上,从左到右,从上到下计算模板图像与重叠子图像的匹配度,匹配程度越大,两者相同的可能性越大。
from matplotlib import pyplot as plt
from cv2 import cv2 as cv
import numpy as np
def template_demo():
tpl = cv.imread("C:\\pictures\\xiaotaohua.jpg")
target = cv.imread("C:\\pictures\\dataohua.jpg")
cv.imshow("template image",tpl)
cv.imshow("target image",target)
methods = [cv.TM_SQDIFF_NORMED,cv.TM_CCOEFF_NORMED,cv.TM_CCORR_NORMED] #各种匹配算法
th,tw = tpl.shape[:2] #获取模板图像的高宽
for md in methods:
print(md)
result = cv.matchTemplate(target,tpl,md)
# result是我们各种算法下匹配后的图像
# cv.imshow("%s"%md,result)
#获取的是每种公式中计算出来的值,每个像素点都对应一个值
min_val,max_val,min_loc,max_loc = cv.minMaxLoc(result)
if md == cv.TM_SQDIFF_NORMED:
tl = min_loc #tl是左上角点
else:
tl = max_loc
br = (tl[0]+tw,tl[1]+th) #右下点
cv.rectangle(target,tl,br,(0,0,255),2) #画矩形 到原图上去
# cv.imshow("match-%s"%md,target)
cv.imshow('math-'+np.str(md),target)
# cv.imshow("match-%s"%md,result)
if __name__ == "__main__":
template_demo()
cv.waitKey(0)
cv.destroyAllWindows()
显示的结果
作者:23dh
链接:https://www.pythonheidong.com/blog/article/147190/86371e74788f229308db/
来源:python黑洞网
任何形式的转载都请注明出处,如有侵权 一经发现 必将追究其法律责任
昵称:
评论内容:(最多支持255个字符)
---无人问津也好,技不如人也罢,你都要试着安静下来,去做自己该做的事,而不是让内心的烦躁、焦虑,坏掉你本来就不多的热情和定力
Copyright © 2018-2021 python黑洞网 All Rights Reserved 版权所有,并保留所有权利。 京ICP备18063182号-1
投诉与举报,广告合作请联系vgs_info@163.com或QQ3083709327
免责声明:网站文章均由用户上传,仅供读者学习交流使用,禁止用做商业用途。若文章涉及色情,反动,侵权等违法信息,请向我们举报,一经核实我们会立即删除!