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

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

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

發(fā)布時(shí)間:2025/3/21 编程问答 39 豆豆
生活随笔 收集整理的這篇文章主要介紹了 分类器是如何做检测的?(1)——CascadeClassifier中的detectMultiScale函数解读 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

在進(jìn)入detectMultiScal函數(shù)之前,首先需要對CascadeClassifier做初始化。

1.???? 初始化——read函數(shù)

CascadeClassifier的初始化很簡單:

cv::CascadeClassifier classifier;

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

?

CascadeClassifier類中既有l(wèi)oad也有read函數(shù),二者是相同的,load將引用read函數(shù)。

1.1?? xml的結(jié)構(gòu)

訓(xùn)練得到的分類器以xml形式保存,整體上它包括stageType、featureType、height、width、stageParams、featureParams、stages、features幾個(gè)節(jié)點(diǎn)。


圖1. 分類器的Xml文件整體結(jié)構(gòu)

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

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


圖2. 分類器的Xml文件具體結(jié)構(gòu)

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


圖3. features的具體結(jié)構(gòu)

1.2?? read的過程

下面是read代碼,主要包括從xml中獲取兩部分內(nèi)容: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的讀取中同樣可以分為兩部分:分類器參數(shù)讀取和stage分類樹的建立。

首先是參數(shù)部分的獲取。

static?constfloatTHRESHOLD_EPS= 1e-5f;

?

// load stage params

// stageTypeBOOST類型

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

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

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

????else

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

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

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

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

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

?

// load feature params

//?載入特征參數(shù),HOG分類器下包括兩個(gè)參數(shù):maxCatCountfeatSizefeatSize很透明,就是特征的種類數(shù),這里為36,是指每個(gè)block4個(gè)cell、每個(gè)cell9個(gè)梯度方向的直方圖。例如特征號為3時(shí),計(jì)算的是當(dāng)前窗口中劃分為4個(gè)cell后第一個(gè)cell中所有點(diǎn)在120°方向(可能是,這要視起始角度而定)上分量的和,然后經(jīng)過歸一化后的值。對于第二個(gè)參數(shù)maxCatCount,這里為0,尚不清楚(這是指代表一個(gè)弱分類器的樹的類別數(shù)量,用來計(jì)算一棵樹的節(jié)點(diǎn)大小也就是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 );

至此分類器參數(shù)讀取完畢。

?

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

// load stages

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

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

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

?

????stages.reserve(fn.size());//stages包含15個(gè)節(jié)點(diǎn),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結(jié)構(gòu)中包含thresholdntreesfirst三個(gè)變量

????????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();//ntreesfirst指出該stage中包含的樹的數(shù)目和起始位置

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

????????classifiers.reserve(stages[si].first?+stages[si].ntrees);//相應(yīng)地?cái)U(kuò)展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);//一個(gè)弱分類器或者說一個(gè)weak tree中只包含一個(gè)int變量,用它在classifiers中的位置和自身來指出它所包含的node個(gè)數(shù)

?

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

????????????leaves.reserve(leaves.size() +leafValues.size());//擴(kuò)展存儲nodeleavesvector結(jié)構(gòu)空間

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

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

?

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

//遍歷nodes

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

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

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

????????????????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結(jié)構(gòu)nodes

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

?

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

?

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

????????????????leaves.push_back((float)*internalNodesIter);//leaves中保存相應(yīng)每個(gè)nodeleft leafright leaf的值,因?yàn)槊總€(gè)weak tree只有一個(gè)node也就分別只有一個(gè)left leafright leaf,這些將保存在leaves

??????? }

??? }

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

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

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

首先要?jiǎng)?chuàng)建某種特征類型的特征計(jì)算器,這里支持的是Haar、LBP和HOG三種。

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

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

這里暫不提其他成員,先介紹一個(gè)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>將是計(jì)算特征的核心,并且featureEvaluator的讀入部分主要就是對這個(gè)vector變量的內(nèi)容作初始化,因此在此展示一下。

?

?featureEvaluator創(chuàng)建之后在xml中的features節(jié)點(diǎn)下開始讀入。

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

{

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

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

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

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

??? {

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

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

??? }

????return?true;

}

Feature的讀入程序:

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

{

????FileNodernode?=node[CC_RECT];//rect節(jié)點(diǎn)下包括一個(gè)矩形和一個(gè)特征類型號featComponent

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

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

????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個(gè)矩形之間的關(guān)系如下圖4所示

?

????return?true;

}


圖4. Rect數(shù)組與xml中矩形的關(guān)系

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

?

1.3?? read的結(jié)果

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

2.???? detectMultiscale函數(shù)

在load分類器之后,可以調(diào)用該函數(shù)對一幅圖像做多尺度檢測。

2.1?? 函數(shù)自身

//輸入?yún)?shù):imageMat類型的圖像

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

???????????rejectLevels—如果不符合特征的矩形,返回級聯(lián)分類器中符合的強(qiáng)分類器數(shù)

???????????levelWeights

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

???????????minNeighbors

??????????flags

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

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

