日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

分类器是如何做检测的?——CascadeClassifier中的detectMultiScale函数解读

發布時間:2023/12/1 编程问答 43 豆豆
生活随笔 收集整理的這篇文章主要介紹了 分类器是如何做检测的?——CascadeClassifier中的detectMultiScale函数解读 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

原地址:http://blog.csdn.net/delltdk/article/details/9186875

在進入detectMultiScal函數之前,首先需要對CascadeClassifier做初始化。

1.???? 初始化——read函數

CascadeClassifier的初始化很簡單:

cv::CascadeClassifier classifier;

classifier.load(“cascade.xml”); //這里的xml是訓練得到的分類器xml

?

CascadeClassifier類中既有load也有read函數,二者是相同的,load將引用read函數。

1.1?? xml的結構

訓練得到的分類器以xml形式保存,整體上它包括stageType、featureType、height、width、stageParams、featureParams、stages、features幾個節點。

?

圖1. 分類器的Xml文件整體結構

除stages和features外,其他主要是一些分類器的參數。

Stages中包含15個stage(訓練程序設定),每個stage中包含多個weakClassifiers,而每個weakClassifier中又包含一個internalNodes和一個leafValues。internalNodes中四個變量代表一個node,分別為node中的left/right標記、特征池中的ID和threshold。leafValues中兩個變量代表一個node,分別為left leaf的值和right leaf的值。

?

圖2. 分類器的Xml文件具體結構

而features是分類器的特征池,每個特征包含一個矩形和要提取的特征序號(0~35)。

?

圖3. features的具體結構

1.2?? read的過程

下面是read代碼,主要包括從xml中獲取兩部分內容:data和featureEvaluator的讀取。

bool?CascadeClassifier::read(constFileNode&root)

{

????if( !data.read(root) )//data成員變量的讀取

????????return?false;

?

????// load features---特征的讀取

????featureEvaluator=?FeatureEvaluator::create(data.featureType);

????FileNodefn?=root[CC_FEATURES];

????if(?fn.empty() )

????????return?false;

?

????return?featureEvaluator->read(fn);

}

1.2.1?????????data成員變量的讀取

data的讀取中同樣可以分為兩部分:分類器參數讀取和stage分類樹的建立。

首先是參數部分的獲取。

static?constfloatTHRESHOLD_EPS= 1e-5f;

?

// load stage params

// stageType為BOOST類型

????string?stageTypeStr?= (string)root[CC_STAGE_TYPE];

????if(?stageTypeStr?==?CC_BOOST)

????????stageType=?BOOST;

????else

????????return?false;

????//?這里以HOG特征分類器為例,featureType=2(HOG)

????string?featureTypeStr?= (string)root[CC_FEATURE_TYPE];

????if(?featureTypeStr?==?CC_HAAR)

????????featureType=?FeatureEvaluator::HAAR;

????else?if(?featureTypeStr==?CC_LBP?)

????????featureType=?FeatureEvaluator::LBP;

????else?if(?featureTypeStr==?CC_HOG?)

????????featureType=?FeatureEvaluator::HOG;

?

????else

????????return?false;

????//檢測窗口的最小size,也就是正樣本的size

????origWinSize.width?= (int)root[CC_WIDTH];

????origWinSize.height?= (int)root[CC_HEIGHT];

????CV_Assert(origWinSize.height> 0 &&origWinSize.width?> 0 );

????//我訓練得到的HOG分類器為true,還不清楚這里的意思

????isStumpBased= (int)(root[CC_STAGE_PARAMS][CC_MAX_DEPTH])== 1 ?true?:?false;

?

// load feature params

//?載入特征參數,HOG分類器下包括兩個參數:maxCatCount和featSize,featSize很透明,就是特征的種類數,這里為36,是指每個block中4個cell、每個cell9個梯度方向的直方圖。例如特征號為3時,計算的是當前窗口中劃分為4個cell后第一個cell中所有點在120°方向(可能是,這要視起始角度而定)上分量的和,然后經過歸一化后的值。對于第二個參數maxCatCount,這里為0,尚不清楚(這是指代表一個弱分類器的樹的類別數量,用來計算一棵樹的節點大小也就是nodeStep)

? ??FileNode?fn?=?root[CC_FEATURE_PARAMS];

????if(?fn.empty() )

????????return?false;

?

????ncategories=?fn[CC_MAX_CAT_COUNT];

????int?subsetSize?= (ncategories+ 31)/32,

???????nodeStep?= 3 + (?ncategories>0 ??subsetSize: 1 );

至此分類器參數讀取完畢。

?

接下來是建立分類樹,也就是stage部分的載入。

// load stages

????fn?=?root[CC_STAGES];

????if(?fn.empty() )

????????return?false;

?

????stages.reserve(fn.size());//stages包含15個節點,fn.size()==15

????classifiers.clear();

????nodes.clear();

?

????FileNodeIteratorit?=fn.begin(),it_end=fn.end();

?

????for(?int?si?= 0;?it?!=?it_end;?si++, ++it?)//遍歷stages

??? {

????????FileNodefns?= *it;

????????Stagestage;//stage結構中包含threshold、ntrees和first三個變量

????????stage.threshold?= (float)fns[CC_STAGE_THRESHOLD]-THRESHOLD_EPS;

????????fns=?fns[CC_WEAK_CLASSIFIERS];

????????if(fns.empty())

????????????returnfalse;

????????stage.ntrees?= (int)fns.size();

????????stage.first?= (int)classifiers.size();//ntrees和first指出該stage中包含的樹的數目和起始位置

????????stages.push_back(stage);//stage被保存在stage的vector(也就是stages)中

????????classifiers.reserve(stages[si].first?+stages[si].ntrees);//相應地擴展classifiers的空間,它存儲的是這些stage中的weak classifiers,也就是weak trees

?

????????FileNodeIteratorit1?=fns.begin(),it1_end=fns.end();//遍歷weak classifier

????????for( ;?it1?!=?it1_end;++it1?)// weaktrees

??????? {

????????????FileNodefnw?= *it1;

????????????FileNodeinternalNodes?=fnw[CC_INTERNAL_NODES];

????????????FileNodeleafValues?=fnw[CC_LEAF_VALUES];

????????????if(internalNodes.empty()||leafValues.empty())

????????????????returnfalse;

?

????????????DTreetree;

????????????tree.nodeCount?= (int)internalNodes.size()/nodeStep;

????????????classifiers.push_back(tree);//一個弱分類器或者說一個weak tree中只包含一個int變量,用它在classifiers中的位置和自身來指出它所包含的node個數

?

????????????nodes.reserve(nodes.size() +tree.nodeCount);

????????????leaves.reserve(leaves.size() +leafValues.size());//擴展存儲node和leaves的vector結構空間

????????????if(subsetSize?> 0 )

????????????????subsets.reserve(subsets.size() +tree.nodeCount*subsetSize);

?

????????????FileNodeIteratorinternalNodesIter?=internalNodes.begin(),internalNodesEnd=internalNodes.end();

//遍歷nodes

????????????for(;?internalNodesIter?!=?internalNodesEnd; )//nodes

??????????? {

????????????????DTreeNodenode;//一個node中包含left、right、threshold和featureIdx四個變量。其中left和right是其對應的代號,left=0,right=-1;featureIdx指的是整個分類器中使用的特征池中某個特征的ID,比如共有108個特征,那么featureIdx就在0~107之間;threshold是node的。同時可以看到這里的HOG分類器中每個弱分類器僅包含一個node,也就是僅對某一個特征做判斷,而不是多個特征的集合

????????????????node.left?= (int)*internalNodesIter; ++internalNodesIter;

????????????????node.right?= (int)*internalNodesIter; ++internalNodesIter;

????????????????node.featureIdx?= (int)*internalNodesIter; ++internalNodesIter;

????????????????if(subsetSize?> 0 )

??????????????? {

????????????????????for(intj?= 0;j?<subsetSize;j++, ++internalNodesIter)

? ??????????????????????subsets.push_back((int)*internalNodesIter);

????????????????????node.threshold?= 0.f;

??????????????? }

????????????????else

??????????????? {

????????????????????node.threshold?= (float)*internalNodesIter; ++internalNodesIter;

??????????????? }

????????????????nodes.push_back(node);//得到的node將保存在它的vector結構nodes中

??????????? }

?

????????????internalNodesIter=leafValues.begin(),internalNodesEnd?=leafValues.end();

?

????????????for(;?internalNodesIter?!=?internalNodesEnd; ++internalNodesIter)// leaves

????????????????leaves.push_back((float)*internalNodesIter);//leaves中保存相應每個node的left leaf和right leaf的值,因為每個weak tree只有一個node也就分別只有一個left leaf和right leaf,這些將保存在leaves中

??????? }

??? }

