日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > c/c++ >内容正文

c/c++

opencv 梯度幅值_opencv3/C++ HOG特征提取方式

發布時間:2024/9/30 c/c++ 41 豆豆
生活随笔 收集整理的這篇文章主要介紹了 opencv 梯度幅值_opencv3/C++ HOG特征提取方式 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

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

發布時間:2020-08-23 16:24:01

來源:腳本之家

閱讀:111

HOG特征

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

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

HOG特征的提取過程為:

Gamma歸一化;

計算梯度;

劃分cell

組合成block,統計block直方圖;

梯度直方圖歸一化;

收集HOG特征。

Gamma歸一化:

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

計算梯度:

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

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

劃分cell

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

9bins:

如圖,不同數量的bins下的錯誤率:

組合成block,統計block直方圖

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

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

梯度直方圖歸一化

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

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

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

收集HOG特征

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

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

HOG的缺點:

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

OpenCV應用

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

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

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

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

#include

#include

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 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);

}

//框選出檢測結果

for(int i=0; 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特征提取方式就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持億速云。

與50位技術專家面對面20年技術見證,附贈技術全景圖

總結

以上是生活随笔為你收集整理的opencv 梯度幅值_opencv3/C++ HOG特征提取方式的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。