???????????outputRejectLevels—是否輸出rejectLevelslevelWeights,默認(rèn)為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灰度級且當(dāng)前縮放因子大于1

?

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

????????return;

?

????if(?isOldFormatCascade() )//這里是指haarTraining得到的分類器或者老版本的OpenCV,我不確定,但是這里可以跳過,因?yàn)橛?xùn)練與檢測所使用的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的應(yīng)用尚不清楚

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

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

??? }

?

?

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

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

?

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

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

??? {

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

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

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

??? }

?

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

????vector<Rect>candidates;//每個(gè)尺度下的圖像的檢測結(jié)果裝在該vector

?

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

??? {

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

?

????????SizewindowSize(cvRound(originalWindowSize.width*factor),cvRound(originalWindowSize.height*factor) );//當(dāng)前檢測窗口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?);//將灰度圖resizescaledImage中,size為當(dāng)前尺度下的縮放圖像

?

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

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

??????? {

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

??????? }

????????else

??????? {

????????????yStep=?factor?> 2. ? 1 : 2;//當(dāng)縮放比例比較大時(shí),滑動步長減小

??????? }

?

????????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());//將每個(gè)尺度下的檢測結(jié)果copy到輸出vector

?

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

??? {

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

??? }

????else

??? {

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

??? }

}

?

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

2.2??detectSingleScale函數(shù)

//函數(shù)參數(shù)設(shè)置可以參見detectMultiScale函數(shù)

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函數(shù)為特征計(jì)算做準(zhǔn)備,

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

?

????Mat?currentMask;

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

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

??? }//仍然不解mask的應(yīng)用,好像沒用到?

?

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

????vector<int>rejectLevels;

????vector<double>levelWeights;

????if(?outputRejectLevels?)//這里選擇的默認(rèn)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));//這里是檢測過程中的關(guān)鍵,使用parallel_for是為了TBB加速中使用,生成stripCount個(gè)平行線程(每個(gè)線程生成一個(gè)CascadeClassifierInvoker),在每個(gè)CascadeClassifierInvoker中對當(dāng)前圖像做一次檢測,這是TBB利用多線程做的加速計(jì)算

??? }

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

?

????return?true;

}

2.2.1?????????featureEvaluators的setImage函數(shù)

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

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個(gè),所以統(tǒng)計(jì)得到的Mat個(gè)數(shù)應(yīng)當(dāng)為9個(gè)

??? {

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

??? }

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

?

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

?

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

//遍歷更新特征池中每個(gè)特征的HOG特征計(jì)算所需要的矩形四個(gè)頂點(diǎn)上對應(yīng)積分圖的指針

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

??? {

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

??? }

????return?true;

}

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

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

{

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

????int?cellIdx?=?featComponent/?BIN_NUM;//計(jì)算要更新的cell是哪一個(gè)

????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);//更新四個(gè)直方積分圖中的指針

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

}

2.2.2?????????CascadeClassifierInvoker類的實(shí)例化

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

void?operator()(constBlockedRange&range)const

??? {

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

?

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

?

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

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

????????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);//在當(dāng)前點(diǎn)提取每個(gè)stage中的特征并檢驗(yàn)是否滿足分類器,result是通過的stage個(gè)數(shù)的相反數(shù),如果全部通過則為1

????????????????if(rejectLevels?)//默認(rèn)為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 )//保存當(dāng)前的窗口

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

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

??????? ??}

? }

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

?

template<classFEval>

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

{

????int?nodeOfs?= 0,?leafOfs= 0;//nodeleaf的整體序號

????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];//遍歷每個(gè)stage

????????sum= 0.0;//stage中的葉節(jié)點(diǎn)的和

?

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

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

??????? {

????????????CascadeClassifier::Data::DTreeNode&node?=cascadeNodes[nodeOfs];//獲取當(dāng)前stage的各個(gè)node

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

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

??????? }

?

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

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

??? }

????return?1;

}

Feature中的calc很簡單,因?yàn)榍懊嬉呀?jīng)更新了四個(gè)對應(yīng)于矩形頂點(diǎn)處積分圖的指針已經(jīng)被更新,歸一圖中的指針也已經(jīng)被更新。

這里表達(dá)的計(jì)算如下圖所示:


圖5. 積分圖計(jì)算示意

要計(jì)算D中的值,在積分圖中四個(gè)頂點(diǎn)的指針?biāo)赶虻膬?nèi)容分別為A,A+B,A+C和A+B+C+D。因此中間兩項(xiàng)與其余兩項(xiàng)的差就是要求的D區(qū)域了。其中的offset變量是根據(jù)滑動窗口的位置確定的,代表上圖中D矩形的左上頂點(diǎn)在全圖中的位置。程序如下:

首先由如下定義

#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函數(shù)

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;

}


總結(jié)

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

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

