亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

opencv3/C++ HOG特征提取方式

 更新時間:2019年12月11日 09:43:29   作者:阿卡蒂奧  
今天小編就為大家分享一篇opencv3/C++ HOG特征提取方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

HOG特征

HOG(Histograms of Oriented Gradients)梯度方向直方圖

通過利用梯度信息能反映圖像目標的邊緣信息并通過局部梯度的大小將圖像局部的外觀和形狀特征化.在論文Histograms of Oriented Gradients for Human Detection中被提出.

HOG特征的提取過程為:

Gamma歸一化;

計算梯度;

劃分cell

組合成block,統(tǒng)計block直方圖;

梯度直方圖歸一化;

收集HOG特征。

Gamma歸一化:

對圖像顏色進行Gamma歸一化處理,降低局部陰影及背景因素的影響.

計算梯度:

通過差分計算出圖像在水平方向上及垂直方向上的梯度:

然后得到各個像素點的梯度的幅值及方向:

劃分cell

將整個窗口劃分成大小相同互不重疊的細胞單元cell(如8×8像素),計算出每個cell的梯度大小及方向.然后將每像素的梯度方向在0−180o0−180o 區(qū)間內(nèi)(無向:0-180,有向:0-360)平均分為9個bins,每個cell內(nèi)的像素用幅值來表示權(quán)值,為其所在的梯度直方圖進行加權(quán)投票.

9bins:

如圖,不同數(shù)量的bins下的錯誤率:

組合成block,統(tǒng)計block直方圖

將2×2個相鄰的cell組成大小為16×16的像素塊即block.依次將block大小的滑動窗口從左到右從上到下滑動,求其梯度方向直方圖向量.

如圖,不同大小的cell與不同大小的block作用下的效果對比:

梯度直方圖歸一化

作者對比了L2-norm、L1-norm、L1-sqrt等歸一化方法,發(fā)現(xiàn)都比非標準數(shù)據(jù)有顯著的改善.其中L2-norm和L1-sqrt效果最好,而L1-norm檢測效果要比L2-norm和L1-sqrt低5%.

如圖,不同的歸一化方法效果對比:

這樣通過歸一化能夠進一步地對光照、陰影和邊緣進行壓縮.

收集HOG特征

由于每個cell內(nèi)的梯度方向分成了9個bins,這樣每個細胞單元的HOG特征向量長度是9.

這樣,對于大小為128×64大小的圖像,采用8*8像素的sell,2×2個cell組成的16×16像素的block,采用8像素的block移動步長,這樣檢測窗口block的數(shù)量有((128-16)/8+1)×((64-16)/8+1)=15×7.則HOG特征描述符的維數(shù)為15×7×4×9.

HOG的缺點:

速度慢,實時性差;難以處理遮擋問題。

OpenCV應用

利用HOG進行行人檢測時有兩種用法:

1、采用HOG特征+SVM分類器進行行人檢測;

2、利用HOG+SVM訓練自己的XML文件。

采用第一種方法,使用HOG特征結(jié)合SVM分類器進行行人檢測,簡單示例:

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

int main()
{
 Mat src, dst;
 src = imread("E:/image/image/passerby.jpg",1);
 if (src.empty())
 {
 printf("can not load the image...\n");
 return -1;
 }
 dst = src.clone();
 vector<Rect> findrects, findrect;
 HOGDescriptor HOG;
 //SVM分類器
 HOG.setSVMDetector(HOGDescriptor::getDefaultPeopleDetector());
 //多尺度檢測
 HOG.detectMultiScale(src, findrects, 0, Size(4,4), Size(0,0), 1.05, 2);
 //若rects有嵌套,則取最外面的矩形存入rect
 for(int i=0; i < findrects.size(); i++)
 {
 Rect rect = findrects[i];
 int j=0;
 for(; j < findrects.size(); j++)
  if(j != i && (rect & findrects[j]) == rect)
  break;
 if( j == findrects.size())
  findrect.push_back(rect);
 }
 //框選出檢測結(jié)果
 for(int i=0; i<findrect.size(); i++)
 {
 RNG rng(i);
 Scalar color = Scalar(rng.uniform(0,255), rng.uniform(0,255), rng.uniform(0,255));
 rectangle(dst, findrect[i].tl(), findrect[i].br(), color, 2);
 }

 imshow("src",src);
 imshow("dst",dst);
 waitKey();
 return 0;
}

以上這篇opencv3/C++ HOG特征提取方式就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • Qt實現(xiàn)自定義矩陣布局

    Qt實現(xiàn)自定義矩陣布局

    這篇文章主要為大家詳細介紹了Qt實現(xiàn)自定義矩陣布局,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • Windows注冊表中修改UAC(用戶賬號控制)及批處理腳本

    Windows注冊表中修改UAC(用戶賬號控制)及批處理腳本

    今天小編就為大家分享一篇關于Windows注冊表中修改UAC(用戶賬號控制)及批處理腳本,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2018-12-12
  • C++控制臺實現(xiàn)俄羅斯方塊游戲

    C++控制臺實現(xiàn)俄羅斯方塊游戲

    這篇文章主要為大家詳細介紹了C++控制臺實現(xiàn)俄羅斯方塊游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-06-06
  • C語言以數(shù)據(jù)塊的形式讀寫文件實例代碼

    C語言以數(shù)據(jù)塊的形式讀寫文件實例代碼

    本文主要介紹C語言中以數(shù)據(jù)塊的形式讀寫文件,這里提供了實例代碼舉例說明,有需要的小伙伴可以參考下
    2016-07-07
  • Qt實現(xiàn)簡易時鐘

    Qt實現(xiàn)簡易時鐘

    這篇文章主要為大家詳細介紹了Qt實現(xiàn)簡易時鐘,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-07-07
  • c++遞歸解數(shù)獨方法示例

    c++遞歸解數(shù)獨方法示例

    這篇文章主要介紹了c++遞歸解數(shù)獨方法示例,需要的朋友可以參考下
    2014-03-03
  • C語言操作符超詳細講解下篇

    C語言操作符超詳細講解下篇

    C?語言提供了豐富的操作符,有:算術(shù)操作符,移位操作符,位操作符,賦值操作符,單目操作符,關系操作符,邏輯操作符,條件操作符等。本篇為第二篇,讓我們通讀本篇來詳細了解吧
    2022-04-04
  • 從頭學習C語言之字符串處理函數(shù)

    從頭學習C語言之字符串處理函數(shù)

    這篇文章主要為大家詳細介紹了C語言之字符串處理函數(shù),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,?希望能夠給你帶來幫助
    2022-01-01
  • C++ OpenCV學習之圖像像素值統(tǒng)計

    C++ OpenCV學習之圖像像素值統(tǒng)計

    在圖像分析的時候,我們經(jīng)常需要對單通道圖像的像素進行統(tǒng)計。本文將主要介紹利用C++ OpenCV實現(xiàn)的圖像像素值統(tǒng)計的幾種方法,需要的可以參考一下
    2022-01-01
  • EasyC++?右值引用

    EasyC++?右值引用

    這篇文章主要介紹了C++?右值引用,右值引用指的是以引用傳遞(而非值傳遞)的方式使用?C++?右值,下面文章將對此詳細介紹,需要的朋友可以參考一下,希望對你有所幫助
    2021-12-12

最新評論