国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當(dāng)前位置: 首頁 - 科技 - 知識(shí)百科 - 正文

opencv2對(duì)讀書筆記反投影直方圖以檢測(cè)待定的圖像內(nèi)容

來源:懂視網(wǎng) 責(zé)編:小采 時(shí)間:2020-11-09 08:32:21
文檔

opencv2對(duì)讀書筆記反投影直方圖以檢測(cè)待定的圖像內(nèi)容

opencv2對(duì)讀書筆記反投影直方圖以檢測(cè)待定的圖像內(nèi)容:一些小概念 1.直方圖是圖像內(nèi)容的一個(gè)重要特性。 2.如果一幅圖像的區(qū)域中顯示的是一種獨(dú)特的紋理或是一個(gè)獨(dú)特的物體,那么這個(gè)區(qū)域的直方圖可以看作是一個(gè)概率函數(shù),它給出的是某個(gè)像素屬于該紋理或物體的概率。 3.反投影直方圖的作用是在于替換一個(gè)輸入圖像
推薦度:
導(dǎo)讀opencv2對(duì)讀書筆記反投影直方圖以檢測(cè)待定的圖像內(nèi)容:一些小概念 1.直方圖是圖像內(nèi)容的一個(gè)重要特性。 2.如果一幅圖像的區(qū)域中顯示的是一種獨(dú)特的紋理或是一個(gè)獨(dú)特的物體,那么這個(gè)區(qū)域的直方圖可以看作是一個(gè)概率函數(shù),它給出的是某個(gè)像素屬于該紋理或物體的概率。 3.反投影直方圖的作用是在于替換一個(gè)輸入圖像

一些小概念 1.直方圖是圖像內(nèi)容的一個(gè)重要特性。 2.如果一幅圖像的區(qū)域中顯示的是一種獨(dú)特的紋理或是一個(gè)獨(dú)特的物體,那么這個(gè)區(qū)域的直方圖可以看作是一個(gè)概率函數(shù),它給出的是某個(gè)像素屬于該紋理或物體的概率。 3.反投影直方圖的作用是在于替換一個(gè)輸入圖像

一些小概念


1.直方圖是圖像內(nèi)容的一個(gè)重要特性。

2.如果一幅圖像的區(qū)域中顯示的是一種獨(dú)特的紋理或是一個(gè)獨(dú)特的物體,那么這個(gè)區(qū)域的直方圖可以看作是一個(gè)概率函數(shù),它給出的是某個(gè)像素屬于該紋理或物體的概率。

3.反投影直方圖的作用是在于替換一個(gè)輸入圖像中每一個(gè)像素值,使其變成歸一化直方圖中對(duì)應(yīng)的概率值。


這是一個(gè)什么樣的過程


名字聽起來感覺很高端,其實(shí)這個(gè)一個(gè)很簡(jiǎn)單的過程。

1.首先我們截取一個(gè)區(qū)域,作為目標(biāo)區(qū)域。

2.然后將目標(biāo)區(qū)域取直方圖,并將其直方圖歸一化,并得到這個(gè)區(qū)域的概率。

3.利用calcBackProject函數(shù)在圖像中檢索。其中函數(shù)會(huì)利用區(qū)域概率,對(duì)圖像中的像素點(diǎn)經(jīng)行映射,映射到[0,1]區(qū)間,所以要擴(kuò)大255倍顯示。

4.這樣一來因?yàn)槭秦?fù)圖像,所以越暗的地方相似概率越大。


calcBackProject函數(shù)


其結(jié)構(gòu)


cv::calcBackProject(&image,//目標(biāo)圖像
	1, // 圖像個(gè)數(shù)
	channels, // 通道數(shù)量
	histogram, // 進(jìn)行反投影的直方圖
	result, // 結(jié)果圖像
	ranges, // 每個(gè)維度的閾值
	255.0 // 放縮因子
	);


該過程的實(shí)例


我們舉個(gè)例子來說明上面說到的過程,我兩個(gè)小嬰兒的圖像中我們截取嬰兒頭部皮膚,來檢測(cè)嬰兒全身皮膚在圖像中的位置。


代碼


#include "cv.h"
#include "highgui.h"
#include "histogram.h"
#include 
using namespace std;

#include 
#include 

class ObjectFinder {

private:

	float hranges[2];
	const float* ranges[3];
	int channels[3];

	float threshold;
	cv::MatND histogram;
	cv::SparseMat shistogram;

public:

	ObjectFinder() : threshold(0.1f){

	ranges[0]= hranges; 
	ranges[1]= hranges; 
	ranges[2]= hranges; 
	}

	// 設(shè)置閾值
	void setThreshold(float t) {

	threshold= t;
	}

	// 返回閾值
	float getThreshold() {

	return threshold;
	}

	// 設(shè)置目標(biāo)直方圖,進(jìn)行歸一化
	void setHistogram(const cv::MatND& h) {
	histogram= h;
	cv::normalize(histogram,histogram,1.0);
	}

