• <fieldset id="8imwq"><menu id="8imwq"></menu></fieldset>
  • <bdo id="8imwq"><input id="8imwq"></input></bdo>
    最新文章專題視頻專題問答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)前位置: 首頁 - 科技 - 知識百科 - 正文

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

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

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

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

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

    一些小概念


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

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

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


    這是一個什么樣的過程


    名字聽起來感覺很高端,其實這個一個很簡單的過程。

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

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

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

    4.這樣一來因為是負圖像,所以越暗的地方相似概率越大。


    calcBackProject函數(shù)


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


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


    該過程的實例


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


    代碼


    #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è)置目標直方圖,進行歸一化
    	void setHistogram(const cv::MatND& h) {
    	histogram= h;
    	cv::normalize(histogram,histogram,1.0);
    	}
    
    	// 查找屬于目標直方圖概率的像素
    	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è)置目標區(qū)域
    	cv::Mat imageROI;
    	imageROI= image(cv::Rect(262,151,113,150)); // 區(qū)域為小孩的臉部區(qū)域
    
    	//顯示目標區(qū)域
    	cv::namedWindow("目標區(qū)域圖像");
    	cv::imshow("目標區(qū)域圖像",imageROI);
    
    	//計算目標區(qū)域直方圖
    	Histogram1D h;
    	cv::MatND hist= h.getHistogram(imageROI);
    	cv::namedWindow("目標區(qū)域直方圖");
    	cv::imshow("目標區(qū)域直方圖",h.getHistogramImage(imageROI));
    
    	//創(chuàng)建檢查類
    	ObjectFinder finder;
    	//將目標區(qū)域直方圖傳入檢測類
    	finder.setHistogram(hist);
    
    	//初始化閾值
    	finder.setThreshold(-1.0f);
    
    	//進行反投影
    	cv::Mat result1;
    	result1= finder.find(image);
    
    	//創(chuàng)建負圖像并顯示概率結(jié)果
    	cv::Mat tmp;
    	result1.convertTo(tmp,CV_8U,-1.0,255.0);
    	cv::namedWindow("負圖像概率結(jié)果圖像越暗概率越大");
    	cv::imshow("負圖像概率結(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)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文檔

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

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

    最新推薦

    猜你喜歡

    熱門推薦

    專題
    Top
    主站蜘蛛池模板: www.精品| 欧美精品一区二区蜜臀亚洲| 一本一本久久a久久综合精品蜜桃 一本一道精品欧美中文字幕 | 国产精品久久久久久影院| 亚洲精品国产自在久久| 国产香蕉国产精品偷在线| 亚洲精品免费在线观看| 国产精品1区2区| 丰满人妻熟妇乱又仑精品| 亚洲精品美女久久777777| 无码精品人妻一区二区三区影院 | 精品无码久久久久国产| 一夲道无码人妻精品一区二区| 四虎永久在线精品免费一区二区| 国产精品白丝AV嫩草影院| 欧美精品国产日韩综合在线| 国产a精品视频| 91精品国产高清91久久久久久| 久久精品天天中文字幕人妻| 亚洲av永久无码精品网站| 亚洲一区无码精品色| 亚洲国产精品成人网址天堂| 日韩蜜芽精品视频在线观看| 久久久久人妻精品一区三寸蜜桃 | jizz国产精品| 成人精品一区二区三区在线观看 | 国产精品美女久久久久AV福利| 杨幂国产精品福利在线观看| 精品九九人人做人人爱| 国产精品久久免费| 欧美精品免费线视频观看视频| 日韩三级精品| 91精品国产品国语在线不卡 | 99精品视频3| 91在线视频精品| 久久国产成人精品麻豆 | 中文字幕一区二区精品区| 亚洲国语精品自产拍在线观看| 91精品国产91久久久久久| 国产A级毛片久久久精品毛片| 国产高清在线精品一区二区三区|