通過stage樹的建立可以看出最終是獲取stages、classifiers、nodes和leaves四個vector變量。其中的nodes和leaves共同組成一系列有序節點,而classifiers中的變量則是在這些節點中查詢來構成一個由弱分類器組,它僅僅是把這些弱分類器組合在一起,最后stages中每一個stage也就是一個強分類器,它在classifiers中查詢得到自己所屬的弱分類器都有哪些,從而構成一個強分類器的基礎。

1.2.2?????????featureEvaluator的讀取

完成data部分的載入后,接下來就是特征計算器(featureEvaluator)的載入了。上面每一個node中都會計算特征池中的某一個特征,這個特征以featureIdx出現在node中。現在來看看這些featureIdx背后的內容。

首先要創建某種特征類型的特征計算器,這里支持的是Haar、LBP和HOG三種。

featureEvaluator =FeatureEvaluator::create(data.featureType);

create中生成一個HaarEvaluator/LBPEvaluator/HOGEvaluator對象并返回指針而已。那HOGEvaluators中包含什么內容呢?

這里暫不提其他成員,先介紹一個vector<Feature>的指針 features,也就是存儲了一系列Feature對象:

struct?Feature

??? {

????????Feature();

????????float?calc(?int?offset?)const;

????????void?updatePtrs(?const?vector<Mat>&_hist,constMat?&_normSum);

????????bool?read(?const?FileNode&node);?

?

????????enum?{?CELL_NUM?= 4,?BIN_NUM= 9 };

?

????????Rectrect[CELL_NUM];

????????int?featComponent;?//componentindex from 0 to 35

????????const?float*?pF[4];?//for feature calculation

????????const?float*?pN[4];?//for normalization calculation

};

這里的vector<Feature>將是計算特征的核心,并且featureEvaluator的讀入部分主要就是對這個vector變量的內容作初始化,因此在此展示一下。

?

?featureEvaluator創建之后在xml中的features節點下開始讀入。

bool?HOGEvaluator::read(?const?FileNode&?node)

{

????features->resize(node.size());//node.size()為整個分類器中使用到的特征數量,以我訓練的HOG分類器為例包含108個特征

????featuresPtr= &(*features)[0];

????FileNodeIteratorit?=node.begin(),it_end=node.end();

????for(inti?= 0;it?!=it_end;++it,i++)

??? {

????????if(!featuresPtr[i].read(*it))//遍歷所有features并讀入到featureEvaluator的features中

????????????returnfalse;

??? }

????return?true;

}

Feature的讀入程序:

bool?HOGEvaluator::Feature?::?read(const?FileNode&node?)

{

????FileNodernode?=node[CC_RECT];//rect節點下包括一個矩形和一個特征類型號featComponent

????FileNodeIteratorit?=rnode.begin();

????it>>?rect[0].x>>?rect[0].y>>?rect[0].width>>?rect[0].height>>?featComponent;//featComponent范圍在[0,35],36類特征中的一個

????rect[1].x?=rect[0].x?+rect[0].width;

????rect[1].y?=rect[0].y;

????rect[2].x?=rect[0].x;

????rect[2].y?=rect[0].y?+rect[0].height;

????rect[3].x?=rect[0].x?+rect[0].width;

????rect[3].y?=rect[0].y?+rect[0].height;

????rect[1].width?=rect[2].width?=rect[3].width?=rect[0].width;

rect[1].height=rect[2].height=rect[3].height=rect[0].height;

//xml中的rect存儲的矩形信息與4個矩形之間的關系如下圖4所示

?

????return?true;

}

?

圖4. Rect數組與xml中矩形的關系

這樣經過特征讀取這一步后,獲得了一個特征池,池中每一個特征表示在圖中某個矩形位置提取ID為0到35的某個特征量。

?

1.3?? read的結果

read的結果一是初始化了分類器的特征類型、最小檢測窗口size等參數;二是建立級聯的分類器樹;三是提取了xml中的特征池。

2.???? detectMultiscale函數

在load分類器之后,可以調用該函數對一幅圖像做多尺度檢測。

2.1?? 函數自身

//輸入參數:image—Mat類型的圖像

???????????objects—檢測得到的矩形

???????????rejectLevels—如果不符合特征的矩形,返回級聯分類器中符合的強分類器數

???????????levelWeights—

??????????scaleFactor—圖像縮放因子

???????????minNeighbors—

??????????flags—

???????? ??minObjectSize—最小檢測窗口大小

???????????maxObjectSize—最大檢測窗口大小

???????????outputRejectLevels—是否輸出rejectLevels和levelWeights,默認為false

voidCascadeClassifier::detectMultiScale(constMat&image,vector<Rect>&objects,vector<int>&rejectLevels,vector<double>&levelWeights,doublescaleFactor,intminNeighbors,intflags,SizeminObjectSize,SizemaxObjectSize,booloutputRejectLevels)