	// 查找屬于目標(biāo)直方圖概率的像素
	cv::Mat find(const cv::Mat& image) {

	cv::Mat result;

	hranges[0]= 0.0;	
	hranges[1]= 255.0;
	channels[0]= 0;	
	channels[1]= 1; 
	channels[2]= 2; 

	cv::calcBackProject(&image,
	1, 
	channels, 
	histogram, 
	result, 
	ranges, 
	255.0 
	);

	// 通過閾值投影獲得二值圖像
	if (threshold>0.0)
	cv::threshold(result, result, 255*threshold, 255, cv::THRESH_BINARY);

	return result;
	}

};

int main()
{
	//讀取圓圖像
	cv::Mat initimage= cv::imread("../2.jpg");
	if (!initimage.data)
	return 0; 

	//顯示原圖像
	cv::namedWindow("原圖像");
	cv::imshow("原圖像",initimage);

	//讀取灰度圖像
	cv::Mat image= cv::imread("../2.jpg",0);
	if (!image.data)
	return 0; 

	//設(shè)置目標(biāo)區(qū)域
	cv::Mat imageROI;
	imageROI= image(cv::Rect(262,151,113,150)); // 區(qū)域?yàn)樾『⒌哪槻繀^(qū)域

	//顯示目標(biāo)區(qū)域
	cv::namedWindow("目標(biāo)區(qū)域圖像");
	cv::imshow("目標(biāo)區(qū)域圖像",imageROI);

	//計(jì)算目標(biāo)區(qū)域直方圖
	Histogram1D h;
	cv::MatND hist= h.getHistogram(imageROI);
	cv::namedWindow("目標(biāo)區(qū)域直方圖");
	cv::imshow("目標(biāo)區(qū)域直方圖",h.getHistogramImage(imageROI));

	//創(chuàng)建檢查類
	ObjectFinder finder;
	//將目標(biāo)區(qū)域直方圖傳入檢測(cè)類
	finder.setHistogram(hist);

	//初始化閾值
	finder.setThreshold(-1.0f);

	//進(jìn)行反投影
	cv::Mat result1;
	result1= finder.find(image);

	//創(chuàng)建負(fù)圖像并顯示概率結(jié)果
	cv::Mat tmp;
	result1.convertTo(tmp,CV_8U,-1.0,255.0);
	cv::namedWindow("負(fù)圖像概率結(jié)果圖像越暗概率越大");
	cv::imshow("負(fù)圖像概率結(jié)果圖像越暗概率越大",tmp);

	//得到二值反投影圖像
	finder.setThreshold(0.01f);
	result1= finder.find(image);

	//在圖像中繪制選中區(qū)域
	cv::rectangle(image,cv::Rect(262,151,113,150),cv::Scalar(0,0,0));

	//顯示原圖像
	cv::namedWindow("原圖像的灰度圖");
	cv::imshow("原圖像的灰度圖",image);

	//二值結(jié)果圖
	cv::namedWindow("二值結(jié)果圖");
	cv::imshow("二值結(jié)果圖",result1);

	cv::waitKey();
	return 0;
}

輸出結(jié)果














-END-

聲明:本網(wǎng)頁內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

opencv2對(duì)讀書筆記反投影直方圖以檢測(cè)待定的圖像內(nèi)容

opencv2對(duì)讀書筆記反投影直方圖以檢測(cè)待定的圖像內(nèi)容:一些小概念 1.直方圖是圖像內(nèi)容的一個(gè)重要特性。 2.如果一幅圖像的區(qū)域中顯示的是一種獨(dú)特的紋理或是一個(gè)獨(dú)特的物體,那么這個(gè)區(qū)域的直方圖可以看作是一個(gè)概率函數(shù),它給出的是某個(gè)像素屬于該紋理或物體的概率。 3.反投影直方圖的作用是在于替換一個(gè)輸入圖像
推薦度:
標(biāo)簽: 直方圖 讀書 定的
  • 熱門焦點(diǎn)

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 欧美色图另类 | 国产福利一区二区三区 | 国产免费三a在线 | 精品欧美一区二区三区在线观看 | 纯毛片| 日本久久精品免视看国产成人 | 我被公睡做舒服爽中文字幕 | 国产成人免费视频精品一区二区 | 午夜操一操 | 欧美一区二区精品 | 亚洲精品二三区伊人久久 | a国产 | 天堂一区二区三区精品 | 亚洲一区二区成人 | 青青草国产免费国产是公开 | 一区二区在线播放视频 | 91aaa在线观看 | 国产一区免费在线观看 | 欧美日本在线 | 国产精品手机视频一区二区 | 欧美日韩精品一区二区三区视频在线 | 欧美精品久久天天躁 | 91精品国产品国语在线不卡 | 中文字幕欧美在线观看 | 国产 欧美 在线 | 免费在线观看一区 | 高清国产美女一级a毛片 | 国产精品视频久久久久 | 影音先锋中文字幕资源 | 天天操夜夜逼 | 欧美日批| 精品一区二区三 | wwwxxx欧美| www国产精品 | 日韩一区二区免费视频 | 中文字幕日韩一区二区三区不卡 | 国产成人精品第一区二区 | 欧美视频日韩专区午夜 | 夜夜操夜夜 | 日韩精品1区 | 日韩www视频 |