欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

opencv?C++模板匹配的簡單實(shí)現(xiàn)

 更新時(shí)間:2022年02月18日 15:42:35   作者:R-G-B  
這篇文章主要介紹了opencv?C++模板匹配的簡單實(shí)現(xiàn),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

一 簡單實(shí)現(xiàn)

#include <opencv2/opencv.hpp>
#include<iostream>
using namespace cv;
using namespace std;

int main()
{
	Mat img = imread("52.jpg");
	Mat templ = imread("templ.jpg");
	Mat result;
	matchTemplate(img,templ,result,TM_CCOEFF_NORMED);//原圖,模板,匹配方法
	
	double maxVal, minVal;
	Point maxLoc, minLoc;
	//尋找最大值,最小值
	minMaxLoc(result, &minVal, &maxVal, &minLoc, &maxLoc);
	//繪制矩形,矩形的左上角是最大值的位置,右下角是在最大值上加上模板的行寬和和列高
	rectangle(img,Point(maxLoc.x,maxLoc.y),Point(maxLoc.x+templ.cols,maxLoc.y+templ.rows),Scalar(0,0,255),2);//顏色紅色,粗度2
	imshow("原圖", img);
	imshow("模板",templ);
	imshow("result",result);
	waitKey(0);
	return 0;
}

結(jié)果如下,分別是模板圖,原圖(找到了與模板匹配的部分,并矩形框標(biāo)記,結(jié)果圖,暫時(shí)覺得有點(diǎn)問題的 )

二 函數(shù)及原理講解

1 matchTemplate()參數(shù)詳解

matchTemplate( InputArray image, InputArray templ,OutputArray result, int method );

image:待匹配的源圖像
templ:模板圖像
result:保存結(jié)果的矩陣,我們可以通過minMaxLoc() 確定結(jié)果矩陣的最大值和最小值的位置.

method :模板匹配的算法
有以下六種:
  enum { TM_SQDIFF=0, TM_SQDIFF_NORMED=1, TM_CCORR=2, TM_CCORR_NORMED=3, TM_CCOEFF=4, TM_CCOEFF_NORMED=5 };

TM_SQDIFF,TM_SQDIFF_NORMED匹配數(shù)值越低表示匹配效果越好,其它四種反之。
TM_SQDIFF_NORMED,TM_CCORR_NORMED,TM_CCOEFF_NORMED是標(biāo)準(zhǔn)化的匹配,得到的最大值,最小值范圍在0~1之間,其它則需要自己對結(jié)果矩陣歸一化。
不同的方法會得到差異很大的結(jié)果,可以通過測試選擇最合適的方法。

cv::TM_SQDIFF 判斷 minVal 越小,效果越好
計(jì)算模板與目標(biāo)圖像的方差,由于是像素值差值的平方的和,所以值越小匹配程度越高;

cv::TM_SQDIFF_NORMED 判斷 minVal 越接近0,效果越好
范化的cv::TM_SQDIFF,取值為0-1之間,完美匹配返回值為0;

cv::TM_CCORR 判斷 maxVal 越大,效果越好
使用dot product計(jì)算匹配度,越高匹配度就好;

cv::TM_CCORR_NORMED 判斷 maxVal 越接近1,效果越好
范化的cv::TM_CCORR,0-1之間,我用的這個;

cv::TM_CCOEFF 判斷 maxVal 越大,效果越好
采用模板與目標(biāo)圖像像素與各自圖像的平均值計(jì)算dot product,正值越大匹配度越高,負(fù)值越大圖像的區(qū)別越大,但如果圖像沒有明顯的特征(即圖像中的像素值與平均值接近)則返回值越接近0;

cv::TM_CCOEFF_NORMED 判斷 maxVal 越接近1,效果越好
范化的cv::TM_CCOEFF,-1 ~ 1之間。

2 minMaxLoc()函數(shù)

查找全局最小和最大稀疏數(shù)組元素并返回其值及其位置

