opencv模板匹配

NORMED的意思就是结果范围在[-1, 1]之间

cv2.TM_SQDIFF, cv2.TM_SQDIFF_NORMED: `0 为最优,越大越差`,值越小越好

cv2.TM_CCORR, cv2.TM_CCORR_NORMED, cv2.TM_CCOEFF, cv2.TM_CCOEFF_NORMED: `越大越好`

复制代码
如果你使用的是 TM_SQDIFF 方法,那么确实需要使用灰度图像。这是因为 TM_SQDIFF 方法计算的是图像差异的平方和,而不是相关性。在这种情况下,你需要确保模板图像和待匹配图像都是灰度图像,以便正确计算差异。
如果你使用的是其他匹配方法(例如 TM_CCORR 或 TM_CCOEFF),则可以使用彩色图像。这些方法计算的是相关性或相关系数,而不涉及差异的平方和。

cv2.imread 是 OpenCV 中用于从指定文件加载图像的函数。第二个参数 flag 决定了图像的读取方式。在你提供的代码中,参数 0 表示将图像以灰度模式读取。

具体来说,这里的 0 对应以下标志:

  • cv2.IMREAD_GRAYSCALE:它指定以灰度模式加载图像。这意味着图像将被转换为单通道的灰度图像,每个像素的值在 0 到 255 之间,表示图像的亮度。这对于处理灰度图像或进行模板匹配等任务非常有用。

如果你想加载彩色图像,可以使用以下标志之一:

  • cv2.IMREAD_COLOR:加载彩色图像 ,忽略图像的透明度。这是默认标志,也可以用整数值 1 表示。

  • cv2.IMREAD_UNCHANGED:加载图像,包括透明通道 (如果有的话)。这对于处理带有 alpha 通道的图像很有用,也可以用整数值 -1 表示。

    method: TM_SQDIFF, 用minVal

    import cv2
    import numpy as np
    import matplotlib.pyplot as plt

    cat = cv2.imread('./aaaa.jpg', 0)
    template = cv2.imread('./template.png', 0)

    th, tw = template.shape[::]

    rv = cv2.matchTemplate(cat, template, cv2.TM_SQDIFF)

    minVal, maxVal, minLoc, maxLoc = cv2.minMaxLoc(rv)

    topLeft = minLoc
    bottomRight = (topLeft[0] + tw, topLeft[1] + th)
    cv2.rectangle(cat, topLeft, bottomRight, 255, 2)

    plt.subplot(121), plt.imshow(rv, cmap='gray')
    plt.title('Matching Result'), plt.xticks([]), plt.yticks([])
    plt.subplot(122), plt.imshow(cat, cmap='gray')
    plt.title('Detected Point'), plt.xticks([]), plt.yticks([])
    plt.show()

    TM_CCOEFF 方法, 越大越好,用maxVal
    import cv2
    import numpy as np
    import matplotlib.pyplot as plt

    cat = cv2.imread('./cats.jpg', 0)
    template = cv2.imread('./tongue.png', 0)
    tw, th = template.shape[::-1]
    rv = cv2.matchTemplate(cat, template, cv2.TM_CCOEFF)

    minVal, maxVal, minLoc, maxLoc = cv2.minMaxLoc(rv)
    topLeft = maxLoc

    bottomRight = (topLeft[0] + tw, topLeft[1] + th)
    cv2.rectangle(cat, topLeft, bottomRight, 255, 2)

    plt.subplot(121), plt.imshow(rv, cmap='gray')
    plt.title('Matching Result'), plt.xticks([]), plt.yticks([])
    plt.subplot(122), plt.imshow(cat, cmap='gray')
    plt.title('Detected Point'), plt.xticks([]), plt.yticks([])
    plt.show()

相关推荐
zy_destiny1 小时前
【工业场景】用YOLOv8实现反光衣识别
人工智能·python·yolo·机器学习·计算机视觉
abcd_zjq3 小时前
【2025最新】【win10】vs2026+qt6.9+opencv(cmake编译opencv_contrib拓展模
人工智能·qt·opencv·计算机视觉·visual studio
abcd_zjq3 小时前
VS2026+QT6.9+opencv图像增强(多帧平均降噪)(CLAHE对比度增强)(边缘增强)(图像超分辨率)
c++·图像处理·qt·opencv·visual studio
Blossom.1183 小时前
用一颗MCU跑通7B大模型:RISC-V+SRAM极致量化实战
人工智能·python·单片机·嵌入式硬件·opencv·机器学习·risc-v
mit6.8243 小时前
[GazeTracking] 摄像头交互与显示 | OpenCV
人工智能·opencv·交互
myloe004 小时前
Linux运维实战如何快速排查服务器CPU占用过高问题
计算机视觉
星期天要睡觉11 小时前
计算机视觉(opencv)——基于 OpenCV DNN 的实时人脸检测 + 年龄与性别识别
opencv·计算机视觉·dnn
算法打盹中15 小时前
计算机视觉:基于 YOLO 的轻量级目标检测与自定义目标跟踪原理与代码框架实现
图像处理·yolo·目标检测·计算机视觉·目标跟踪
sali-tec16 小时前
C# 基于halcon的视觉工作流-章42-手动识别文本
开发语言·人工智能·算法·计算机视觉·c#·ocr
AndrewHZ21 小时前
【图像处理基石】暗光增强算法入门:从原理到实战(Python+OpenCV)
图像处理·python·opencv·算法·计算机视觉·cv·暗光增强