openCV matchTemplate函数不同参数对应的相似性度量

Compares a template against overlapped image regions.

C++:  void  matchTemplate (InputArray  image,InputArray  templ,OutputArray  result,int  method )
Python:   cv2. matchTemplate (image,templ,method [,result ] ) → result
C:  void  cvMatchTemplate (const CvArr*  image,const CvArr*  templ,CvArr*  result,int  method )
Python:   cv. MatchTemplate (image,result,method ) → None
Parameters:
  • image – Image where the search is running. It must be 8-bit or 32-bit floating-point.
  • templ – Searched template. It must be not greater than the source image and have the same data type.
  • result – Map of comparison results. It must be single-channel 32-bit floating-point. If imageis 

    W \times H

     and templ is 

    w \times h

     ,then result is 

    (W-w+1) \times (H-h+1)

     .
  • method – Parameter specifying the comparison method (see below).

The function slides through image ,compares the overlapped patches of size 

w \times h

 against templ using the specified method and stores the comparison results in result . Here are the formulae for the available comparison methods ( 

I

denotes image

T

 template

R

 result ). The summation is done over template and/or the image patch: 

x' = 0...w-1,y' = 0...h-1

 * method=CV_TM_SQDIFF

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

  • method=CV_TM_SQDIFF_norMED

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

  • method=CV_TM_CCORR

    R(x,y')  \cdot I(x+x',y+y'))

  • method=CV_TM_CCORR_norMED

    R(x,y') \cdot I(x+x',y+y'))}{\sqrt{\sum_{x',y+y')^2}}

  • method=CV_TM_CCOEFF

    R(x,y'} (T'(x',y')  \cdot I'(x+x',y+y'))

    where

    \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}

  • method=CV_TM_CCOEFF_norMED

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

After the function finishes the comparison,the best matches can be found as global minimums (when CV_TM_SQDIFF was used) or maximums (when CV_TM_CCORR or CV_TM_CCOEFF was used) using the minMaxLoc() function. In case of a color image,template summation in the numerator and each sum in the denominator is done over all of the channels and separate mean values are used for each channel. That is,the function can take a color template and a color image. The result will still be a single-channel image,which is easier to analyze.

相关文章

自1998年我国取消了福利分房的政策后,房地产市场迅速开展蓬...
文章目录获取数据查看数据结构获取数据下载数据可以直接通过...
网上商城系统MySql数据库设计
26个来源的气象数据获取代码
在进入21世纪以来,中国电信业告别了20世纪最后阶段的高速发...