久久99久久99精品免视看婷婷 | 国产亚洲视频中文字幕视频 | 日韩欧美综合视频 | 高清不卡一区二区三区 | 波多野结衣一区二区三区中文字幕 | 五月综合激情 | 久久人人爽人人爽人人 | 国产精品视频999 | 成年人网站免费观看 | 日本午夜免费福利视频 | 天天超碰 | 亚洲精品久久久久久国 | 激情视频在线观看网址 | 正在播放 久久 | 久久成人高清 | 国产日韩精品在线观看 | 久久人人97超碰国产公开结果 | 成人在线播放av | 成人avav | 97超碰国产精品 | 在线观看中文字幕一区二区 | 性日韩欧美在线视频 | 午夜精选视频 | 日日夜夜狠狠操 | 国产精品99久久久久久有的能看 | 婷香五月 | 日本精品一区二区三区在线播放视频 | 久久精品香蕉视频 | 色在线免费观看 | 久要激情网 | 久精品视频在线 | 91精品国产麻豆国产自产影视 | 777xxx欧美| 干狠狠| 97**国产露脸精品国产 | 伊人天天综合 | 中文字幕在线看视频国产 | 97精品国产aⅴ | 人人添人人澡人人澡人人人爽 | 一级黄色在线免费观看 | 久久国产乱 | 久久影视中文字幕 | 一区二区三区电影大全 | 天天综合区 | 日韩r级电影在线观看 | 在线91观看 | 中文字幕日本电影 | 中文字幕电影网 | 久久久久国产精品免费免费搜索 | 91资源在线播放 | 人人爽人人av | 日韩羞羞 | 81国产精品久久久久久久久久 | 在线免费观看国产黄色 | 波多野结衣一区 | 久久国产精品久久国产精品 | 韩国精品福利一区二区三区 | 国产无吗一区二区三区在线欢 | 国产精品大全 | 在线看片a | 99久热在线精品视频成人一区 | 国产在线精品一区二区三区 | 欧美va在线观看 | 精品久久久久久久久久久久久久久久 | 国内小视频在线观看 | 久久草在线视频国产 | 精品国产1区二区 | 国产福利在线 | 91视频中文字幕 | 天天干夜夜夜 | 97超碰在线久草超碰在线观看 | 日本激情中文字幕 | 免费观看91视频 | 欧美a级片网站 | av黄在线播放 | 毛片网站观看 | 日韩一级片观看 | 国内偷拍精品视频 | 69久久99精品久久久久婷婷 | 久久中文字幕视频 | 亚洲国产丝袜在线观看 | 久久久久久久久久亚洲精品 | 久久久久99精品国产片 | 四虎免费在线观看视频 | 成人国产精品久久久久久亚洲 | 天天艹日日干 | 97视频免费在线看 | 久久超级碰 | 欧美日韩免费一区二区 | 8x成人在线 | 色综合小说 | 日本三级久久 | 最近中文字幕免费大全 | 福利视频一区二区 | 主播av在线 | 天堂久色 | 狠狠干干 | 成人免费xyz网站 | 欧美激情精品久久 | 欧美性色综合 | 美国三级黄色大片 | 欧美天堂久久 | 日韩亚洲在线视频 | 手机在线看片日韩 | 免费观看完整版无人区 | 久久人人精品 | 久久久一本精品99久久精品 | 亚洲va欧美va国产va黑人 | 国产精品成久久久久 | 亚洲人av免费网站 | 国产在线不卡 | 99热国内精品 | 狠狠操欧美 | 天天综合精品 | 天天干天天插 | 婷婷丁香色综合狠狠色 | 伊人天天色 | 精品a级片 | 国产一区二区午夜 | 久久 亚洲视频 | 亚洲一区黄色 | 五月天,com | 欧美日韩一区二区在线观看 | 99视频精品免费观看, | 天天操天天操天天操天天操天天操天天操 | 国产不卡免费视频 | 国产人免费人成免费视频 | 国产高清视频在线播放 | 久久成人精品视频 | 日韩激情在线 | 最近中文国产在线视频 | 99久久久久久久久 | 不卡的av在线播放 | 久久综合射 | 国产一级电影网 | 麻豆国产精品一区二区三区 | 久久久综合色 | 国产精品一区二区三区99 | 永久黄网站色视频免费观看w | 中文字幕在线视频国产 | 欧美成人xxxxx | 成人av动漫在线 | 成人久久电影 | 蜜臀久久99精品久久久酒店新书 | 精品成人a区在线观看 | 国产成人一级 | 91在线视频免费 | 欧美资源 | 天天摸夜夜添 | 日韩视频一区二区三区在线播放免费观看 | 国产精品专区h在线观看 | 日韩在线观看你懂得 | 亚洲成人av片 | 久福利 | 国产视频一区在线 | 久久久精品国产免费观看一区二区 | 色 免费观看 | 91亚色视频在线观看 | 亚洲四虎| 伊人色综合久久天天网 | 国产探花 | 亚洲一二视频 | 999国内精品永久免费视频 | 国产永久免费高清在线观看视频 | 亚洲一区二区天堂 | 激情五月婷婷丁香 | 91精品国产91久久久久久三级 | 国产精品都在这里 | 中文字幕免费成人 | 久久99精品国产一区二区三区 | 国产又粗又硬又长又爽的视频 | 久草在线高清视频 | 超碰人人在线 | 色吊丝在线永久观看最新版本 | 成人网看片 | 91av在线电影| 久久视频精品在线 | 亚洲国产视频a | 亚洲日本精品视频 | 天天射天| 免费男女羞羞的视频网站中文字幕 | www..com黄色片| 成人欧美亚洲 | 国产成人精品午夜在线播放 | 欧美一区二区日韩一区二区 | 在线观看亚洲成人 | 看av免费 | 激情在线五月天 | 狠狠狠干狠狠 | 欧洲视频一区 | 久久久精品一区二区三区 | av三区在线 | 在线播放日韩av | 亚洲综合激情 | 成人欧美在线 | 三级毛片视频 | 国产小视频你懂的在线 | 精品在线观看免费 | www黄在线 | 福利av影院 | 免费一级片视频 | 2020天天干天天操 | 日日夜夜天天 | 一区二精品 | 美女网站在线看 | 亚洲在线精品视频 | 日韩在线免费 | 麻豆影视在线播放 | www操操 | 色婷婷电影 | 国产精品久久久久一区二区 | 亚洲国产伊人 | 波多野结衣资源 | 欧美精品免费在线观看 | 久久久久国产一区二区 | 亚洲精品一区中文字幕乱码 | 最近中文字幕免费观看 | 久久久久久高清 | aaa日本高清在线播放免费观看 | 日本久久免费视频 | 国产 色 | 四月婷婷在线观看 | 亚洲日本三级 | 中文字幕在线观看网站 | 欧美人交a欧美精品 | 成 人 黄 色 片 在线播放 | 久久国产精品二国产精品中国洋人 | 国产最新在线 | 日韩视频一区二区三区在线播放免费观看 | 国产精品一区二区在线播放 | 在线视频观看你懂的 | 亚洲精品在线一区二区 | 97电影手机| 久久国产美女视频 | 久久综合色播五月 | 亚洲午夜久久久综合37日本 | 久热免费在线 | 91九色在线播放 | 99精品在线观看 | 欧美久久精品 | 天天色图 | 国产亲近乱来精品 | 最近最新中文字幕 | 久久国产精品免费一区 | 久久九九久久 | 黄av资源 | 天天色婷婷 | av免费在线看网站 | 成人高清在线观看 | 久久成人午夜视频 | 国产精品女主播一区二区三区 | www.五月天婷婷 | 婷婷丁香导航 | 91刺激视频 | 在线播放视频一区 | 中文字幕字幕中文 | 欧美一区二视频在线免费观看 | 国产精品自产拍在线观看网站 | 日日爱av| 中文字幕日韩免费视频 | 久久久久久久久久久网站 | 日本精品一区二区三区在线播放视频 | 国产又粗又猛又黄视频 | 免费在线观看视频一区 | 韩国av在线 | 狠狠色丁香久久婷婷综合五月 | 私人av| 丝袜美女在线观看 | 丁香六月天 | 免费黄色特级片 | 悠悠av资源片 | 亚洲免费一级电影 | 黄色在线小网站 | 91高清完整版在线观看 | 亚洲,播放 | 亚洲免费在线播放视频 | 亚洲观看黄色网 | 色婷婷成人网 | 日韩精品久久一区二区 | 国产精品久久久久久久久久 | 欧美日韩精品在线观看视频 | 亚洲成人一区 | 成年人电影毛片 | 国产精品theporn | 中文一区在线观看 | 国模一区二区三区四区 | 国产精品久久伊人 | 国产不卡高清 | 亚洲综合少妇 | 国产精选在线 | av线上看| 99精品国产免费久久久久久下载 | 99久热在线精品视频成人一区 | 日韩精品一区二区免费 | 中文字幕a∨在线乱码免费看 | 欧美亚洲精品在线观看 | 97视频在线观看免费 | 亚州精品国产 | 国产精品午夜在线观看 | 大型av综合网站 | 久久久久亚洲精品男人的天堂 | 国产精品久久久久久久久久 | 中文国产字幕在线观看 | 免费看黄在线观看 | 91成人免费观看视频 | 狠狠色丁香婷婷综合 | 成人小视频免费在线观看 | 成人高清av在线 | 狠狠操电影网 | 97免费在线观看视频 | 亚洲va欧美va人人爽春色影视 | 国产又粗又猛又黄又爽视频 | 成年人在线看视频 | 五月婷婷免费 | 日本高清中文字幕有码在线 | 精品国产亚洲日本 | 手机版av在线 | 91 中文字幕 | 中文免费观看 | 国产精品黄网站在线观看 | 美女黄色网在线播放 | 久久精品亚洲综合专区 | 四虎永久精品在线 | 最近免费中文字幕 | 国产精品视频地址 | 97精品国产91久久久久久 | 天天干天天玩天天操 | 欧洲高潮三级做爰 | 成人久久久电影 | 亚洲色图 校园春色 | 国产91丝袜在线播放动漫 | 天天拍天天爽 | 色综合天天天天做夜夜夜夜做 | 看黄色.com| 日本中文字幕在线观看 | 天天操天天色天天射 | 国产高清视频网 | 成年人网站免费观看 | 成人av网站在线 | 麻豆视频国产精品 | 三级黄色免费 | 久久久久伊人 | 成人久久久久久久久久 | 国产成人免费高清 | 成年人视频免费在线 | 成人播放器 | 久久精品99北条麻妃 | 婷婷精品 | 久久婷婷色 | 青青色影院 | 在线导航av| 日日色综合 | 激情av资源 | 欧美精品中文 | 成人免费视频网站在线观看 | 黄色亚洲在线 | 亚洲禁18久人片 | 99精品偷拍视频一区二区三区 | 欧美在线一二区 | 97精品国产97久久久久久久久久久久 | 久久系列| 国产99久久久欧美黑人 | 色综合天天综合网国产成人网 | 黄色大全在线观看 | 日韩女同av | 中文字幕一区二区三区四区久久 | 欧美一区二视频在线免费观看 | 九色91在线 | 久久九九精品久久 | 人人爽人人爽人人爽学生一级 | 久久综合导航 | 一级免费av| 人人看看人人 | 在线中文字幕电影 | 久久字幕精品一区 | 狠狠色丁香婷综合久久 | 97精品超碰一区二区三区 | 狠狠色丁香婷婷综合橹88 | 欧美一级视频免费 | 久久久国产影视 | 一级黄色电影网站 | 热久久免费视频 | 亚洲夜夜综合 | 成人av亚洲 | 91久久久久久久一区二区 | 亚洲国产一二三 | 欧美极品少妇xbxb性爽爽视频 | 国产91精品一区二区麻豆网站 | 我要色综合天天 | 综合色婷婷 | 午夜.dj高清免费观看视频 | 久久高视频 | 天天色中文 | 亚洲天堂网在线观看视频 | 国产电影一区二区三区四区 | 久久黄色小说 | 国产91学生粉嫩喷水 | 精品久久1 | 中文字幕高清有码 | 午夜久久久久久久久久影院 | 亚洲片在线 | 亚洲精品乱码久久久久久久久久 | 久久久视屏 | 午夜精品福利影院 | 久久久久北条麻妃免费看 | 亚洲午夜精品在线观看 | 色婷婷久久久 | 亚洲在线网址 | www178ccom视频在线 | 麻豆免费在线播放 | 99视频精品全部免费 在线 | 99久久精品久久久久久清纯 | 日韩精品一区二区三区在线视频 | 日韩在线国产精品 | 久草电影网| 69国产在线观看 | 日韩在线中文字幕视频 | 免费a现在观看 | 在线视频久久 | 久久精品九色 | 六月色丁香 | 国产精品一区二区在线观看免费 | 亚洲a网| 欧美a级成人淫片免费看 | 一区二区伦理电影 | 国产日韩中文字幕在线 | 成人av亚洲| 亚洲国产精品成人女人久久 | 国产精品久久久久9999 | 亚洲专区 国产精品 | 婷婷色婷婷 | 香蕉影院在线 | 国产一级片不卡 | 一级a毛片高清视频 | 国产午夜精品一区二区三区四区 | 激情久久婷婷 | 黄色av电影在线观看 | 亚洲精品在线观看中文字幕 | 欧美肥妇free| 午夜在线免费视频 | 最新精品国产 | 亚洲成人免费在线观看 | 丁香婷婷在线观看 | 福利视频导航网址 | 中文字幕在线观看完整版 | 国产成人av一区二区三区在线观看 | 国产黄 | 久草在线免费看视频 | 99精品热视频只有精品10 | 丁香九月婷婷 | 西西www444 | 911国产 | 日本高清中文字幕有码在线 | 欧美日韩国产一区二区在线观看 | 五月婷婷婷婷婷 | 亚洲成人av电影 | 国产一区二区精品久久 | 五月婷婷久 | 波多野结衣一区二区三区中文字幕 | 日韩视频免费在线观看 | 久久成人在线视频 | 四虎5151久久欧美毛片 | 91天堂素人约啪 | 国产精品美女网站 | 激情视频一区 | 欧美日韩亚洲在线观看 | aaawww| 日韩精品一卡 | 国产精品成久久久久三级 | 国产高清视频在线播放一区 | 黄色资源在线 | 99免费在线观看 | 一区二区三区电影大全 | 色综合 久久精品 | 国产一级不卡毛片 | 免费av的网站 | 又爽又黄在线观看 | 国产成人一级 | 免费看一级特黄a大片 | 91精品999| 成人精品福利 | 国产中文a | 视频在线观看亚洲 | 亚洲国产欧美一区二区三区丁香婷 | 亚洲综合色站 | 国产一区二区久久久 | 久久人人爽人人爽人人片av免费 | 国产精品亚洲片在线播放 | 91av视频免费观看 | 国产成人精品av久久 | 婷婷四房综合激情五月 | 伊人精品影院 | 欧美日韩不卡一区二区三区 | 夜夜天天干| 日韩精品一区在线观看 | 中文字幕中文字幕在线中文字幕三区 | 国产精品一区二区在线播放 | 狠狠干干| 麻豆国产网站入口 | 国产精品久久久久久一二三四五 | 黄色app网站在线观看 | 久久成人午夜视频 | 五月婷婷综合网 | 深爱激情开心 | 成人一级片免费看 | 久久久穴 | 四虎影视成人永久免费观看亚洲欧美 | 日本精品一二区 | 久久夜色精品国产欧美一区麻豆 | 青草视频免费观看 | 在线亚洲成人 | 中文字幕在线免费97 | 正在播放国产一区 | 综合五月 | 午夜精品久久久久久久久久久久 | 午夜美女福利直播 | 天天爽网站 | 久久久久| 99riav1国产精品视频 | 免费www视频| 激情狠狠干| 色播五月激情五月 | 日本资源中文字幕在线 | 特级西西444www大精品视频免费看 | 黄色av大片 | 婷婷久久丁香 | 国产一二三四在线视频 | 亚洲国产免费 | 日日夜夜免费精品视频 | 特黄特色特刺激视频免费播放 | 永久免费在线 | 99久精品| 91精品啪在线观看国产81旧版 | 欧美性生活久久 | 婷婷五天天在线视频 | 人人草网站 | 久久一视频 | 永久免费的啪啪网站免费观看浪潮 | 丁香六月在线 | 亚洲精品资源在线 | 欧美电影在线观看 | 日韩免费专区 | 在线国产小视频 | 欧美福利网站 | 在线看91| 亚洲国产人午在线一二区 | 男女视频久久久 | 黄色aa久久 | 国产高清成人 | 91在线看黄 | 国产精品久久久久久爽爽爽 | 激情丁香在线 | av在线一级 | 成人午夜黄色影院 | 中文字幕日韩精品有码视频 | 黄www在线观看 | www.超碰97.com| 狠狠躁日日躁狂躁夜夜躁av | 成年人黄色av | 免费观看一级特黄欧美大片 | 免费福利在线观看 | 国产精品午夜在线观看 | 亚洲国产精品视频 | 美女免费网视频 | 日日操天天操夜夜操 | 亚洲天堂网在线观看视频 | 狠狠插狠狠操 | 日韩中文字幕第一页 | 一区二区视频欧美 | 尤物一区二区三区 | 人人擦 | av在线精品 | 国产精品高潮在线观看 | 欧美日韩一区二区在线观看 | 久久黄色美女 | 国产天天综合 | 日韩精品一二三 | 成人黄色片免费 | 欧美日韩在线视频一区二区 | 色永久免费视频 | 99这里只有精品99 | 在线91视频 | 最新日韩在线观看视频 | 国产黄影院色大全免费 | 97在线成人 | 天天干天天操人体 | 久久久福利影院 | 日韩v在线 | 最新不卡av | 日本不卡123区 | 日本不卡一区二区三区在线观看 | 国产美女免费视频 | 成人中文字幕+乱码+中文字幕 | 国内精品久久久久久久久久清纯 | 日日夜夜中文字幕 | 91pony九色丨交换 | 亚洲 精品在线视频 | 国产精品美女免费看 | 天天舔天天射天天操 | 999久久久精品视频 日韩高清www | 7777精品伊人久久久大香线蕉 | 成人国产一区 | av电影不卡在线 | 免费黄色小网站 | 亚洲免费av片 | 国产精品久久久久久久久久久杏吧 | 国产精品99视频 | 亚洲精品动漫久久久久 | 精品久久久99 | 国语黄色片| 国产一二三四在线视频 | 亚洲精品久久久久久久蜜桃 | 国产黄在线免费观看 | 99久久久久久久久久 | 国产小视频在线看 | 久久福利剧场 | 精品国产成人av在线免 | 91热爆在线观看 | 91热在线| 国产成人久久av977小说 | 日日爽天天爽 | 精品欧美一区二区三区久久久 | 国产不卡av在线 | 久草在线最新视频 | 久久久美女| 精品久久国产精品 | 国产精品久久婷婷六月丁香 | 欧美在线视频日韩 | 国产精彩在线视频 | 国产精品久久久久久av | 免费观看国产精品 | 国产精品欧美精品 | 综合网婷婷 | 狠狠色丁香婷婷综合最新地址 | 国产小视频你懂的 | 欧美一级片免费播放 | 成片视频在线观看 | 久草视频在线看 | 中文字幕视频网 | 高清一区二区 | 午夜视频播放 | 久草在线资源免费 | 97视频人人澡人人爽 | 中日韩欧美精彩视频 | 久久夜色精品国产欧美乱 | 91系列在线| 一本一本久久a久久精品综合小说 | 亚洲视频观看 | 国产伦精品一区二区三区高清 | 97色在线视频 | 日韩天天操 | 午夜精品成人一区二区三区 | 日韩视频一区二区在线观看 | 国产精品激情偷乱一区二区∴ | av短片在线 | 99久久99久久精品国产片 | 欧美精品在线一区二区 | 亚洲精品资源在线观看 | 欧美黑人xxxx猛性大交 | 亚洲精品一区二区精华 | 国产一级在线免费观看 | 国产欧美精品在线观看 | 伊人五月天av | 日产av在线播放 | 色多多在线观看 | 日韩欧美一区视频 | 娇妻呻吟一区二区三区 | 手机成人免费视频 | 成人福利在线 | 亚洲精品网站 | 91av在线国产 | 久热av在线 | 超碰av在线免费观看 | 国产美女久久 | 欧美一级久久久久 | 久草精品在线观看 | 天天躁天天躁天天躁婷 | 日韩av成人在线观看 | 欧美色操| av一区二区三区在线播放 | av片一区二区 | 国产精品久久久毛片 | 五月婷色| 精品女同一区二区三区在线观看 | 国产色视频123区 | 亚洲精品福利在线 | 一区二区精 | 色综合小说 | 在线看成人 | 国产高清在线精品 | 免费日韩一区二区 | 国产黄影院色大全免费 | 日韩电影在线观看一区二区三区 | av成人亚洲 | 91亚洲精品久久久久图片蜜桃 | 色播五月婷婷 | 日韩久久一区 | 久久这里只有精品视频首页 | 私人av| 五月婷婷操 | 亚洲成人精品影院 | 麻豆视频免费播放 | 久久久久免费观看 | 日日夜夜人人精品 | 国产精品日韩欧美 | 四季av综合网站 | 欧美9999| 操操综合网 | 尤物一区二区三区 | 日本特黄特色aaa大片免费 | 国产精品日韩 | 综合久久影院 | 午夜美女av| 99视频网址 | 99精品视频观看 | 亚色视频在线观看 | 中文字幕在线免费97 | 欧美一级专区免费大片 | 一级片免费观看视频 | 国产精品免费一区二区三区在线观看 | 国产精品高 | 91人人爽人人爽人人精88v | 日韩欧美网址 | 91免费国产在线观看 | 黄色软件网站在线观看 | 国产精品久久久久久一区二区 | 国产精品mm | 日韩在线观看精品 | 丝袜美腿一区 | 久日视频 | 亚洲四虎影院 | 亚洲区色| 91经典在线 | 免费人人干 | 免费看的av片 | 国产精品视频区 | 欧美日韩在线观看一区二区三区 | 亚洲婷婷综合色高清在线 | 六月丁香综合 | 欧美日韩亚洲第一 | 亚洲最新视频在线 | 在线观看免费视频你懂的 | 亚洲国产精品影院 | 91中文字幕在线 | 九九九在线观看视频 | 在线91观看 | 日韩欧美在线第一页 | 丁香国产视频 | 91精品国产高清自在线观看 | 高清中文字幕 | 最近中文字幕免费观看 | 久久999精品| 综合色站 | 亚洲精品中文字幕在线观看 | www.久久com| 国产精品久久久久毛片大屁完整版 | 久久激情视频免费观看 | 久久一及片 | japanesexxx乱女另类 | 99热超碰在线 | 国产精品色在线 | 国产精品成人一区二区 | 成年人免费在线播放 | 欧美视频二区 | 亚洲婷婷在线 | 免费精品国产va自在自线 | 久久精品日韩 | 国产美女搞久久 | 色网站免费在线观看 | 狠狠的操你 | 久久黄色免费观看 | 色噜噜在线观看 | 天天干天天搞天天射 | 五月开心六月伊人色婷婷 | 国内揄拍国产精品 | 久久99久久99免费视频 | av免费试看 | 久久精品一区二区三 | 九九久久在线看 | 国产又黄又爽又猛视频日本 | 国产精品乱码久久久 | 亚洲精品国产自产拍在线观看 | 人人玩人人爽 | 美女黄频免费 | 在线免费91 | 99精品视频免费看 | 欧美做受高潮电影o | 久久久久久久国产精品影院 | 在线观看的黄色 | 激情网站五月天 | 99爱在线观看 | 国产成人三级在线观看 | 日韩精品高清视频 | 日韩免费| 黄色毛片大全 | 久章草在线观看 | 亚洲成成品网站 | 国产在线免费 | 免费av看片| 四季av综合网站 | 四虎在线视频免费观看 | 国产一区福利在线 | 人人狠狠综合久久亚洲 | 在线观看成人av | 中文字幕最新精品 | 五月的婷婷| 中文字幕亚洲欧美日韩2019 | av视屏在线 | 免费av网址大全 | 在线99热 | 国产美女视频 | a色视频 | 在线观看视频免费播放 | 97视频资源 | 久草热视频| 91免费网 | 91探花国产综合在线精品 | 欧美视频不卡 | 婷婷久久国产 | 国产免费看| 免费观看一区二区三区视频 | 国产亚洲小视频 | 久久久精品免费观看 | 狠狠狠狠狠狠狠 | 国内99视频 | 亚洲美女免费视频 | 天天操天天爽天天干 | 色激情五月 | 久久精品人人做人人综合老师 | 亚洲精品1234区 | 99精品黄色| 中文字幕一区二区三区四区在线视频 | 麻豆国产精品永久免费视频 | av一级一片 | 男女视频国产 | 亚洲视频国产 | 亚洲伦理精品 | 97在线播放视频 | 超碰免费97| 久久精品99视频 | 中文不卡视频 | 五月婷婷综合在线观看 | 久久久国产影视 | 亚洲一区美女视频在线观看免费 | 三级黄色在线观看 | 亚洲国产精品影院 | 色噜噜在线观看 | 精精国产xxxx视频在线播放 | 综合色天天 | 一区二区三区在线电影 | 日韩小视频网站 | 色999在线 | 一区二区三区免费在线观看视频 | 91av久久 | 99精品视频观看 | 深爱婷婷网 | 麻豆传媒视频在线 | 韩国一区二区av | 欧美一区二区三区在线视频观看 | 视频一区二区视频 | 国产69精品久久久久99尤 | 成人xxxx | 精品久久久久国产免费第一页 | 欧美激情另类文学 | 国产精品99在线播放 | 国产精品99久久免费观看 | 精品美女在线观看 | 久久你懂得 | 亚洲第二色 | 天天干天天操天天搞 | 国产乱对白刺激视频在线观看女王 | 国产一区二区免费看 | 玖玖视频国产 | 久久视频国产精品免费视频在线 | 青青草在久久免费久久免费 | 免费看片日韩 | 国产中的精品av小宝探花 | 三级动图 | aaa亚洲精品一二三区 | 国产不卡一二三区 | 欧美乱大交 | 国产一区在线免费观看 | 日日日操 | 蜜桃视频精品 | 亚洲激精日韩激精欧美精品 | 国产精品免费观看久久 | 国产精品毛片一区视频播不卡 | 久草精品视频在线播放 | 国产成年免费视频 | 午夜少妇 | 国产成人免费网站 | 色免费在线 | 国内综合精品午夜久久资源 | 婷婷色中文 | 国产精品a成v人在线播放 | 国产一区二区在线播放视频 | 手机色站| 国产免费久久精品 | 高清精品久久 | 在线视频黄 | 久久精品79国产精品 | 午夜久久久精品 | 伊人天天色 | 97电影院在线观看 | 国产精品久久久久久久久免费看 | 国产精品综合在线观看 | 欧美成人性网 | 日韩 国产 | 极品国产91在线网站 | 午夜精品久久久久99热app | 色网站在线免费观看 | 欧美日性视频 | 精品久久一级片 | 国产成人精品久久二区二区 | 2019精品手机国产品在线 | 看片的网址 | 五月婷婷六月综合 | 人人舔人人 | 久久国产精品视频 | 久99久精品 | 国产视频久久久久 | 国产在线a | 九九影视理伦片 | 国产精品久久久久9999吃药 | 亚洲精品网站在线 | 最新国产在线 | 日韩99热 | 国产精品久久久久久久久久久杏吧 | 亚洲精品在线观看的 | 欧美日韩一区久久 | 国产精品18久久久久久久 | 福利在线看片 | 五月网婷婷 | 美女福利视频 | av丝袜在线 | 国产在线自| 国产精品久久三 | av中文字幕不卡 | 亚洲 综合 精品 | 爱色av.com | 亚洲狠狠 | 九九色在线观看 | 国产精品成人免费精品自在线观看 | av一级久久 | 日韩亚洲在线 | 久久香蕉电影 | 亚洲欧洲精品一区二区 | 91福利视频免费观看 | 深爱婷婷激情 | 久久精品视频日本 | 正在播放国产精品 | 在线中文字幕网站 | 国产精品日韩欧美 | 不卡av免费在线观看 | 亚洲精品综合一二三区在线观看 | 五月天激情综合网 | 香蕉视频久久 | 在线观看黄色 | 亚洲狠狠丁香婷婷综合久久久 | 欧美大荫蒂xxx | 美国av大片 | 91av社区 | 久久tv视频 | 欧美在线视频免费 | 国产精品毛片一区二区 | 亚洲综合在线五月天 | 天堂中文在线播放 | 97人人网 | 亚洲精品国产电影 | 天天射天天搞 | 五月天中文在线 | 国产中文字幕第一页 | 精品美女在线观看 | 99精品一级欧美片免费播放 | 狠狠网站 | 国产成人精品一区一区一区 | 亚洲三级在线播放 | 久久综合狠狠狠色97 | 亚洲激情视频在线观看 | 美女免费视频一区 | 麻豆传媒在线免费看 | av资源中文字幕 | 狠狠色狠狠色合久久伊人 | 嫩模bbw搡bbbb搡bbbb | 中文字幕一二 | 伊人婷婷网 | 久久久综合香蕉尹人综合网 | 亚洲精品自拍视频在线观看 | 国产精品久久久久久久久蜜臀 | 国产精品久久久久久久免费大片 | 超碰人人99 | 在线免费视频你懂的 | 五月婷婷深开心 | 日韩电影久久久 | 最新中文字幕在线资源 | av天天在线观看 | 最近中文字幕高清字幕免费mv | 国产成人一区二区在线观看 |