{

????const?double?GROUP_EPS?=0.2;

?

????CV_Assert(scaleFactor?> 1 &&image.depth()==CV_8U?);//256灰度級且當前縮放因子大于1

?

????if(?empty() )//沒有載入

????????return;

?

????if(?isOldFormatCascade() )//這里是指haarTraining得到的分類器或者老版本的OpenCV,我不確定,但是這里可以跳過,因為訓練與檢測所使用的OpenCV版本是一致的

??? {

????????MemStoragestorage(cvCreateMemStorage(0));

????????CvMat_image?=image;

????????CvSeq*_objects=cvHaarDetectObjectsForROC(&_image,oldCascade,storage,rejectLevels,levelWeights,scaleFactor,

??????????????????????????????????????????????minNeighbors,?flags,minObjectSize,maxObjectSize,outputRejectLevels?);

????????vector<CvAvgComp>vecAvgComp;

????????Seq<CvAvgComp>(_objects).copyTo(vecAvgComp);

????????objects.resize(vecAvgComp.size());

????????std::transform(vecAvgComp.begin(),vecAvgComp.end(),objects.begin(),getRect());

????????return;

??? }

?

????objects.clear();

//mask的應用尚不清楚

????if?(!maskGenerator.empty()){

????????maskGenerator->initializeMask(image);

??? }

?

?

????if(?maxObjectSize.height== 0 ||?maxObjectSize.width?== 0 )//很明顯不能為0

????????maxObjectSize=?image.size();//默認最大檢測size為圖像size

?

????Mat?grayImage?=?image;

????if(?grayImage.channels()> 1 )//如果是三通道轉換為灰度圖

??? {

????????Mat?temp;

????????cvtColor(grayImage,temp,CV_BGR2GRAY);

????????grayImage=?temp;

??? }

?

????Mat?imageBuffer(image.rows?+ 1,image.cols?+ 1,CV_8U);

????vector<Rect>candidates;//每個尺度下的圖像的檢測結果裝在該vector中

?

????for(?double?factor?= 1;;?factor?*=?scaleFactor)//對每個尺度下圖像檢測

??? {

????????SizeoriginalWindowSize?=getOriginalWindowSize();//最小檢測窗口size

?

????????SizewindowSize(cvRound(originalWindowSize.width*factor),cvRound(originalWindowSize.height*factor) );//當前檢測窗口size

????????SizescaledImageSize(cvRound(grayImage.cols/factor?),cvRound(grayImage.rows/factor?) );//縮放后圖像size

????????SizeprocessingRectSize(scaledImageSize.width?-originalWindowSize.width?+ 1,scaledImageSize.height-originalWindowSize.height?+ 1 );//滑動窗口在寬和高上的滑動距離

?

????????if(?processingRectSize.width<= 0 ||?processingRectSize.height?<= 0 )

????????????break;

????????if(?windowSize.width>?maxObjectSize.width||?windowSize.height>?maxObjectSize.height)

????????????break;

????????if(?windowSize.width<?minObjectSize.width||?windowSize.height<?minObjectSize.height)

????????????continue;

?

????????Mat?scaledImage(?scaledImageSize,CV_8U,imageBuffer.data?);

????????resize(grayImage,scaledImage,scaledImageSize, 0, 0,CV_INTER_LINEAR?);//將灰度圖resize到scaledImage中,size為當前尺度下的縮放圖像

?

????????int?yStep;//滑動窗口的滑動步長,x和y方向上相同

????????if(?getFeatureType() ==?cv::FeatureEvaluator::HOG)

??????? {

????????????yStep= 4;

??????? }

????????else

??????? {

????????????yStep=?factor?> 2. ? 1 : 2;//當縮放比例比較大時,滑動步長減小

??????? }

?

????????int?stripCount,?stripSize;

?

????#ifdef?HAVE_TBB

??????? const intPTS_PER_THREAD = 1000;

??????? stripCount =((processingRectSize.width/yStep)*(processingRectSize.height + yStep-1)/yStep +PTS_PER_THREAD/2)/PTS_PER_THREAD;

??????? stripCount =std::min(std::max(stripCount, 1), 100);

??????? stripSize =(((processingRectSize.height + stripCount - 1)/stripCount +yStep-1)/yStep)*yStep;

????#else

????????stripCount= 1;

????????stripSize=?processingRectSize.height;//y方向上的滑動距離

????#endif

?

????????if( !detectSingleScale(scaledImage,stripCount,processingRectSize,stripSize,yStep,factor,candidates,

????????????rejectLevels,levelWeights,outputRejectLevels) )//對單尺度圖像做檢測

????????????break;

??? }

?

?

????objects.resize(candidates.size());

????std::copy(candidates.begin(),candidates.end(),objects.begin());//將每個尺度下的檢測結果copy到輸出vector中

?

????if(?outputRejectLevels?)//默認為false,不輸出rejectLevels

??? {

????????groupRectangles(objects,rejectLevels,levelWeights,minNeighbors,GROUP_EPS?);

??? }

????else

??? {

????????groupRectangles(objects,minNeighbors,GROUP_EPS?);//尚未去看

??? }

}

?

可以看到detectMultiscale只是對detectSingleScale做了一次多尺度的封裝。在單一尺度的圖像中detectSingleScale是如何檢測的呢?

2.2??detectSingleScale函數

//函數參數設置可以參見detectMultiScale函數

boolCascadeClassifier::detectSingleScale(constMat&image,intstripCount,SizeprocessingRectSize,intstripSize,intyStep,doublefactor,vector<Rect>&candidates,vector<int>&levels,vector<double>&weights,booloutputRejectLevels)

{

????if( !featureEvaluator->setImage(image,data.origWinSize?) )//setImage函數為特征計算做準備,

????????return?false;

?

????Mat?currentMask;

????if?(!maskGenerator.empty()){

????????currentMask=maskGenerator->generateMask(image);

??? }//仍然不解mask的應用,好像沒用到?

?

????ConcurrentRectVectorconcurrentCandidates;//在每個平行粒子中訪問的檢測輸出空間

????vector<int>rejectLevels;

????vector<double>levelWeights;

????if(?outputRejectLevels?)//這里選擇的默認false,不返回

??? {

???????parallel_for(BlockedRange(0,stripCount),CascadeClassifierInvoker(*this,processingRectSize,stripSize,yStep,factor,

????????????concurrentCandidates,rejectLevels,levelWeights,true,currentMask));

????????levels.insert(levels.end(),rejectLevels.begin(),rejectLevels.end() );

????????weights.insert(weights.end(),levelWeights.begin(),levelWeights.end() );

??? }

????else

??? {

????????parallel_for(BlockedRange(0,stripCount),CascadeClassifierInvoker(*this,processingRectSize,stripSize,yStep,factor,concurrentCandidates,rejectLevels,levelWeights,false,currentMask));//這里是檢測過程中的關鍵,使用parallel_for是為了TBB加速中使用,生成stripCount個平行線程(每個線程生成一個CascadeClassifierInvoker),在每個CascadeClassifierInvoker中對當前圖像做一次檢測,這是TBB利用多線程做的加速計算

??? }

????candidates.insert(candidates.end(),concurrentCandidates.begin(),concurrentCandidates.end() );//將檢測結果加入到輸出中

?

????return?true;

}

2.2.1?????????featureEvaluators的setImage函數

?? 此處仍以HOG為例,其他兩個特征的計算可能與之有所不同。

bool?HOGEvaluator::setImage(?const?Mat&?image,Size?winSize)

{

????int?rows?=?image.rows?+ 1;

????int?cols?=?image.cols?+ 1;

????origWinSize=?winSize;//最小檢測窗口size

????if(?image.cols?<origWinSize.width||image.rows<origWinSize.height)

????????return?false;

????hist.clear();//hist為存儲Mat類型的vector

????for(?int?bin?= 0;?bin?<?Feature::BIN_NUM;bin++)//BIN_NUM=9,梯度方向分為9個,所以統計得到的Mat個數應當為9個

??? {

????????hist.push_back(Mat(rows,cols,CV_32FC1) );

??? }

????normSum.create(rows,cols,CV_32FC1);//歸一化的norm存儲空間

?

????integralHistogram(image,hist,normSum,Feature::BIN_NUM?);//計算歸一化后的直方圖

?

????size_t?featIdx,?featCount=?features->size();

//遍歷更新特征池中每個特征的HOG特征計算所需要的矩形四個頂點上對應積分圖的指針

????for(?featIdx?= 0;?featIdx<?featCount;?featIdx++)

??? {

????????featuresPtr[featIdx].updatePtrs(hist,normSum);

??? }

????return?true;

}

這里的updatePtrs函數是要根據梯度直方圖和歸一圖來更新每個Feature中保存的四個指針,例如某Feature在xml中的形式為0 0 8 8 13,那么它所在的矩形就是cvRect(0,0,16,16),同時featComponent=13,binIdx=featComponent%9=4,cellIdx=featComponent/9=1.那么這個特征就是要計算矩形(8,0,8,8)中梯度方向160°方向上的分量總和。要計算這個特征我們只需要在hist中的第4個Mat中查找出矩形四個頂點上的值就可以了。而Feature中的四個float型指針正是指向hist中這四個值的指針。UpdatePtrs的作用就是要更新這四個指針。具體程序如下:

inline?voidHOGEvaluator::Feature?::updatePtrs(constvector<Mat> &_hist,constMat&_normSum?)