void minMaxLoc(const SparseMat& a, double* minVal,double* maxVal, int* minIdx=0, int* maxIdx=0);

a: 匹配結(jié)果矩陣
&minVal 和 &maxVal: 在矩陣 result 中存儲的最小值和最大值
&minLoc 和 &maxLoc: 在結(jié)果矩陣中最小值和最大值的坐標(biāo).

到此這篇關(guān)于opencv C++模板匹配的文章就介紹到這了,更多相關(guān)opencv 模板匹配內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C++九種排序具體實(shí)現(xiàn)代碼

    C++九種排序具體實(shí)現(xiàn)代碼

    這篇文章主要介紹了C++九種排序具體實(shí)現(xiàn)代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-04-04
  • C語言入門篇--初識結(jié)構(gòu)體

    C語言入門篇--初識結(jié)構(gòu)體

    本篇文章是基礎(chǔ)篇,適合c語言剛?cè)腴T的朋友,本文對c語言的結(jié)構(gòu)體做了簡單的分析,幫助大家快速入門c語言的世界,更好的理解c語言
    2021-08-08
  • C語言經(jīng)典算法例題求100-999之間的“水仙花數(shù)”

    C語言經(jīng)典算法例題求100-999之間的“水仙花數(shù)”

    本文的主要內(nèi)容,設(shè)計(jì)一個程序,找出100-999之間的“水仙花數(shù)”,需要的朋友可以參考下
    2015-07-07
  • VC小技巧匯總之5則實(shí)用小技巧

    VC小技巧匯總之5則實(shí)用小技巧

    這篇文章主要介紹了VC小技巧匯總之5則實(shí)用小技巧,需要的朋友可以參考下
    2014-07-07
  • C語言的模板與泛型編程你了解嗎

    C語言的模板與泛型編程你了解嗎

    這篇文章主要為大家詳細(xì)介紹了C語言的模板與泛型編程,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-03-03
  • c++中string類型和int類型相互轉(zhuǎn)換的幾種常用方法

    c++中string類型和int類型相互轉(zhuǎn)換的幾種常用方法

    我們在編寫程序時(shí),經(jīng)常涉及到int與string之間的類型轉(zhuǎn)換,本文主要介紹了c++中string類型和int類型相互轉(zhuǎn)換的幾種常用方法,具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-08-08
  • C++使用遞歸函數(shù)和棧操作逆序一個棧的算法示例

    C++使用遞歸函數(shù)和棧操作逆序一個棧的算法示例

    這篇文章主要介紹了C++使用遞歸函數(shù)和棧操作逆序一個棧的算法,結(jié)合實(shí)例形式分析了C++遞歸函數(shù)與逆序棧的相關(guān)操作技巧,需要的朋友可以參考下
    2017-05-05
  • C/C++?Qt?運(yùn)用JSON解析庫的實(shí)例代碼

    C/C++?Qt?運(yùn)用JSON解析庫的實(shí)例代碼

    這篇文章主要介紹了C/C++?Qt?運(yùn)用JSON解析庫的相關(guān)知識,通過代碼依次解析這個json文件中的每一個參數(shù),代碼簡單易懂,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-01-01
  • C++中的運(yùn)算符和表達(dá)式

    C++中的運(yùn)算符和表達(dá)式

    這篇文章主要介紹了C++中的運(yùn)算符和表達(dá)式,學(xué)習(xí)使用表達(dá)式,對數(shù)據(jù)類型進(jìn)行處理.詳細(xì)介紹內(nèi)容需要的小伙伴可以參考下面文章相關(guān)內(nèi)容
    2022-03-03
  • C++實(shí)現(xiàn)LeetCode(94.二叉樹的中序遍歷)

    C++實(shí)現(xiàn)LeetCode(94.二叉樹的中序遍歷)

    這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(94.二叉樹的中序遍歷),本篇文章通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-07-07

最新評論