openCV+Python 数字图像处理(10)——模板匹配

1.基本概念

模板匹配: 在整个图像区域中发现与给定子图像匹配的小块区域
要素: ①模板图像T ②待检图像S

2.API 介绍

(1)模板匹配API

# 模板匹配 API
result = cv2.matchTemplate(image: Any, templ: Any, method: Any, result: Any = None, mask: Any = None)`

image: 待检图像S
templ: 模板图像T
method: 匹配方法
result: 二维矩阵,像素值代表匹配程度

cv2.TM_CCORR相关匹配数值越大效果越好
cv2.TM_CCORR_NORMED归一化相关匹配数值越大效果越好
cv2.TM_CCOEFF相关系数匹配数值越大效果越好
cv2.TM_CCOEFF_NORMED相关系数匹配数值越大效果越好
cv2.TM_SQDIFF平方差匹配数值越小效果越好
cv2.TM_SQDIFF_NORMED平方差匹配数值越小效果越好

(2)二维矩阵获取最大最小值及位置

# 在二维矩阵中获取最大最小值及最大最小值位置
min_val, max_val, min_loc, max_loc = cv2.minMaxLoc(src: Any, mask: Any = None)

min_val: 最小值
max_val: 最大值
min_loc: 最小值位置,如(2,5)
max_loc: 最大值位置,如(4,10)

(3)在图像上画出模板区域

# 在图像上画出矩形
cv2.rectangle(img: Any, pt1: Any, pt2: Any, color: Any, thickness: Any = None, lineType: Any = None, shift: Any = None)

img: 原图像
pt1: (x,y), 矩阵左上角的位置
pt2: (x+w, y+h), 矩阵右下角的位置
color: 例:(0,0,255)表示红色
thickness: 线条粗细

3.代码示例

import cv2
import numpy as np

source = cv2.imread('E:/PycharmProjects/source.jpg')
tpl = cv2.imread('E:/PycharmProjects/tpl.jpg')

def show(name, img):
    cv2.imshow(name, img)
    cv2.waitKey(0)

show('source', source)
show('template', tpl)

def template_demo():
    methods = [cv2.TM_CCOEFF_NORMED, cv2.TM_CCORR_NORMED, cv2.TM_SQDIFF_NORMED]
    th, tw = tpl.shape[:2]
    for md in methods:
        result = cv2.matchTemplate(source, tpl, md)
        print(type(result))
        min_val, max_val, min_loc, max_loc = cv2.minMaxLoc(result)
        if md == cv2.TM_SQDIFF_NORMED:
            tl = min_loc
        else:
            tl = max_loc
        br = tl[0]+tw, tl[1]+th
        cv2.rectangle(source, tl, br, (0, 0, 255), 3)
        show('result'+np.str(md), result)
        show('match'+np.str(md), source)

template_demo()

cv2.destroyAllWindows()

4.结果展示

原图:原图模板:
在这里插入图片描述

匹配后结果:
在这里插入图片描述
作出矩形框:
在这里插入图片描述

  • 0
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值