{

????int?binIdx?=?featComponent%?BIN_NUM;//計算要更新的角度

????int?cellIdx?=?featComponent/?BIN_NUM;//計算要更新的cell是哪一個

????Rect?normRect?=?Rect(rect[0].x,rect[0].y,2*rect[0].width,2*rect[0].height);

?

????const?float*?featBuf?= (constfloat*)_hist[binIdx].data;

????size_t?featStep?=?_hist[0].step?/sizeof(featBuf[0]);

?

????const?float*?normBuf?= (constfloat*)_normSum.data;

????size_t?normStep?=?_normSum.step?/sizeof(normBuf[0]);

?

????CV_SUM_PTRS(pF[0],pF[1],pF[2],pF[3],featBuf,rect[cellIdx],featStep);//更新四個直方積分圖中的指針

????CV_SUM_PTRS(pN[0],pN[1],pN[2],pN[3],normBuf,normRect,normStep?);//更新四個歸一圖中的指針

}

2.2.2?????????CascadeClassifierInvoker類的實例化

每個線程中會生成該類的一個對象,但是這里沒有做TBB加速,因而是單線程。該對象的operator中對當前縮放尺度下的圖像以滑窗形式掃描,在每個點上做分類器級聯檢測;如果有TBB加速,每個對象僅檢測一行,通過多行一起掃描來加速。

void?operator()(constBlockedRange&range)const

??? {

????????Ptr<FeatureEvaluator>evaluator=classifier->featureEvaluator->clone();//復制featureEvaluator的指針

?

????????SizewinSize(cvRound(classifier->data.origWinSize.width*scalingFactor),cvRound(classifier->data.origWinSize.height*scalingFactor));//當前檢測窗口的size,其實這里是通過縮放圖像來做的,而不是窗口大小的改變

?

????????int?y1?=?range.begin() *stripSize;//range的變化范圍為[0,1)

????????int?y2?=?min(range.end() *stripSize,processingRectSize.height);//y方向上的行數不可能超過滑動距離

????????for(?int?y?=?y1;y?<y2;y?+=yStep?)//遍歷所有行

??????? {

????????????for(intx?= 0;x?<processingRectSize.width;x?+=yStep?)//遍歷一行

??????????? {

//依然是尚未搞懂的mask

????????????????if( (!mask.empty())&& (mask.at<uchar>(Point(x,y))==0)) {

????????????????????continue;

??????????????? }

?

????????????????doublegypWeight;

????????????????intresult?=classifier->runAt(evaluator,Point(x,y),gypWeight);//在當前點提取每個stage中的特征并檢驗是否滿足分類器,result是通過的stage個數的相反數,如果全部通過則為1

????????????????if(rejectLevels?)//默認為false

??????????????? {

????????????????????if(result?== 1 )

????????????????????????result?=? -(int)classifier->data.stages.size();

????????????????????if(classifier->data.stages.size() +result?< 4 )

??????????????????? {

????????????????????????rectangles->push_back(Rect(cvRound(x*scalingFactor),cvRound(y*scalingFactor),winSize.width,winSize.height));

????????????????????????rejectLevels->push_back(-result);

????????????????????????levelWeights->push_back(gypWeight);

??????????????????? }

??????????????? }

????????????????elseif(result> 0 )

????????????????????rectangles->push_back(Rect(cvRound(x*scalingFactor),cvRound(y*scalingFactor),winSize.width,winSize.height));

????????????????if(result?== 0 )//保存當前的窗口

????????????????????x+=?yStep;

??????????? }

??????? ??}

? }

這個程序中唯一需要解釋的是CascadeClassifier::runAt函數。對于isStumpBased=true的HOG分類器,返回的結果是predictOrderedStump<HOGEvaluator>(*this, evaluator, weight )this指針是當前CascadeClassifier的指針,evaluator是featureEvaluator的指針,weight為double類型。predictOrderedStump函數如下:

?

template<classFEval>

inline?intpredictOrderedStump(CascadeClassifier&cascade,Ptr<FeatureEvaluator> &_featureEvaluator,double&sum)

{

????int?nodeOfs?= 0,?leafOfs= 0;//node和leaf的整體序號

????FEval&featureEvaluator?= (FEval&)*_featureEvaluator;

????float*?cascadeLeaves?= &cascade.data.leaves[0];//定義指向leaves首地址的指針

????CascadeClassifier::Data::DTreeNode*cascadeNodes?= &cascade.data.nodes[0];//定義指向nodes首地址的指針

????CascadeClassifier::Data::Stage*cascadeStages?= &cascade.data.stages[0];//定義指向stages首地址的指針

?

????int?nstages?= (int)cascade.data.stages.size();

????for(?int?stageIdx?= 0;?stageIdx?<?nstages;stageIdx++ )

??? {

????????CascadeClassifier::Data::Stage&stage?=cascadeStages[stageIdx];//遍歷每個stage

????????sum= 0.0;//該stage中的葉節點的和

?

????????int?ntrees?=?stage.ntrees;

????????for(?int?i?= 0;?i?<?ntrees;?i++,?nodeOfs++,leafOfs+= 2 )

??????? {

????????????CascadeClassifier::Data::DTreeNode&node?=cascadeNodes[nodeOfs];//獲取當前stage的各個node

????????????doublevalue?=featureEvaluator(node.featureIdx);//這里node的featureIdx指出要計算的是哪一個特征,也就是xml中的哪一個rect,在生成一個HOGEvaluator時就會在operator中根據傳入的featureIdx計算特征值,引用到HOGEvaluator中的calc函數

????????????sum+=?cascadeLeaves[?value<?node.threshold??leafOfs?:?leafOfs+ 1 ];//根據node中的threshold得到左葉子或者右葉子的值,加到該stage中的總和

??????? }

?

????????if(?sum?<?stage.threshold?)//如果總和大于stage的threshold則通過,小于則退出,并返回當前stage的相反數

????????????return-stageIdx;

??? }

????return?1;

}

Feature中的calc很簡單,因為前面已經更新了四個對應于矩形頂點處積分圖的指針已經被更新,歸一圖中的指針也已經被更新。

這里表達的計算如下圖所示:

?

圖5. 積分圖計算示意

要計算D中的值,在積分圖中四個頂點的指針所指向的內容分別為A,A+B,A+C和A+B+C+D。因此中間兩項與其余兩項的差就是要求的D區域了。其中的offset變量是根據滑動窗口的位置確定的,代表上圖中D矩形的左上頂點在全圖中的位置。程序如下:

首先由如下定義

#define?CALC_SUM_(p0,p1,p2,p3,offset)

??? ((p0)[offset] - (p1)[offset] - (p2)[offset] + (p3)[offset])??

???

#define?CALC_SUM(rect,offset)CALC_SUM_((rect)[0], (rect)[1],(rect)[2], (rect)[3],offset)

然后是Feature中的calc函數

inline?floatHOGEvaluator::Feature?::calc(intoffset?)const

{

????float?res?=?CALC_SUM(pF,offset);

????float?normFactor?=?CALC_SUM(pN,offset);

????res?= (res?> 0.001f) ? (res/ (normFactor?+ 0.001f) ) : 0.f;

????return?res;

}

?

編后語: 此處均以HOG特征為例,有關Haar特征和LBP特征的計算部分,可參見

分類器是如何做檢測的?——【續】檢測中Haar和LBP特征的計算

轉載于:https://www.cnblogs.com/lanye/p/3599375.html

總結

以上是生活随笔為你收集整理的分类器是如何做检测的?——CascadeClassifier中的detectMultiScale函数解读的全部內容,希望文章能夠幫你解決所遇到的問題。

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

