OpenCV 4.12.0
开源计算机视觉
加载中...
搜索中...
无匹配项
对象检测

详细描述

枚举

枚举  cv::TemplateMatchModes {
  cv::TM_SQDIFF = 0 ,
  cv::TM_SQDIFF_NORMED = 1 ,
  cv::TM_CCORR = 2 ,
  cv::TM_CCORR_NORMED = 3 ,
  cv::TM_CCOEFF = 4 ,
  cv::TM_CCOEFF_NORMED = 5
}
 模板匹配操作的类型 更多...
 

函数

void cv::matchTemplate (InputArray image, InputArray templ, OutputArray result, int method, InputArray mask=noArray())
 将模板与重叠图像区域进行比较。
 

枚举类型文档

◆ TemplateMatchModes

#include <opencv2/imgproc.hpp>

模板匹配操作的类型

枚举器
TM_SQDIFF 
Python: cv.TM_SQDIFF

\[R(x,y)= \sum _{x',y'} (T(x',y')-I(x+x',y+y'))^2\]

带掩码

\[R(x,y)= \sum _{x',y'} \left( (T(x',y')-I(x+x',y+y')) \cdot M(x',y') \right)^2\]

TM_SQDIFF_NORMED 
Python: cv.TM_SQDIFF_NORMED

\[R(x,y)= \frac{\sum_{x',y'} (T(x',y')-I(x+x',y+y'))^2}{\sqrt{\sum_{ x',y'}T(x',y')^2 \cdot \sum_{x',y'} I(x+x',y+y')^2}}\]

带掩码

\[R(x,y)= \frac{\sum _{x',y'} \left( (T(x',y')-I(x+x',y+y')) \cdot M(x',y') \right)^2}{\sqrt{\sum_{x',y'} \left( T(x',y') \cdot M(x',y') \right)^2 \cdot \sum_{x',y'} \left( I(x+x',y+y') \cdot M(x',y') \right)^2}}\]

TM_CCORR 
Python: cv.TM_CCORR

\[R(x,y)= \sum _{x',y'} (T(x',y') \cdot I(x+x',y+y'))\]

带掩码

\[R(x,y)= \sum _{x',y'} (T(x',y') \cdot I(x+x',y+y') \cdot M(x',y') ^2)\]

TM_CCORR_NORMED 
Python: cv.TM_CCORR_NORMED

\[R(x,y)= \frac{\sum_{x',y'} (T(x',y') \cdot I(x+x',y+y'))}{\sqrt{ \sum_{x',y'}T(x',y')^2 \cdot \sum_{x',y'} I(x+x',y+y')^2}}\]

带掩码

\[R(x,y)= \frac{\sum_{x',y'} (T(x',y') \cdot I(x+x',y+y') \cdot M(x',y')^2)}{\sqrt{\sum_{x',y'} \left( T(x',y') \cdot M(x',y') \right)^2 \cdot \sum_{x',y'} \left( I(x+x',y+y') \cdot M(x',y') \right)^2}}\]

TM_CCOEFF 
Python: cv.TM_CCOEFF

\[R(x,y)= \sum _{x',y'} (T'(x',y') \cdot I'(x+x',y+y'))\]

其中

\[\begin{array}{l} T'(x',y')=T(x',y') - 1/(w \cdot h) \cdot \sum _{ x'',y''} T(x'',y'') \\ I'(x+x',y+y')=I(x+x',y+y') - 1/(w \cdot h) \cdot \sum _{x'',y''} I(x+x'',y+y'') \end{array}\]

带掩码

\[\begin{array}{l} T'(x',y')=M(x',y') \cdot \left( T(x',y') - \frac{1}{\sum _{x'',y''} M(x'',y'')} \cdot \sum _{x'',y''} (T(x'',y'') \cdot M(x'',y'')) \right) \\ I'(x+x',y+y')=M(x',y') \cdot \left( I(x+x',y+y') - \frac{1}{\sum _{x'',y''} M(x'',y'')} \cdot \sum _{x'',y''} (I(x+x'',y+y'') \cdot M(x'',y'')) \right) \end{array} \]

TM_CCOEFF_NORMED 
Python: cv.TM_CCOEFF_NORMED

\[R(x,y)= \frac{ \sum_{x',y'} (T'(x',y') \cdot I'(x+x',y+y')) }{ \sqrt{\sum_{x',y'}T'(x',y')^2 \cdot \sum_{x',y'} I'(x+x',y+y')^2} }\]

函数文档

◆ matchTemplate()

void cv::matchTemplate ( InputArray image,
InputArray templ,
OutputArray result,
int 方法,
InputArray mask = noArray() )
Python
cv.matchTemplate(image, templ, method[, result[, mask]]) -> result

#include <opencv2/imgproc.hpp>

将模板与重叠图像区域进行比较。

该函数在 image 上滑动,使用指定的方法比较大小为 \(w \times h\) 的重叠块与 templ,并将比较结果存储在 result 中。 TemplateMatchModes 描述了可用比较方法的公式(\(I\) 表示图像,\(T\) 表示模板,\(R\) 表示结果,\(M\) 表示可选掩码)。 求和是在模板和/或图像块上完成的:\(x' = 0...w-1, y' = 0...h-1\)

函数完成比较后,可以使用 minMaxLoc 函数找到最佳匹配作为全局最小值(当使用 TM_SQDIFF 时)或最大值(当使用 TM_CCORRTM_CCOEFF 时)。 对于彩色图像,分子中的模板求和以及分母中的每个求和都在所有通道上完成,并且每个通道使用单独的平均值。 也就是说,该函数可以采用彩色模板和彩色图像。 结果仍然是单通道图像,这更容易分析。

参数
image运行搜索的图像。 它必须是 8 位或 32 位浮点数。
templ搜索的模板。 它必须不大于源图像,并且具有相同的数据类型。
result比较结果的映射。 它必须是单通道 32 位浮点数。 如果 image 是 \(W \times H\) 并且 templ 是 \(w \times h\) ,则 result 是 \((W-w+1) \times (H-h+1)\) 。
方法指定比较方法的参数,请参阅 TemplateMatchModes
mask可选掩码。 它必须与 templ 的大小相同。 它必须具有与模板相同的通道数,或者只有一个通道,然后该通道用于所有模板和图像通道。 如果数据类型为 CV_8U,则掩码被解释为二进制掩码,这意味着仅使用掩码为非零的元素,并且独立于实际掩码值(权重等于 1)保持不变。 对于数据类型 CV_32F,掩码值用作权重。 确切的公式记录在 TemplateMatchModes 中。