国产亚洲综合性久久久影院 | 婷香五月| 亚洲国产精品va在线看黑人动漫 | 久色 网| 在线一区二区三区 | 99精品在线 | 亚洲国产中文字幕在线 | 免费网址你懂的 | 国产系列精品av | 永久免费的啪啪网站免费观看浪潮 | 国产一区自拍视频 | 97在线观视频免费观看 | 久久99精品一区二区三区三区 | 日本黄色黄网站 | 91超级碰碰 | 美女搞黄国产视频网站 | 精品国产乱码久久久久久1区2匹 | 色综合久久88色综合天天免费 | 国产精品99视频 | 精品久久网站 | 成片免费观看视频 | 黄色亚洲 | 婷久久| 一级片视频免费观看 | 亚洲黄色区 | 涩涩网站在线播放 | 国产欧美久久久精品影院 | 久久人人爽人人爽人人 | 国产高清永久免费 | 国产中文字幕在线视频 | 在线中文字幕视频 | 精品亚洲视频在线观看 | 国产一区二区久久久久 | 在线观看视频你懂的 | 午夜性盈盈 | 最近免费观看的电影完整版 | 日韩三区在线观看 | 麻豆网站免费观看 | 亚洲干 | 91精品在线观看视频 | 99精品免费久久久久久日本 | 97香蕉久久超级碰碰高清版 | 草久电影 | 色天堂在线视频 | 日韩中文字幕91 | a√国产免费a | 国产乱码精品一区二区蜜臀 | 亚洲 欧美日韩 国产 中文 | 黄色一区二区在线观看 | 国产1区在线观看 | 免费观看久久久 | 日韩电影久久 | 欧美精品v国产精品v日韩精品 | 欧美电影在线观看 | 久久久网站 | 亚洲欧美视频在线观看 | 精品一区二区电影 | www.com久久久| 国产成人精品久久久久 | 91av亚洲 | 亚洲一区久久久 | 欧美最爽乱淫视频播放 | 国产高清无av久久 | 成人久久18免费网站麻豆 | 五月婷香 | 久久九九国产精品 | 在线视频国产区 | 91黄色免费看 | 亚洲欧洲国产日韩精品 | 在线观看国产91 | 天天干天天射天天操 | 日韩中文免费视频 | 激情久久久久久久久久久久久久久久 | 欧美国产视频在线 | 亚洲久草视频 | 一区二区三区四区五区在线 | 不卡av电影在线 | 国产 在线观看 | 17婷婷久久www | 亚洲一区二区三区精品在线观看 | 成年人免费在线 | 国产中文字幕网 | 成人不用播放器 | 国产成人精品一区二区三区福利 | 五月婷婷六月丁香 | 国产区精品区 | japanese黑人亚洲人4k | 国产一区二区三区高清播放 | 国产精品久久久久一区 | 黄色av影视| 精品日韩中文字幕 | 三上悠亚一区二区在线观看 | 精品久久久久一区二区国产 | 黄色网址a | 国产精品一级视频 | 一区二区三区电影 | 亚洲一级片在线看 | 亚洲一区二区三区miaa149 | 青青草华人在线视频 | 国产精品久久久久久久久久久久午 | 伊人电影天堂 | 欧美精品久久久久久久亚洲调教 | 国产精品一区二区三区四区在线观看 | 欧美日韩国产一区二区在线观看 | 婷婷六月在线 | 免费精品视频在线 | 精品天堂av | av不卡在线看 | 日本特黄一级片 | 天天艹 | 国产伦精品一区二区三区无广告 | 国产一线天在线观看 | 91刺激视频 | 久久久久久久久久久久久国产精品 | 国产欧美精品一区二区三区四区 | 91福利国产在线观看 | 伊人在线视频 | 天天操天天操天天操 | 久草在线99 | 高清久久久久久 | 免费电影一区二区三区 | 亚洲va欧美va人人爽春色影视 | 亚洲精品国产拍在线 | 免费看片成年人 | 久久久夜色 | 中文字幕一区二区三区四区 | 男女全黄一级一级高潮免费看 | 片网站 | 四虎国产精| 亚洲成人资源网 | 日韩 精品 一区 国产 麻豆 | 婷婷激情网站 | 中文字幕xxxx| 成人黄大片视频在线观看 | 久国产在线播放 | 国产成人一区三区 | 中文字幕av在线电影 | 亚洲国产精品电影在线观看 | 中文字幕色婷婷在线视频 | 美女av免费看 | 日韩va在线观看 | 黄色免费视频在线观看 | 亚洲精品色 | 欧美日韩一区二区免费在线观看 | 久久国产精品一区二区三区四区 | 亚洲精品在线视频观看 | 亚洲国产婷婷 | 精品一区二区三区在线播放 | 91精品一区二区三区蜜桃 | 91精品久久久久久综合乱菊 | 成人av片在线观看 | 欧美日韩国产亚洲乱码字幕 | 另类老妇性bbwbbw高清 | 欧美成人xxxx| 久草新在线 | 美女久久精品 | 免费亚洲一区二区 | 午夜视频在线观看一区二区 | 色视频在线看 | 黄色av影视 | 国产精品婷婷午夜在线观看 | 国产99久 | 久久免费成人网 | 在线观看免费日韩 | 久久99九九99精品 | 久99久中文字幕在线 | 国产精品免费小视频 | 欧美日韩亚洲在线观看 | 91麻豆精品国产自产 | 国产日韩精品一区二区三区 | 亚州精品在线视频 | 久久蜜臀一区二区三区av | 亚洲va在线va天堂va偷拍 | 99久久er热在这里只有精品66 | 性色大片在线观看 | 97在线观看免费观看高清 | 国产一区国产二区在线观看 | 91看国产 | 天海翼一区二区三区免费 | 免费中午字幕无吗 | 久久成年人网站 | 九九色在线 | 美女视频a美女大全免费下载蜜臀 | 四虎小视频 | 国产视频 亚洲视频 | 欧美日韩视频网站 | 亚洲天堂网在线视频观看 | 国产成人一区二区三区 | 天堂av在线网 | www五月天婷婷 | 久久y| 亚洲国产精品久久久久久 | 欧美久草视频 | 中文字幕乱码亚洲精品一区 | 亚洲精品自拍 | 国产在线p| 国产成人精品一区二区三区在线 | 国产美女黄网站免费 | 国产 日韩 欧美 在线 | 在线播放亚洲激情 | 亚洲欧美精品一区二区 | 444av| 久久国产免费视频 | 黄色国产在线观看 | 热九九精品 | 中文字幕日本在线 | 色五月色开心色婷婷色丁香 | 成人av播放 | 日韩精品中文字幕av | 热99在线| 国产99精品在线观看 | 久热免费在线 | 日韩欧美网址 | 成人网中文字幕 | av福利免费 | av免费观看网址 | 992tv又爽又黄的免费视频 | 亚洲成人av在线电影 | 日韩成片| 久草精品视频 | 日韩电影中文字幕在线 | 日韩美女一级片 | 精品一区91 | 欧美日韩精品国产 | 日韩一级黄色大片 | 综合在线亚洲 | 日韩电影久久 | 一个色综合网站 | 国产一区二区三精品久久久无广告 | 国产精品一区二区在线观看 | 大型av综合网站 | 亚洲欧美怡红院 | 久久综合九色综合97_ 久久久 | 日日久视频 | 99在线免费视频 | 夜夜高潮夜夜爽国产伦精品 | 国产精品综合在线 | 国产精品对白一区二区三区 | 99久精品| 久久艹精品 | 久久久久在线 | 国产麻豆精品免费视频 | 91麻豆精品久久久久久 | 成人a级免费视频 | 久99久在线视频 | 黄色电影网站在线观看 | 成人国产精品久久久久久亚洲 | 亚洲更新最快 | 日本韩国精品一区二区在线观看 | 国产亚洲aⅴaaaaaa毛片 | 丁香五月亚洲综合在线 | 久久天天躁狠狠躁夜夜不卡公司 | 国产精品第十页 | 亚洲狠狠丁香婷婷综合久久久 | 国产精品专区在线观看 | av视屏在线播放 | 91九色在线观看视频 | 中文字幕a∨在线乱码免费看 | 97色综合 | 99re8这里有精品热视频免费 | 国产看片网站 | 91九色国产在线 | 手机看国产毛片 | 九七在线视频 | 国产做aⅴ在线视频播放 | 香蕉视频色 | 国内视频| 91网站在线视频 | 欧美视频日韩视频 | 99国产成+人+综合+亚洲 欧美 | 中文字幕色网站 | 午夜美女福利 | 欧美一级片在线免费观看 | 亚洲精品观看 | 97成人在线观看 | 超碰在线亚洲 | 激情丁香5月 | 亚洲狠狠婷婷综合久久久 | 久久综合天天 | 在线视频黄 | www.精选视频.com | 国产精品一区一区三区 | 国产黄色精品在线 | 精品国产伦一区二区三区 | 国产一区二区三区视频在线 | 国产五月色婷婷六月丁香视频 | www五月天com | 极品美女被弄高潮视频网站 | 97日日碰人人模人人澡分享吧 | 久久精品—区二区三区 | 天天撸夜夜操 | a级国产乱理伦片在线播放 久久久久国产精品一区 | 粉嫩高清一区二区三区 | 久久永久免费视频 | 久久精品二区 | 亚洲做受高潮欧美裸体 | 免费av大全 | 国产精品99久久久久久武松影视 | 99久久夜色精品国产亚洲96 | 日韩在线免费高清视频 | 人人插人人看 | 亚洲a色| 麻花豆传媒mv在线观看 | 国产精品原创av片国产免费 | 国产色就色 | 国产精品video爽爽爽爽 | 国产精品久久久久久影院 | 久久久精品高清 | 手机av看片| 最新高清无码专区 | 草莓视频在线观看免费观看 | 中文字幕在线观看视频网站 | 久福利| 在线天堂v| 97超碰色 | 日韩av资源在线观看 | 六月色| 亚洲精品综合久久 | 色综合人人 | 天天爱天天操天天爽 | 美女久久一区 | 99免费在线观看视频 | 激情电影在线观看 | 欧美日韩国产二区 | 久久久久色| 日日干日日 | 亚洲一区尤物 | 精品日本视频 | 国产精品久久久久永久免费观看 | 99这里只有精品视频 | 亚洲婷婷免费 | 国产亚洲字幕 | 中文字幕 国产精品 | 国产在线观看网站 | 国产精品资源网 | 91丨九色丨蝌蚪丨老版 | 在线高清一区 | 久久精品老司机 | 精品国产一区二区三区久久影院 | 97在线影院 | 国产色一区| 日韩一区二区免费播放 | 中文字幕在线观看免费 | 久久成电影 | 97超碰人人网 | www.夜夜骑.com | 色免费在线 | 手机在线看永久av片免费 | 日韩免费视频网站 | 日韩电影中文,亚洲精品乱码 | 中文字幕中文字幕在线一区 | 久久精品久久精品久久 | 免费在线观看一区二区三区 | 欧美日韩高清国产 | 亚洲欧美激情精品一区二区 | 天天射一射 | 久久人人爽爽人人爽人人片av | 99久久精品免费看国产免费软件 | 四虎成人免费观看 | 久久99九九99精品 | 欧美污污视频 | 九九免费精品视频 | 日韩av线观看 | 欧美激情第十页 | www.香蕉视频 | 欧美日韩视频观看 | 日韩av中文字幕在线免费观看 | 中文字幕在线有码 | 九九视频在线观看视频6 | 国产精品美女久久久久久久 | 97精品超碰一区二区三区 | 中文字幕 二区 | 中文字幕韩在线第一页 | 国产一区电影在线观看 | 免费碰碰 | 超碰97免费在线 | 激情五月五月婷婷 | 一区二区三区久久 | 日韩特级毛片 | 色午夜影院 | 亚洲一级片在线看 | 手机在线永久免费观看av片 | 中文字幕国产一区二区 | 亚洲成aⅴ人片久久青草影院 | 久草在线免费色站 | 国产白浆在线观看 | 毛片基地黄久久久久久天堂 | 激情图片区 | 日韩精品一区二区在线观看 | 狠狠色丁香九九婷婷综合五月 | 中文字幕日韩有码 | 欧美日韩不卡一区二区 | 色婷婷综合久色 | 日日骑| 91成人区| 在线国产精品视频 | 五月婷婷综合激情网 | 91免费在线视频 | 欧美在线a视频 | 丰满少妇久久久 | 91av在线免费观看 | 永久免费的啪啪网站免费观看浪潮 | 日韩手机视频 | 亚洲人xxx| 久久怡红院 | 婷婷国产在线观看 | 婷久久 | 国产 一区二区三区 在线 | 日韩网站免费观看 | 国产成在线观看免费视频 | 国产黄视频在线观看 | 国产黄色片网站 | 成人免费一级 | 久久国产精品免费 | 狠狠狠色丁香婷婷综合久久88 | 日韩精品一区二区三区视频播放 | 九九在线视频免费观看 | 国产精品婷婷 | 欧美一级片在线免费观看 | 天天操综合 | 黄色成年片 | 99热在线这里只有精品 | 91麻豆精品国产91久久久无限制版 | 国产一区二区网址 | 国产成人三级一区二区在线观看一 | 亚洲一级片在线观看 | 超碰97久久| 日韩精品一区二区久久 | 91精品国产一区二区在线观看 | 午夜精品久久久久久 | 日韩av免费观看网站 | 成人免费视频视频在线观看 免费 | 特级西西444www大胆高清无视频 | 日韩高清免费观看 | 伊人久久电影网 | 亚洲黄色精品 | 日韩免费成人 | 日本精品中文字幕在线观看 | 日韩三级视频在线观看 | 久久在线播放 | 婷婷六月综合亚洲 | 国内精品久久久久久久 | 精品一区二区三区久久 | 不卡av电影在线观看 | 日韩欧美在线第一页 | 日韩视频免费 | 美女网色 | 人人舔人人爱 | 五月婷婷丁香在线观看 | 2019精品手机国产品在线 | 久久网站最新地址 | 国产成人av免费在线观看 | 亚洲自拍偷拍色图 | 国产一在线精品一区在线观看 | 日韩69视频 | 久草在线视频网 | av成人免费在线看 | 国产精品短视频 | 精品一区欧美 | 成人手机在线视频 | 激情五月激情综合网 | 91麻豆免费看 | 日本精a在线观看 | 国产五月天婷婷 | 久久久资源 | www.com久久| 国产精品18久久久久久久 | 国产伦精品一区二区三区照片91 | 日日色综合 | 亚洲精品乱码久久久久久蜜桃动漫 | 国产精品久久9 | 黄色片网站av | 国产中文字幕视频在线观看 | 亚洲日b视频 | av在线进入 | 欧美91av| 日韩网站免费观看 | a级片网站 | 狠狠狠色丁香综合久久天下网 | 国产免费美女 | 免费网站看v片在线a | 久久综合久久综合九色 | 一级黄色免费网站 | 特级a毛片 | 天天色天天操天天爽 | 国产视频一 | 亚洲高清在线 | 丁香花在线视频观看免费 | www国产在线 | 成人久久久电影 | 欧美一级淫片videoshd | 久久久精华网 | 中文字幕乱码一区二区 | 91mv.cool在线观看 | 国产精品视频久久久 | 一级成人网 | 成人 亚洲 欧美 | 91精品一区国产高清在线gif | 91丨porny丨九色 | 久草在线中文888 | 欧美日韩p片| 黄色app网站在线观看 | 伊人中文字幕在线 | 在线观看av免费观看 | 九九热精品视频在线播放 | 久久激情视频网 | 国产精品久久久久久久久久久久久 | 日日躁你夜夜躁你av蜜 | 国产精品密入口果冻 | 亚洲午夜精品电影 | 色网av | 婷婷中文在线 | 黄av免费| 蜜桃视频成人在线观看 | av成人亚洲 | 91精品视频免费在线观看 | av专区在线| 久久久久久久久综合 | 2019中文字幕第一页 | 久久综合中文色婷婷 | 中文字幕一区二区三区乱码不卡 | 国产精品激情在线观看 | 一性一交视频 | 最近日韩免费视频 | 日本黄色免费大片 | 国产香蕉视频 | 激情小说久久 | 天天操人人要 | a视频在线 | 热re99久久精品国产66热 | 福利一区在线视频 | 中文字幕欧美激情 | 国产 精品 资源 | 日本中文字幕在线 | www.av在线.com| 欧美性久久久久久 | 四虎影视www | 黄色的网站在线 | 免费成人av在线 | 中文字幕在线观看1 | 91在线永久| 国产美女视频一区 | 97超碰人人爱 | 激情深爱 | 日韩精品视频免费 | 夜夜高潮夜夜爽国产伦精品 | 啪啪免费观看网站 | 日韩深夜在线观看 | 中文区中文字幕免费看 | 1024手机看片国产 | 亚洲国产精久久久久久久 | 精品视频99| 在线蜜桃视频 | 九九天堂 | 天天综合区| 国产1级毛片 | 国产 色| 国产特黄色片 | aaa免费毛片 | 日韩久久午夜一级啪啪 | 久久欧美在线电影 | 中文字幕av在线不卡 | 久久9精品| 免费日韩 精品中文字幕视频在线 | 欧美一级欧美一级 | 亚洲国产精品一区二区尤物区 | 2023亚洲精品国偷拍自产在线 | 91天天操 | 99热官网 | 午夜精品一区二区三区免费视频 | 国产精品男女啪啪 | 久久黄色网页 | 91麻豆精品国产自产 | 丁香五香天综合情 | 日日噜噜噜噜夜夜爽亚洲精品 | 国产剧情一区二区在线观看 | 日韩在线欧美在线 | 久久免费视频播放 | bayu135国产精品视频 | 国产精品夜夜夜一区二区三区尤 | 久久精品国产精品亚洲 | av女优中文字幕在线观看 | 日韩1页| 夜夜躁天天躁很躁波 | 午夜精品一区二区三区四区 | 久草在线最新免费 | av福利在线免费观看 | 在线免费观看黄 | 91av蜜桃 | 最近最新中文字幕视频 | 激情文学丁香 | av黄色亚洲 | 91视频最新网址 | 成人av在线影视 | 欧美日韩国产区 | 狠狠干夜夜操天天爽 | 人人搞人人搞 | 婷婷色在线播放 | 国模精品一区二区三区 | 久久精品综合网 | 开心色婷婷| 天天操天天操天天操天天操天天操 | 成人av影院在线观看 | 激情中文在线 | 黄色大片av| 久久久精品欧美 | 国产人成一区二区三区影院 | 日本精品视频一区 | 天天色图 | 精一区二区 | 一区二三国产 | 在线av资源 | 国产中文在线播放 | 国产一区二区视频在线播放 | japanesefreesex中国少妇 | 激情在线网址 | 亚洲欧美婷婷六月色综合 | 国产成人av免费在线观看 | 少妇自拍av | 久久夜视频 | 婷婷国产一区二区三区 | 欧美精品久久久久a | 欧美天天综合 | 国产一级a毛片视频爆浆 | 91一区啪爱嗯打偷拍欧美 | 91香蕉视频在线下载 | 亚洲精品视频一二三 | 精品视频免费 | 国产 日韩 在线 亚洲 字幕 中文 | 色综合天天在线 | 四虎www com | av成人免费在线看 | 久久精品电影 | 日韩精品影视 | 成人午夜影院在线观看 | 欧美日韩视频观看 | 中文字幕在线视频免费播放 | 中文字幕av专区 | www色网站 | 久久这里只有精品视频首页 | 黄色成人av | 国产福利在线 | 国产日产精品一区二区三区四区 | 欧美视频99| 91成人精品一区在线播放69 | 国产一区二区午夜 | 日韩一级片大全 | www色网站| 日本久热 | 2023亚洲精品国偷拍自产在线 | 免费观看黄 | 日韩99热| 亚洲a色| 夜夜视频资源 | 欧美成人精品在线 | 免费国产在线精品 | 人人看人人草 | 99久久婷婷国产综合亚洲 | 免费在线国产 | 久草在线官网 | 欧美 激情 国产 91 在线 | 精品久久久一区二区 | 午夜久久影院 | 91日韩精品视频 | 日韩色高清 | 97在线观看免费观看高清 | 四虎海外影库www4hu | 成人精品影视 | 中文字幕一区二区三区精华液 | 国产123av| 91大神免费在线观看 | 久久黄色片子 | 成年人在线电影 | 99久久99视频只有精品 | 久久午夜国产 | 国内精品久久久久久久久久清纯 | 成人综合免费 | 在线看片中文字幕 | 亚洲最大的av网站 | 久久精品一区二区三区中文字幕 | 亚洲视频在线观看免费 | 免费观看黄 | 日韩影视在线观看 | 成人在线免费观看网站 | 久久国产亚洲视频 | 99热在| 91天堂在线观看 | 日本99热 | 久久久久久久久久久久久久电影 | 一区二区三区久久精品 | 国产毛片在线 | 中文字幕一区二区三区四区 | 一本一本久久a久久精品综合 | 日韩免费一区二区 | 91久久久久久久一区二区 | 人人爽人人搞 | 中文字幕在线一区二区三区 | 国产精品综合在线观看 | 在线观看亚洲精品视频 | 日日夜日日干 | 亚洲第一久久久 | 五月婷婷丁香网 | 2023亚洲精品国偷拍自产在线 | 日本高清xxxx | 亚洲一级片 | 91在线看网站 | 久久综合九色综合久99 | 欧美日韩国内在线 | 欧美精品v国产精品 | 激情视频综合网 | 天天操天天干天天操天天干 | 成全在线视频免费观看 | 日韩中文字 | 91av小视频 | 国产一区二区高清视频 | 亚洲视频h | 欧美国产高清 | 日本久久高清视频 | 国产激情电影综合在线看 | 日本中文字幕在线播放 | 久久久免费 | 97超碰人人澡 | 国产精品久久久久久久久久久免费看 | 美女久久视频 | 久久久久久久久久影视 | av不卡在线看 | 日韩欧美69| 国产探花视频在线播放 | 亚洲aⅴ一区二区三区 | 在线观看黄色国产 | 日韩久久久久久久久 | 久久图 | 国产成人一区二区三区免费看 | 深夜福利视频一区二区 | 亚洲六月丁香色婷婷综合久久 | 国产91对白在线 | 人人插超碰 | 99精彩视频在线观看免费 | 午夜精品久久一牛影视 | 国产亚洲视频中文字幕视频 | 免费 在线 中文 日本 | 欧美日韩久久 | 国产在线欧美在线 | 日日日干 | 一区二区三区四区免费视频 | 丁香av | 96久久久 | 日韩精品不卡在线观看 | 亚洲一区在线看 | 超碰人人舔| 黄p网站在线观看 | 黄网站a| 国产亚洲精品久久久久久 | 国产69精品久久久久久久久久 | 在线观看成人福利 | 狠狠色狠狠色 | 欧美日韩国产精品一区二区三区 | 午夜视频不卡 | 亚洲播放一区 | 欧美男女爱爱视频 | 国产成人一区二区三区免费看 | 国产高清视频免费最新在线 | www免费看 | 日操干| 91在线永久| 久久96国产精品久久99软件 | 日韩在线高清视频 | 国产婷婷视频在线 | 日韩三级在线 | 激情丁香久久 | 欧美人交a欧美精品 | 色综合夜色一区 | 伊人影院99| 天天躁天天躁天天躁婷 | 深爱激情五月网 | 国产精品久久久毛片 | 国产日本在线观看 | bbbbb女女女女女bbbbb国产 | 日韩高清成人 | 啪啪肉肉污av国网站 | www毛片com| 色婷婷免费| 亚洲电影第一页av | 欧美日韩精品在线观看视频 | 亚洲精品 在线视频 | 狠狠久久婷婷 | 亚洲国产欧洲综合997久久, | 国产日韩精品一区二区在线观看播放 | 亚洲一区二区高潮无套美女 | 久久久高清一区二区三区 | 精品国产成人在线 | 亚洲人成在线电影 | 一区 在线 影院 | 久久色在线播放 | 亚州精品国产 | 国产免费成人 | 狠狠狠色丁香综合久久天下网 | 久热久草在线 | 国内精品久久久久久久久久久久 | 国产精品美女久久久久久久 | 国产成人精品一区二区在线 | 在线电影 一区 | 久操操| 99精品在线视频播放 | 欧美另类高潮 | 人人爽久久久噜噜噜电影 | 国产最顶级的黄色片在线免费观看 | 玖玖精品在线 | 欧美日韩不卡一区 | 国产成人在线一区 | 亚洲欧美国产精品va在线观看 | 午夜视频在线观看一区二区三区 | 九九热re | 视频精品一区二区三区 | 日本三级全黄少妇三2023 | 国产精品美乳一区二区免费 | 国产香蕉视频 | 久久这里只有精品9 | 中文在线免费看视频 | 香蕉蜜桃视频 | 亚洲精品456在线播放乱码 | 久久久成人精品 | 久久久久国产成人精品亚洲午夜 | 久久狠狠婷婷 | 97超碰伊人| 涩涩网站在线看 | 51精品国自产在线 | 国产一区二区三区免费观看视频 | 久久久九色精品国产一区二区三区 | 日p视频在线观看 | 久草色在线观看 | 精品9999 | 深爱婷婷久久综合 | 911国产在线观看 | 看全黄大色黄大片 | 中文字幕在线观看免费观看 | 欧美一级片在线免费观看 | 国产区在线 | 久久国产精品99久久久久久进口 | 久久国产精品一国产精品 | 国产成人无码AⅤ片在线观 日韩av不卡在线 | 国产精品久久久久久久久久久久 | 亚洲电影黄色 | 国产精品久久久久一区二区三区共 | 天天爽夜夜爽人人爽一区二区 | 国产又粗又猛又色 | 中文在线8新资源库 | 91chinesexxx| 97视频网址 | 免费毛片aaaaaa | 手机在线日韩视频 | 亚洲国产免费网站 | 男女全黄一级一级高潮免费看 | 亚洲国产丝袜在线观看 | 国产精品video | 日韩网站在线播放 | 2020天天干天天操 | 超碰免费久久 | 一级片免费观看视频 | 国产最新在线视频 | 美女啪啪图片 | 欧美一性一交一乱 | www在线免费观看 | 欧美精品在线观看 | 国产精品99久久久久人中文网介绍 | 亚洲午夜av | 国产白浆视频 | 国产成人l区 | 日韩精品一卡 | 操操操av| 成人免费在线视频观看 | 成人黄色大片 | 日韩一级电影网站 | 天天干天天射天天插 | 久久情爱 | 免费在线观看毛片网站 | 久草a在线 | av中文电影 | 亚洲精品自拍 | 日韩欧美精品一区二区 | 国产精品9区 | 日韩精品一区二区三区在线播放 | 亚洲精品一区中文字幕乱码 | 久草在线免费在线观看 | 91超碰在线播放 | 日韩在线观看网站 | 91精品一区二区三区久久久久久 | 成人国产精品久久久久久亚洲 | 天天爱天天操 | 久久视频在线观看免费 | 亚洲一区二区高潮无套美女 | 91在线观看视频网站 | 国产精品精品国产婷婷这里av | 中文超碰字幕 | 91精品视频一区 | 国产成人精品一区二区三区福利 | 五月天婷婷视频 | 午夜视频播放 | 久久综合色一综合色88 | 亚洲免费不卡 | 中文字幕中文 | 久久综合亚洲鲁鲁五月久久 | 在线观看国产www | 欧美久久久久久久久久 | 丁香花中文字幕 | 日韩欧美一区视频 | 欧美精品久久99 | av在线电影网站 | 久久99精品视频 | 久久高视频| 亚洲国产成人av网 | 尤物97国产精品久久精品国产 | 在线免费观看黄色 | 在线观看中文av | 久久人人爽 | 看av在线 | 亚洲精品在线一区二区三区 | 91毛片在线观看 | 午夜视频一区二区三区 | 久久中文欧美 | 在线免费黄网站 | 亚洲精品视频在线观看视频 | 五月天视频网站 | 亚洲精品在线免费播放 | 欧美激情精品久久久久久变态 | 久久国色夜色精品国产 | 国产精品欧美一区二区三区不卡 | 亚洲欧洲国产精品 | 日韩精品五月天 | 日韩电影中文字幕 | 久草在线在线视频 | 国产精品3 | 天天躁日日躁狠狠躁 | 欧美一级大片在线观看 | 91在线看网站 | 国产午夜亚洲精品 | 欧美精品免费在线 | 97av色 | 国产精品第二页 | 在线观看涩涩 | 色综合激情久久 | 久久九九网站 | 国产精品6 | 在线观看av免费观看 | 婷婷中文字幕综合 | 激情五月网站 | 色多多污污在线观看 | 精品久久久久久亚洲综合网站 | 国产一二区免费视频 | 久久综合色一综合色88 | 亚洲禁18久人片 | 中文字幕成人在线观看 | 久久手机免费观看 | 五月激情综合婷婷 | 婷婷爱五月天 | 米奇狠狠狠888 | 久久一区二区三区日韩 | 国产黄视频在线观看 | 亚洲精品在线观看网站 | 欧美日韩在线第一页 | 久久草网站 | 色999视频| 国产成人精品国内自产拍免费看 | 久久国产品| 精品国内自产拍在线观看视频 | 91福利免费 | 狠狠躁天天躁综合网 | 国产视频二 | 久久综合中文字幕 | 91av视频免费在线观看 | 色婷婷视频在线观看 | 人人要人人澡人人爽人人dvd | 欧美激情视频一二三区 | 在线观看一级 | 久久精品欧美日韩精品 | 亚洲三级在线免费观看 | 天天色图 | 色网站免费在线看 | 超碰人人99 | 中文字幕免费不卡视频 | 樱空桃av| 国产精品国产毛片 | 亚洲精品啊啊啊 | 精品国产一区二区三区免费 | 国产 欧美 日产久久 | 久久免费精彩视频 | 久久av一区二区三区亚洲 | 亚洲三级黄| 中文字幕乱码亚洲精品一区 | 456成人精品影院 | 欧美精品久久久久久久久老牛影院 | 国产成人精品三级 | 一区二区欧美激情 | 日韩电影中文,亚洲精品乱码 | 伊人天天狠天天添日日拍 | 欧美精品在线观看免费 | 久久激情五月婷婷 | 亚洲最大的av网站 |