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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

faster rcnn学习之rpn训练全过程

發(fā)布時間:2023/12/10 编程问答 46 豆豆
生活随笔 收集整理的這篇文章主要介紹了 faster rcnn学习之rpn训练全过程 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

上篇我們講解了rpn與fast rcnn的數(shù)據(jù)準(zhǔn)備階段,接下來我們講解rpn的整個訓(xùn)練過程。最后 講解rpn訓(xùn)練完畢后rpn的生成。

我們順著stage1_rpn_train.pt的內(nèi)容講解。

name: "VGG_CNN_M_1024" layer {name: 'input-data'type: 'Python'top: 'data'top: 'im_info'top: 'gt_boxes'python_param {module: 'roi_data_layer.layer'layer: 'RoIDataLayer'param_str: "'num_classes': 21"} } layer {name: "conv1"type: "Convolution"bottom: "data"top: "conv1"param { lr_mult: 0 decay_mult: 0 }param { lr_mult: 0 decay_mult: 0 }convolution_param {num_output: 96kernel_size: 7 stride: 2} } layer {name: "relu1"type: "ReLU"bottom: "conv1"top: "conv1" } layer {name: "norm1"type: "LRN"bottom: "conv1"top: "norm1"lrn_param {local_size: 5alpha: 0.0005beta: 0.75k: 2} } layer {name: "pool1"type: "Pooling"bottom: "norm1"top: "pool1"pooling_param {pool: MAXkernel_size: 3 stride: 2} } layer {name: "conv2"type: "Convolution"bottom: "pool1"top: "conv2"param { lr_mult: 1 }param { lr_mult: 2 }convolution_param {num_output: 256pad: 1 kernel_size: 5 stride: 2} } layer {name: "relu2"type: "ReLU"bottom: "conv2"top: "conv2" } layer {name: "norm2"type: "LRN"bottom: "conv2"top: "norm2"lrn_param {local_size: 5alpha: 0.0005beta: 0.75k: 2} } layer {name: "pool2"type: "Pooling"bottom: "norm2"top: "pool2"pooling_param {pool: MAXkernel_size: 3 stride: 2} } layer {name: "conv3"type: "Convolution"bottom: "pool2"top: "conv3"param { lr_mult: 1 }param { lr_mult: 2 }convolution_param {num_output: 512pad: 1 kernel_size: 3} } layer {name: "relu3"type: "ReLU"bottom: "conv3"top: "conv3" } layer {name: "conv4"type: "Convolution"bottom: "conv3"top: "conv4"param { lr_mult: 1 }param { lr_mult: 2 }convolution_param {num_output: 512pad: 1 kernel_size: 3} } layer {name: "relu4"type: "ReLU"bottom: "conv4"top: "conv4" } layer {name: "conv5"type: "Convolution"bottom: "conv4"top: "conv5"param { lr_mult: 1 }param { lr_mult: 2 }convolution_param {num_output: 512pad: 1 kernel_size: 3} } layer {name: "relu5"type: "ReLU"bottom: "conv5"top: "conv5" }#========= RPN ============layer {name: "rpn_conv/3x3"type: "Convolution"bottom: "conv5"top: "rpn/output"param { lr_mult: 1.0 }param { lr_mult: 2.0 }convolution_param {num_output: 256kernel_size: 3 pad: 1 stride: 1weight_filler { type: "gaussian" std: 0.01 }bias_filler { type: "constant" value: 0 }} } layer {name: "rpn_relu/3x3"type: "ReLU"bottom: "rpn/output"top: "rpn/output" } layer {name: "rpn_cls_score"type: "Convolution"bottom: "rpn/output"top: "rpn_cls_score"param { lr_mult: 1.0 }param { lr_mult: 2.0 }convolution_param {num_output: 18 # 2(bg/fg) * 9(anchors)kernel_size: 1 pad: 0 stride: 1weight_filler { type: "gaussian" std: 0.01 }bias_filler { type: "constant" value: 0 }} } layer {name: "rpn_bbox_pred"type: "Convolution"bottom: "rpn/output"top: "rpn_bbox_pred"param { lr_mult: 1.0 }param { lr_mult: 2.0 }convolution_param {num_output: 36 # 4 * 9(anchors)kernel_size: 1 pad: 0 stride: 1weight_filler { type: "gaussian" std: 0.01 }bias_filler { type: "constant" value: 0 }} } layer {bottom: "rpn_cls_score"top: "rpn_cls_score_reshape"name: "rpn_cls_score_reshape"type: "Reshape"reshape_param { shape { dim: 0 dim: 2 dim: -1 dim: 0 } } } layer {name: 'rpn-data'type: 'Python'bottom: 'rpn_cls_score'bottom: 'gt_boxes'bottom: 'im_info'bottom: 'data'top: 'rpn_labels'top: 'rpn_bbox_targets'top: 'rpn_bbox_inside_weights'top: 'rpn_bbox_outside_weights'python_param {module: 'rpn.anchor_target_layer'layer: 'AnchorTargetLayer'param_str: "'feat_stride': 16"} } layer {name: "rpn_loss_cls"type: "SoftmaxWithLoss"bottom: "rpn_cls_score_reshape"bottom: "rpn_labels"propagate_down: 1propagate_down: 0top: "rpn_cls_loss"loss_weight: 1loss_param {ignore_label: -1normalize: true} } layer {name: "rpn_loss_bbox"type: "SmoothL1Loss"bottom: "rpn_bbox_pred"bottom: "rpn_bbox_targets"bottom: 'rpn_bbox_inside_weights'bottom: 'rpn_bbox_outside_weights'top: "rpn_loss_bbox"loss_weight: 1smooth_l1_loss_param { sigma: 3.0 } }#========= RCNN ============layer {name: "dummy_roi_pool_conv5"type: "DummyData"top: "dummy_roi_pool_conv5"dummy_data_param {shape { dim: 1 dim: 18432 }data_filler { type: "gaussian" std: 0.01 }} } layer {name: "fc6"type: "InnerProduct"bottom: "dummy_roi_pool_conv5"top: "fc6"param { lr_mult: 0 decay_mult: 0 }param { lr_mult: 0 decay_mult: 0 }inner_product_param {num_output: 4096} } layer {name: "fc7"type: "InnerProduct"bottom: "fc6"top: "fc7"param { lr_mult: 0 decay_mult: 0 }param { lr_mult: 0 decay_mult: 0 }inner_product_param {num_output: 1024} } layer {name: "silence_fc7"type: "Silence"bottom: "fc7" }
它的示意圖如下: 這里借用了 http://blog.csdn.net/zy1034092330/article/details/62044941里的圖。

上面Conv layers包含了五層卷積層。 接下來,對于第五層卷積層,進(jìn)行了3*3的卷積操作,輸出了256個通道,當(dāng)然大小與卷積前的大小相同。

然后開始分別接入了cls層與regression層。對于cls層,使用1*1的卷積操作輸出了18(9*2 bg/fg)個通道的feature map,大小不變。而對于regression層,也使用1*1的卷積層輸出了36(4*9)個通道的feature map,大小不變。?

對于cls層后又接了一個reshape層,為什么要接這個層呢?引用參考文獻(xiàn)[1]的話,其實(shí)只是為了便于softmax分類,至于具體原因這就要從caffe的實(shí)現(xiàn)形式說起了。在caffe基本數(shù)據(jù)結(jié)構(gòu)blob中以如下形式保存數(shù)據(jù):
blob=[batch_size, channel,height,width]
對應(yīng)至上面的保存bg/fg anchors的矩陣,其在caffe blob中的存儲形式為[1, 2*9, H, W]。而在softmax分類時需要進(jìn)行fg/bg二分類,所以reshape layer會將其變?yōu)閇1, 2, 9*H, W]大小,即單獨(dú)“騰空”出來一個維度以便softmax分類,之后再reshape回復(fù)原狀。

我們可以用python模擬一下,看如下的程序:

>>> a=np.array([[[1,2],[3,4]],[[5,6],[7,8]],[[9,10],[11,12]],[[13,14],[15,16]]]) >>> a array([[[ 1, 2],[ 3, 4]],[[ 5, 6],[ 7, 8]],[[ 9, 10],[11, 12]],[[13, 14],[15, 16]]]) >>> a.shape (4L, 2L, 2L)然后由于caffe中是行優(yōu)先,numpy也如此,那么reshape一下的結(jié)果如下:

>>> b=a.reshape(2,4,2) >>> b array([[[ 1, 2],[ 3, 4],[ 5, 6],[ 7, 8]],[[ 9, 10],[11, 12],[13, 14],[15, 16]]])
從上面可以看出reshape是把相鄰?fù)ǖ赖木仃囈频剿南旅媪恕_@樣就剩下兩個大的矩陣了,就可以相鄰?fù)ǖ乐g進(jìn)行softmax了。 從中其實(shí)我們也能發(fā)現(xiàn),對于rpn每個點(diǎn)的18個輸出通道,前9個為背景的預(yù)測分?jǐn)?shù),而后9個為前景的預(yù)測分?jǐn)?shù)。

假定softmax昨晚后,我們看看是否能夠回到原先?

>>> b.reshape(4,2,2) array([[[ 1, 2],[ 3, 4]],[[ 5, 6],[ 7, 8]],[[ 9, 10],[11, 12]],[[13, 14],[15, 16]]])果然又回到了原始的狀態(tài)。

而對于regression呢,不需要這樣的操作,那么他的36個通道是不是也是如上面18個通道那樣呢?即第一個9通道為dx,第二個為dy,第三個為dw,第五個是dh。還是我們比較容易想到的那種,即第一個通道是第一個盒子的回歸量(dx1,dy1,dw1,dh1),第二個為(dx2,dy2,dw,2,dh2).....。待后面查看對應(yīng)的bbox_targets就知道了。先留個坑。

正如圖上所示,我們還需要準(zhǔn)備一個層rpn-data。

layer {name: 'rpn-data'type: 'Python'bottom: 'rpn_cls_score'bottom: 'gt_boxes'bottom: 'im_info'bottom: 'data'top: 'rpn_labels'top: 'rpn_bbox_targets'top: 'rpn_bbox_inside_weights'top: 'rpn_bbox_outside_weights'python_param {module: 'rpn.anchor_target_layer'layer: 'AnchorTargetLayer'param_str: "'feat_stride': 16"} }
這一層輸入四個量:data,gt_boxes,im_info,rpn_cls_score,其中前三個是我們在前面說過的,

data: ? ? ? ? 1*3*600*1000
gt_boxes: N*5, ? ? ? ? ? ? ? ? ? N為groundtruth box的個數(shù),每一行為(x1, y1, x2, y2, cls) ,而且這里的gt_box是經(jīng)過縮放的。
im_info: 1*3 ? ? ? ? ? ? ? ? ? (h,w,scale)

rpn_cls_score是cls層輸出的18通道,shape可以看成是1*18*H*W. ?

輸出為4個量:rpn_labels 、rpn_bbox_targets(回歸目標(biāo))、rpn_bbox_inside_weights(內(nèi)權(quán)重)、rpn_bbox_outside_weights(外權(quán)重)。

通俗地來講,這一層產(chǎn)生了具體的anchor坐標(biāo),并與groundtruth box進(jìn)行了重疊度計算,輸出了kabel與回歸目標(biāo)。

接下來我們來看一下文件anchor_target_layer.py?

def setup(self, bottom, top):layer_params = yaml.load(self.param_str_) #在第5個卷積層后的feature map上的每個點(diǎn)取anchor,尺度為(8,16,32),結(jié)合后面的feat_stride為16,#再縮放回原來的圖像大小,正好尺度是(128,256,512),與paper一樣。anchor_scales = layer_params.get('scales', (8, 16, 32)) self._anchors = generate_anchors(scales=np.array(anchor_scales)) #產(chǎn)生feature map最左上角的那個點(diǎn)對應(yīng)的anchor(x1,y1,x2,y2),# 尺度為原始圖像的尺度(可以看成是Im_info的寬和高尺度,或者是600*1000)。self._num_anchors = self._anchors.shape[0] #9self._feat_stride = layer_params['feat_stride'] #16if DEBUG:print 'anchors:'print self._anchorsprint 'anchor shapes:'print np.hstack(( # 輸出寬和高self._anchors[:, 2::4] - self._anchors[:, 0::4], #第2列減去第0列self._anchors[:, 3::4] - self._anchors[:, 1::4], #第3列減去第1列))self._counts = cfg.EPSself._sums = np.zeros((1, 4))self._squared_sums = np.zeros((1, 4))self._fg_sum = 0self._bg_sum = 0self._count = 0# allow boxes to sit over the edge by a small amount self._allowed_border = layer_params.get('allowed_border', 0) height, width = bottom[0].data.shape[-2:] #cls后的feature map的大小if DEBUG:print 'AnchorTargetLayer: height', height, 'width', widthA = self._num_anchors # labelstop[0].reshape(1, 1, A * height, width) # 顯然與rpn_cls_score_reshape保持相同的shape.# bbox_targetstop[1].reshape(1, A * 4, height, width) # bbox_inside_weightstop[2].reshape(1, A * 4, height, width)# bbox_outside_weightstop[3].reshape(1, A * 4, height, width) setup設(shè)置了top輸出的shape,并且做了一些準(zhǔn)備工作。

接下來看forward函數(shù)。

def forward(self, bottom, top):# Algorithm:## for each (H, W) location i# generate 9 anchor boxes centered on cell i# apply predicted bbox deltas at cell i to each of the 9 anchors# filter out-of-image anchors# measure GT overlapassert bottom[0].data.shape[0] == 1, \'Only single item batches are supported' # 僅僅支持一張圖片# map of shape (..., H, W)height, width = bottom[0].data.shape[-2:] # GT boxes (x1, y1, x2, y2, label)gt_boxes = bottom[1].data # im_infoim_info = bottom[2].data[0, :]if DEBUG:print ''print 'im_size: ({}, {})'.format(im_info[0], im_info[1])print 'scale: {}'.format(im_info[2])print 'height, width: ({}, {})'.format(height, width)print 'rpn: gt_boxes.shape', gt_boxes.shapeprint 'rpn: gt_boxes', gt_boxes# 1. Generate proposals from bbox deltas and shifted anchorsshift_x = np.arange(0, width) * self._feat_stride shift_y = np.arange(0, height) * self._feat_stride shift_x, shift_y = np.meshgrid(shift_x, shift_y)shifts = np.vstack((shift_x.ravel(), shift_y.ravel(),shift_x.ravel(), shift_y.ravel())).transpose()# add A anchors (1, A, 4) to# cell K shifts (K, 1, 4) to get# shift anchors (K, A, 4)# reshape to (K*A, 4) shifted anchorsA = self._num_anchorsK = shifts.shape[0]all_anchors = (self._anchors.reshape((1, A, 4)) +shifts.reshape((1, K, 4)).transpose((1, 0, 2)))all_anchors = all_anchors.reshape((K * A, 4))total_anchors = int(K * A) # 根據(jù)左上角的anchor生成所有的anchor,這里將所有的anchor按照行排列。行:K*A(K= height*width ,A=9),列:4,且按照feature map按行優(yōu)先這樣排下來。# only keep anchors inside the image #取所有在圖像內(nèi)部的anchorinds_inside = np.where((all_anchors[:, 0] >= -self._allowed_border) &(all_anchors[:, 1] >= -self._allowed_border) &(all_anchors[:, 2] < im_info[1] + self._allowed_border) & # width(all_anchors[:, 3] < im_info[0] + self._allowed_border) # height)[0] if DEBUG:print 'total_anchors', total_anchorsprint 'inds_inside', len(inds_inside)# keep only inside anchorsanchors = all_anchors[inds_inside, :]if DEBUG:print 'anchors.shape', anchors.shape# label: 1 is positive, 0 is negative, -1 is dont carelabels = np.empty((len(inds_inside), ), dtype=np.float32)labels.fill(-1)# overlaps between the anchors and the gt boxes# overlaps (ex, gt)overlaps = bbox_overlaps(np.ascontiguousarray(anchors, dtype=np.float),np.ascontiguousarray(gt_boxes, dtype=np.float))argmax_overlaps = overlaps.argmax(axis=1) #對于每一個anchor,取其重疊度最大的ground truth的序號max_overlaps = overlaps[np.arange(len(inds_inside)), argmax_overlaps] #生成max_overlaps,(為一列)即每個anchor對應(yīng)的最大重疊度gt_argmax_overlaps = overlaps.argmax(axis=0) #對于每個類,選擇其對應(yīng)的最大重疊度的anchor序號gt_max_overlaps = overlaps[gt_argmax_overlaps, np.arange(overlaps.shape[1])] #生成gt_max_overlaps,(為一行)即每類對應(yīng)的最大重疊度gt_argmax_overlaps = np.where(overlaps == gt_max_overlaps)[0] #找到那些等于gt_max_overlaps的anchor,這些anchor將參與訓(xùn)練rpn# 找到所有overlaps中所有等于gt_max_overlaps的元素,因?yàn)間t_max_overlaps對于每個非負(fù)類別只保留一個# anchor,如果同一列有多個相等的最大IOU overlap值,那么就需要把其他的幾個值找到,并在后面將它們# 的label設(shè)為1,即認(rèn)為它們是object,畢竟在RPN的cls任務(wù)中,只要認(rèn)為它是否是個object即可,即一個# 二分類問題。 (總結(jié))# 如下設(shè)置了前景(1)、背景(0)以及不關(guān)心(-1)的anchor標(biāo)簽if not cfg.TRAIN.RPN_CLOBBER_POSITIVES:# assign bg labels first so that positive labels can clobber themlabels[max_overlaps < cfg.TRAIN.RPN_NEGATIVE_OVERLAP] = 0 #對于最大重疊度低于0.3的設(shè)為背景# fg label: for each gt, anchor with highest overlap labels[gt_argmax_overlaps] = 1 # fg label: above threshold IOUlabels[max_overlaps >= cfg.TRAIN.RPN_POSITIVE_OVERLAP] = 1 if cfg.TRAIN.RPN_CLOBBER_POSITIVES:# assign bg labels last so that negative labels can clobber positiveslabels[max_overlaps < cfg.TRAIN.RPN_NEGATIVE_OVERLAP] = 0# 取前景與背景的anchor各一半,目前一批有256個anchor.# subsample positive labels if we have too manynum_fg = int(cfg.TRAIN.RPN_FG_FRACTION * cfg.TRAIN.RPN_BATCHSIZE) #256*0.5=128fg_inds = np.where(labels == 1)[0]if len(fg_inds) > num_fg:disable_inds = npr.choice(fg_inds, size=(len(fg_inds) - num_fg), replace=False)labels[disable_inds] = -1# subsample negative labels if we have too manynum_bg = cfg.TRAIN.RPN_BATCHSIZE - np.sum(labels == 1) #另一半256*0.5=128bg_inds = np.where(labels == 0)[0]if len(bg_inds) > num_bg:disable_inds = npr.choice(bg_inds, size=(len(bg_inds) - num_bg), replace=False)labels[disable_inds] = -1#print "was %s inds, disabling %s, now %s inds" % (#len(bg_inds), len(disable_inds), np.sum(labels == 0))#計算了所有在內(nèi)部的anchor與對應(yīng)的ground truth的回歸量bbox_targets = np.zeros((len(inds_inside), 4), dtype=np.float32)bbox_targets = _compute_targets(anchors, gt_boxes[argmax_overlaps, :])#只有前景類內(nèi)部權(quán)重才非0,參與回歸bbox_inside_weights = np.zeros((len(inds_inside), 4), dtype=np.float32)bbox_inside_weights[labels == 1, :] = np.array(cfg.TRAIN.RPN_BBOX_INSIDE_WEIGHTS) #(1.0, 1.0, 1.0, 1.0)# Give the positive RPN examples weight of p * 1 / {num positives}# and give negatives a weight of (1 - p)/(num negative) # Set to -1.0 to use uniform example weightingbbox_outside_weights = np.zeros((len(inds_inside), 4), dtype=np.float32)if cfg.TRAIN.RPN_POSITIVE_WEIGHT < 0:# uniform weighting of examples (given non-uniform sampling)num_examples = np.sum(labels >= 0)positive_weights = np.ones((1, 4)) * 1.0 / num_examplesnegative_weights = np.ones((1, 4)) * 1.0 / num_exampleselse:assert ((cfg.TRAIN.RPN_POSITIVE_WEIGHT > 0) &(cfg.TRAIN.RPN_POSITIVE_WEIGHT < 1))positive_weights = (cfg.TRAIN.RPN_POSITIVE_WEIGHT /np.sum(labels == 1))negative_weights = ((1.0 - cfg.TRAIN.RPN_POSITIVE_WEIGHT) /np.sum(labels == 0))bbox_outside_weights[labels == 1, :] = positive_weights # 前景與背景anchor的外參數(shù)相同,都是1/anchor個數(shù)bbox_outside_weights[labels == 0, :] = negative_weightsif DEBUG:self._sums += bbox_targets[labels == 1, :].sum(axis=0)self._squared_sums += (bbox_targets[labels == 1, :] ** 2).sum(axis=0)self._counts += np.sum(labels == 1)means = self._sums / self._countsstds = np.sqrt(self._squared_sums / self._counts - means ** 2)print 'means:'print meansprint 'stdevs:'print stds# map up to original set of anchors 生成全部anchor的數(shù)據(jù),將非0的數(shù)據(jù)填入。labels = _unmap(labels, total_anchors, inds_inside, fill=-1)bbox_targets = _unmap(bbox_targets, total_anchors, inds_inside, fill=0)bbox_inside_weights = _unmap(bbox_inside_weights, total_anchors, inds_inside, fill=0)bbox_outside_weights = _unmap(bbox_outside_weights, total_anchors, inds_inside, fill=0)if DEBUG:print 'rpn: max max_overlap', np.max(max_overlaps)print 'rpn: num_positive', np.sum(labels == 1)print 'rpn: num_negative', np.sum(labels == 0)self._fg_sum += np.sum(labels == 1)self._bg_sum += np.sum(labels == 0)self._count += 1print 'rpn: num_positive avg', self._fg_sum / self._countprint 'rpn: num_negative avg', self._bg_sum / self._count# labels labels = labels.reshape((1, height, width, A)).transpose(0, 3, 1, 2)labels = labels.reshape((1, 1, A * height, width))top[0].reshape(*labels.shape)top[0].data[...] = labels# bbox_targetsbbox_targets = bbox_targets \.reshape((1, height, width, A * 4)).transpose(0, 3, 1, 2)top[1].reshape(*bbox_targets.shape)top[1].data[...] = bbox_targets# bbox_inside_weightsbbox_inside_weights = bbox_inside_weights \.reshape((1, height, width, A * 4)).transpose(0, 3, 1, 2)assert bbox_inside_weights.shape[2] == heightassert bbox_inside_weights.shape[3] == widthtop[2].reshape(*bbox_inside_weights.shape)top[2].data[...] = bbox_inside_weights# bbox_outside_weightsbbox_outside_weights = bbox_outside_weights \.reshape((1, height, width, A * 4)).transpose(0, 3, 1, 2)assert bbox_outside_weights.shape[2] == heightassert bbox_outside_weights.shape[3] == widthtop[3].reshape(*bbox_outside_weights.shape)top[3].data[...] = bbox_outside_weights
這里已經(jīng)有詳細(xì)的注釋,總的來說,rpn_cls_score的作用就是告知第五層feature map的寬和高。便于決定生成多少個anchor. 而其他的bottom輸入才最終決定top的輸出。


首先這里生成了所有feature map各點(diǎn)對應(yīng)的anchors。生成的方式很特別,先考慮了左上角一個點(diǎn)的anchor生成,考慮到feat_stride=16,所以這個點(diǎn)對應(yīng)原始圖像(這里統(tǒng)一指縮放后image)的(0,0,15,15)感受野。然后取其中心點(diǎn),生成比例為1:1,1:2,2:1,尺度在128,256,512的9個anchor.然后考慮使用平移生成其他的anchor.

然后過濾掉那些不在圖像內(nèi)部的anchor. 對于剩下的anchor,計算與gt_boxes的重疊度,再分別計算label,bbox_targets,bbox_inside_weights,bbox_outside_weights.


最后將內(nèi)部的anchor的相關(guān)變量擴(kuò)充到所有的anchor,只不過不在內(nèi)部的為0即可。尤其值得說的是對于內(nèi)部的anchor,bbox_targets都進(jìn)行了運(yùn)算。但是選取了256個anchor,前景與背景比例為1:1,bbox_inside_weights中只有l(wèi)abel=1,即前景才進(jìn)行了設(shè)置。正如論文所說,對于回歸項(xiàng),需要內(nèi)部參數(shù)來約束,bbox_inside_weights正好起到了這個作用。

我們統(tǒng)計一下top的shape:

rpn_labels : (1, 1, 9 * height, width)

rpn_bbox_targets(回歸目標(biāo)): (1, 36,height, width)

rpn_bbox_inside_weights(內(nèi)權(quán)重):(1, 36,height, width)

rpn_bbox_outside_weights(外權(quán)重):(1, 36,height, width)


回到stage1_rpn_train.pt,接下里我們就可以利用rpn_cls_score_reshape與rpn_labels計算SoftmaxWithLoss,輸出rpn_cls_loss。

而regression可以利用rpn_bbox_pred,rpn_bbox_targets,rpn_bbox_inside_weights,rpn_bbox_outside_weights計算SmoothL1Loss,輸出rpn_loss_bbox。

回到我們之前有一個問題rpn_bbox_pred的shape怎么構(gòu)造的。其實(shí)從rpn_bbox_targets的生成過程中可以推斷出應(yīng)該采用后一種,即第一個盒子的回歸量(dx1,dy1,dw1,dh1),第二個為(dx2,dy2,dw,2,dh2).....,這樣順序著來。


其實(shí)怎么樣認(rèn)為都是從我們方便的角度出發(fā)。



至此我們完成了rpn的前向過程,反向過程中只需注意AnchorTargetLayer不參與反向傳播。因?yàn)樗峁┑亩际窃磾?shù)據(jù)。


參考:

1. ?http://blog.csdn.net/zy1034092330/article/details/62044941?

2.? Faster RCNN anchor_target_layer.py


創(chuàng)作挑戰(zhàn)賽新人創(chuàng)作獎勵來咯,堅(jiān)持創(chuàng)作打卡瓜分現(xiàn)金大獎

總結(jié)

以上是生活随笔為你收集整理的faster rcnn学习之rpn训练全过程的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

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

国产中文| 欧美色精品天天在线观看视频 | 一区二区中文字幕在线播放 | 一区二区国产精品 | 99精品视频免费看 | 欧美精品久久久久久久 | av电影免费在线播放 | 91中文字幕在线观看 | 97在线资源 | 在线观看91精品国产网站 | 国产黄a三级三级三级三级三级 | 超碰97人人干 | 免费看的黄色小视频 | 日本一区二区三区免费观看 | 日韩乱色精品一区二区 | 韩日电影在线观看 | 国产精品女人久久久 | 99这里都是精品 | 国产欧美最新羞羞视频在线观看 | 天天草av | 伊人亚洲综合网 | 成人三级网站在线观看 | 日韩丝袜 | 成人九九视频 | 亚洲美女精品区人人人人 | 五月天婷婷在线观看视频 | 久久免费影院 | 91成人免费看片 | 国产精品久久久久一区二区三区 | 日韩高清在线一区 | 国产精品久久久久av | 久久久久国产一区二区三区四区 | 黄色av一级片 | 国产精品一区二区三区在线免费观看 | 国产视频综合在线 | 麻豆视频免费播放 | 久久精品国产亚洲精品2020 | 欧美日本不卡视频 | 9ⅰ精品久久久久久久久中文字幕 | 亚洲视频在线免费观看 | 久久精品第一页 | 免费看污黄网站 | 国产精品欧美久久久久天天影视 | 国产成人精品aaa | 夜色成人av | 98涩涩国产露脸精品国产网 | 四虎永久精品在线 | 天天爱天天干天天爽 | 91视频免费网址 | 中文字幕电影网 | 一区二区精品在线 | 麻豆免费视频网站 | 亚洲精品久久久蜜臀下载官网 | 中文字幕欧美日韩va免费视频 | 国产精品激情偷乱一区二区∴ | 成人a视频 | 丁香 婷婷 激情 | 欧美亚洲国产精品久久高清浪潮 | 中文字幕色网站 | 久久精品激情 | 97超碰人人澡人人爱 | 久久这里有精品 | .国产精品成人自产拍在线观看6 | 丰满少妇一级 | 日日夜夜网 | 香蕉视频免费看 | 成人欧美一区二区三区在线观看 | 日韩在线观看一区二区 | 69亚洲视频 | 一本一本久久a久久精品综合妖精 | 国产一区免费视频 | 精品福利网 | 国产精品国产三级国产aⅴ无密码 | 夜夜操网站 | 91在线国内视频 | 麻豆传媒视频在线免费观看 | 91亚·色| 日日干夜夜干 | 天天射天天色天天干 | 伊人资源站 | 天天干天天射天天操 | 欧美 亚洲 另类 激情 另类 | 中中文字幕av在线 | 亚洲aⅴ乱码精品成人区 | 91视视频在线直接观看在线看网页在线看 | 黄色国产高清 | 亚洲精品久久久久中文字幕二区 | 开心婷婷色 | 免费看黄色91 | 一区二区三区日韩视频在线观看 | 亚洲精品国偷拍自产在线观看蜜桃 | 久久一级片 | 亚洲精品国产精品国自产观看浪潮 | 去看片 | 国产理论在线 | 国产精品久久久久久欧美 | 色香天天 | 国产一区免费在线观看 | 91精品国产高清自在线观看 | 黄色小说18 | 亚洲免费精品一区二区 | 色视频网站在线 | 日韩免费视频播放 | 国产 日韩 欧美 中文 在线播放 | 亚洲黄色网络 | 91人人澡人人爽人人精品 | 日本中文字幕在线看 | 日本中文一区二区 | 在线免费91 | 久久综合九色综合久久久精品综合 | 国产黄色在线观看 | 蜜臀av性久久久久蜜臀aⅴ涩爱 | 国产精品一区二区久久久 | 午夜 久久 tv | 麻豆91在线 | 欧美成人精品欧美一级乱 | 亚洲欧洲av在线 | 色噜噜噜| 99久久久国产精品免费观看 | 久久综合狠狠综合久久综合88 | 亚洲精品999 | 黄色片网站 | 香蕉影院在线播放 | 公开超碰在线 | 国产在线理论片 | 免费在线成人av电影 | 午夜视频在线观看一区 | 99精品在线看 | 久久综合色综合88 | 久久精品视频国产 | 国产成人99久久亚洲综合精品 | 色国产视频 | 国产午夜精品久久久久久久久久 | 在线日韩精品视频 | 日韩黄视频| av网站有哪些 | 激情五月婷婷综合 | 91视频免费播放 | 亚洲第一av在线播放 | 日韩专区中文字幕 | 欧美视频国产视频 | 国产美女视频一区 | 亚洲日本va在线观看 | 日韩精品免费一区二区在线观看 | 成人毛片100免费观看 | 激情黄色av| 黄色在线网站噜噜噜 | 日日夜夜精品免费 | 婷婷综合伊人 | 中文字幕 在线看 | 久操视频在线播放 | 丰满少妇一级片 | 91成人精品观看 | 天堂av免费观看 | 91在线精品秘密一区二区 | 在线观看日韩专区 | 456成人精品影院 | 亚洲免费观看视频 | 国产免费不卡 | 亚洲视频久久 | 久久中文精品视频 | www.久久久精品 | 中文成人字幕 | 手机av电影在线观看 | 五月天综合激情网 | 日日婷婷夜日日天干 | 日本精品一区二区三区在线观看 | 久久久福利 | 手机在线看a | 丁香综合av | 国产成a人亚洲精v品在线观看 | 麻豆播放 | 亚洲黄色av网址 | 久久精品视频18 | 日韩在线观看视频中文字幕 | 欧美另类视频 | 成人黄性视频 | 在线视频成人 | 国产三级精品在线 | 久久99精品波多结衣一区 | 永久免费毛片在线观看 | 国产原创在线 | 狠狠色狠狠色综合系列 | 久草国产在线 | 欧美一区二区视频97 | 一区二区三区在线影院 | 国产 日韩 欧美 中文 在线播放 | 国产精品激情在线观看 | 国产 日韩 在线 亚洲 字幕 中文 | 手机在线中文字幕 | av黄网站 | 久久精品在线免费观看 | 天天综合91| 国产午夜精品一区二区三区嫩草 | 人人插人人爱 | 国产色a在线观看 | 98涩涩国产露脸精品国产网 | 亚洲精品国产综合99久久夜夜嗨 | 久久综合九色综合欧美就去吻 | 天天干天天干天天干 | 91男人影院 | 亚洲综合射 | 日韩剧| 97超碰国产精品女人人人爽 | 中文字幕电影高清在线观看 | 在线观看成人国产 | 色综合久久五月天 | 91私密保健| 日韩中文字幕在线不卡 | 久久这里只有精品久久 | 久久精品99国产 | 97成人在线免费视频 | 日韩视频免费观看高清 | 99在线免费视频观看 | 日韩精品欧美一区 | 日韩欧美高清一区二区三区 | 成人av片免费观看app下载 | 久久成人资源 | 在线日韩三级 | 中文字幕在线看视频 | 欧美日韩一区二区视频在线观看 | 日韩三级一区 | 91九色精品国产 | 亚洲精品久久久久中文字幕二区 | 欧美日本不卡 | 蜜桃视频日韩 | 91精品人成在线观看 | 97涩涩视频 | 麻豆小视频在线观看 | 丁香婷婷激情五月 | 国产99久久精品一区二区300 | 日韩欧美一区二区三区免费观看 | 四虎在线永久免费观看 | 日本三级不卡视频 | 在线播放精品一区二区三区 | 国产精品美女久久久久久久 | 天天操狠狠操夜夜操 | 午夜精品中文字幕 | 日韩中文字幕a | 亚洲日韩精品欧美一区二区 | 精品久久久久免费极品大片 | 久久久www | 玖玖视频国产 | 手机在线观看国产精品 | 国产品久精国精产拍 | 精品在线小视频 | 久久精品一区二区三区视频 | av一级久久 | 午夜私人影院 | 青青草在久久免费久久免费 | 天天草天天干天天 | 国产在线黄 | 又黄又刺激的网站 | 日韩色综合网 | 亚洲一区精品人人爽人人躁 | 亚洲精品国精品久久99热 | 亚洲天堂精品视频 | 中文字幕资源在线观看 | 操操操日日 | 免费在线观看av网站 | 久久久国产精品一区二区中文 | 色婷婷国产 | 探花视频免费观看高清视频 | 国产亚洲精品中文字幕 | 日韩三级在线观看 | 久草精品在线播放 | 国产欧美精品在线观看 | 欧洲精品视频一区 | 日韩精品亚洲专区在线观看 | 黄色一级免费网站 | 国产精品国产精品 | 成人精品视频久久久久 | 亚洲视频六区 | 亚洲作爱| 亚洲精品在线视频播放 | 欧美日韩伦理在线 | 在线免费观看视频 | 中文字幕网站视频在线 | 久久久免费精品国产一区二区 | 欧美在线aa| 欧美俄罗斯性视频 | 黄色a一级视频 | 亚洲黄色片在线 | 91在线在线观看 | 干狠狠 | 国产精品一区二区免费 | 免费在线观看黄 | 久久视频在线观看免费 | 日韩视频一二三区 | 国产视频一区在线免费观看 | 国产大片免费久久 | 久久爽久久爽久久av东京爽 | 91最新网址在线观看 | 91成人免费观看视频 | 看片一区二区三区 | 一区二区三区在线不卡 | 欧美久久九九 | 自拍超碰在线 | 人人添人人澡人人澡人人人爽 | 91精品久久久久久久99蜜桃 | 欧美黑人性猛交 | 91综合久久一区二区 | 久久亚洲视频 | 欧美成人精品三级在线观看播放 | 999热线在线观看 | 亚洲国产精品久久久久婷婷884 | 成人网在线免费视频 | 国产亚洲视频在线观看 | 亚洲综合视频在线观看 | 少妇精69xxtheporn | av丝袜美腿| 亚洲黄色免费在线看 | 成人免费一级片 | 久久黄色美女 | 国产高清在线免费视频 | 日本中文字幕在线免费观看 | 97在线观看视频国产 | 久久精品爱爱视频 | 欧美日本日韩aⅴ在线视频 插插插色综合 | 国产午夜精品一区二区三区嫩草 | 欧美日韩裸体免费视频 | 国产亚洲精品久久久久久电影 | 国产小视频福利在线 | 久久久久国产精品免费 | 六月丁香社区 | 久久综合给合久久狠狠色 | 日韩av电影免费观看 | 丁香婷婷深情五月亚洲 | 国产一区麻豆 | 亚洲成人网在线 | 成人a视频片观看免费 | 美女久久久久 | 婷婷丁香九月 | 四虎伊人 | 在线免费高清一区二区三区 | 国产高清视频免费在线观看 | 欧美激情精品久久久久久变态 | 色老板在线 | 亚洲精品在线资源 | 欧美91视频 | 欧美精品一区二区三区四区在线 | 天天色天天骑天天射 | 激情婷婷综合网 | 成人免费在线视频观看 | 国产在线97| 久草9视频 | 国产精品对白一区二区三区 | 91视频午夜 | 视频在线观看亚洲 | 在线国产一区二区 | 99久久久久成人国产免费 | 一区二区三区免费 | 在线观看黄污 | 一级淫片a| 亚洲日日日| 天堂av网址 | 国内小视频在线观看 | 亚洲精品视频久久 | 国产理论免费 | 视频直播国产精品 | 欧美性色19p | 五月天婷婷狠狠 | 一区二区成人国产精品 | 国产美女视频黄a视频免费 久久综合九色欧美综合狠狠 | 色99视频 | 久久久久久久久久久久久9999 | 在线观看视频日韩 | 久久久久亚洲国产 | 成人午夜影视 | 午夜在线国产 | 成人四虎 | 国产一区二区三区在线 | www激情久久 | 开心色激情网 | 五月婷婷六月综合 | 日韩黄色免费在线观看 | 少妇性aaaaaaaaa视频 | 日日操日日插 | 亚洲精品啊啊啊 | 极品久久久久 | 香蕉视频国产在线观看 | 人人爽人人看 | 亚洲成aⅴ人片久久青草影院 | 国产在线更新 | 在线观看资源 | 成人影片在线免费观看 | 视频二区在线 | 中文字幕久久久精品 | 美女一级毛片视频 | 婷婷亚洲综合 | 亚洲精品久久久蜜桃直播 | 在线视频免费观看 | 成人四虎| 久久精品香蕉 | 在线视频 一区二区 | 99国产免费网址 | 亚洲理论视频 | 在线免费中文字幕 | 91精品国产综合久久久久久久 | 91大神电影 | 亚洲欧美国产精品18p | 亚洲国产中文字幕在线观看 | 国产精品一区二区三区四区在线观看 | 免费网站在线观看人 | 亚洲精品ww| 国产精品美女久久久 | 婷婷午夜激情 | 成人影片在线免费观看 | 国产成人一区二区三区免费看 | 成在线播放 | 国产麻豆果冻传媒在线观看 | 国产精品 日韩精品 | 精品国产99国产精品 | 精品久久久久久久久久国产 | 久草精品视频 | 色婷婷福利视频 | 欧美午夜理伦三级在线观看 | 久久怡红院 | 日韩av资源在线观看 | 天天看天天干 | 五月激情五月激情 | 视频在线观看亚洲 | 久久不色 | 亚洲区视频在线观看 | 国产高清久久久 | 久久精品电影院 | 91精品久久久久久综合乱菊 | 日韩av在线免费看 | 91精品久久久久久久99蜜桃 | 婷婷久久网站 | www.久久久精品 | 中文字幕在线一区二区三区 | 九色91福利 | 丁香婷婷久久 | 中文字幕精品一区二区精品 | 99中文字幕在线观看 | 国产在线p | www亚洲精品 | 91秒拍国产福利一区 | av大全在线免费观看 | 在线中文视频 | 亚洲黄色大片 | 亚洲国产成人久久 | 丁香国产视频 | 中文字幕在线看视频国产 | av黄色成人| 午夜视频在线观看一区二区 | 午夜视频在线网站 | 综合国产在线观看 | 亚洲一级片在线观看 | 成人av免费网站 | 激情综合色图 | 久久国产精品久久久 | 日韩av一区二区三区在线观看 | av超碰免费在线 | 91精品国产99久久久久久久 | 中国一级特黄毛片大片久久 | 国产高清无线码2021 | 亚洲黄色影院 | 五月开心综合 | 九九久久久久久久久激情 | 怡红院久久 | 色婷婷影视 | 99热精品视 | 午夜 久久 tv | 成人av免费在线 | 久久激情网站 | 麻豆国产在线播放 | 一区 二区电影免费在线观看 | 天天操,夜夜操 | 97av在线视频免费播放 | 黄p网站在线观看 | 日韩欧美视频二区 | 少妇bbb好爽| av手机在线播放 | 狠狠色丁婷婷日日 | 99久久精品日本一区二区免费 | 天天碰天天操 | 久久久久亚洲a | 中文字幕观看av | 亚洲一级性 | 亚洲第二色 | 一区 二区 精品 | 中文字幕资源网 国产 | 在线观看亚洲精品视频 | 成人久久久久久久久久 | 啪嗒啪嗒免费观看完整版 | 啪啪午夜免费 | 99国产精品久久久久老师 | 欧美日韩久 | 国产精品久久久久久久久久不蜜月 | 手机av在线免费观看 | 毛片无卡免费无播放器 | 精品视频免费在线 | 久久99热精品这里久久精品 | 五月婷婷深开心 | 欧美极品xxx | 国产精品美女久久久久久网站 | 欧美一级电影在线观看 | 国产精品自产拍在线观看 | 一级久久精品 | 一区二区三区手机在线观看 | 日韩专区中文字幕 | 天天色综合1 | 天堂网av 在线 | 在线国产视频 | 国产精品免费看久久久8精臀av | 国产黄大片 | 激情五月婷婷网 | 日韩欧美视频在线播放 | 黄色大片av | 国产精品毛片一区二区 | 国产视频一区二区在线 | 91一区在线观看 | 国内精品久久久久影院优 | 狠狠狠色丁香综合久久天下网 | 天天插日日插 | 97色噜噜 | 免费国产在线精品 | 亚洲精品国产日韩 | 一本之道乱码区 | 成年人在线| 欧美精品久久久久久久久久 | 午夜久久影视 | 激情网在线视频 | 中文字幕亚洲高清 | 中文不卡视频 | 久久精选视频 | 天天操狠狠操网站 | 一区二区理论片 | 99免费在线视频观看 | 欧美在线aaa| 亚洲精品一区二区三区在线观看 | 九九在线高清精品视频 | 一区二区三区在线免费 | 成人黄色国产 | 亚洲精品成人av在线 | 国产91亚洲 | 四虎影视4hu4虎成人 | 日韩专区在线 | 91九色蝌蚪视频在线 | 国产小视频在线观看免费 | 西西4444www大胆视频 | 国产视频日本 | 国产婷婷 | 91粉色视频 | 久青草视频 | 亚洲综合色激情五月 | 色婷婷久久久综合中文字幕 | 国产91对白在线播 | 中文av在线播放 | 国产欧美日韩一区 | 天天干天天拍天天操天天拍 | www.夜夜干.com | 九月婷婷综合网 | 国产精品丝袜在线 | 啪啪小视频网站 | 日韩视频一区二区在线 | 久久精品国产一区 | 丁香六月久久综合狠狠色 | 日韩欧美视频免费在线观看 | 日韩资源在线 | 国产高清精品在线观看 | 91少妇精拍在线播放 | 亚洲精品国偷自产在线91正片 | 亚洲国产精品资源 | 日韩黄色大片在线观看 | 欧美日韩三区二区 | 国产精品福利在线 | 国产一级免费在线 | 日韩久久激情 | 日韩三级av| 91看片在线看片 | 国产精品毛片久久蜜 | 久久精品国产免费看久久精品 | www免费 | 亚洲一二三久久 | 成人国产精品电影 | 99精品视频免费在线观看 | 久久人人爽人人 | 国产精品免费视频网站 | 91视频在线国产 | 免费大片av | 色噜噜噜| 国产成人精品午夜在线播放 | 天天干天天操av | 国产麻豆视频网站 | 免费看的国产视频网站 | 日韩av手机在线看 | 久久久久久久久久电影 | 国产艹b视频 | 成人影视免费看 | 国产亚州av | 日韩激情影院 | 久久久免费网站 | 91高清免费看 | 91网址在线观看 | www久久国产| 99热这里只有精品免费 | 久久色亚洲 | 国产一级在线播放 | 最新国产视频 | 黄色高清视频在线观看 | av网站地址 | 国产精品美女在线观看 | 午夜国产福利视频 | 欧美无极色 | 丁香六月在线 | 欧美在线视频一区二区三区 | 婷婷久久国产 | 欧美极品少妇xbxb性爽爽视频 | 精品三级av| 99资源网 | 国产精品美女免费 | 最新国产福利 | 波多野结衣视频一区 | 91免费在线看片 | 久久精品视频一 | 少妇bbbb| 五月综合色| 国产一区二区三区视频在线 | 日韩最新在线 | 国产99久久久精品视频 | 亚洲人人精品 | 欧美色图狠狠干 | 亚洲国产精品成人综合 | 国产无遮挡又黄又爽在线观看 | 综合网在线视频 | 91精品视频网站 | 97超在线视频 | 成人性生交大片免费观看网站 | 天天干天天射天天操 | 中文字幕成人 | 日日爽视频 | 国产999精品 | 天天天天天操 | 91九色视频观看 | 欧美日韩亚洲一 | 国产在线国产 | 毛片a级片 | 伊人看片| 中文字幕日韩一区二区三区不卡 | 色视频 在线| 日韩一区二区免费在线观看 | 在线观看精品 | 国产精品免费一区二区三区在线观看 | 草免费视频 | 99视频在线精品免费观看2 | 欧美国产91 | 在线亚洲午夜片av大片 | 久久视频在线观看免费 | 免费中午字幕无吗 | 婷婷色站 | 日韩av电影免费观看 | 欧美在线观看视频免费 | 伊人五月在线 | 一级黄色片在线观看 | 91麻豆网| 日韩欧美不卡 | 国产精品精品久久久 | 亚洲精品66 | 国产精品久久久久久一区二区 | 国产又粗又长又硬免费视频 | 在线成人中文字幕 | 国内亚洲精品 | 天天天色| 久久国产免 | www.狠狠 | 亚洲精品视频偷拍 | av在线专区| 激情丁香综合五月 | 日韩精品一区二区在线视频 | 日韩精品视频免费看 | 久久国产精品视频观看 | 在线视频观看你懂的 | 久久成人毛片 | 日韩爱爱网站 | www.在线观看视频 | 女人魂免费观看 | 日韩最新av| 久久国产精品免费观看 | 久久乐九色婷婷综合色狠狠182 | 国产精品午夜久久久久久99热 | 亚洲精品视频免费在线观看 | 亚洲成人频道 | 日韩69视频 | 黄网站app在线观看免费视频 | 国产一级片网站 | 黄污网站在线 | 国产无套精品久久久久久 | 国产精品爽爽久久久久久蜜臀 | 69精品 | 国产亚洲成av片在线观看 | 摸bbb搡bbb搡bbbb| 国产香蕉在线 | 2018好看的中文在线观看 | 亚洲午夜精品久久久 | 国产粉嫩在线观看 | 日本中文字幕在线观看 | 国产精久久久久久妇女av | 色婷婷激情四射 | 午夜美女网站 | 香蕉视频久久 | 91精品视频播放 | 五月天堂色 | 久久成人在线视频 | 成人网在线免费视频 | av高清网站在线观看 | 亚洲婷婷伊人 | 91av精品| 91成人欧美 | 五月天婷亚洲天综合网鲁鲁鲁 | 精品久久久久久一区二区里番 | 伊人网av | 又黄又刺激视频 | 日韩v欧美v日本v亚洲v国产v | 国产99爱| 国产成人精品亚洲日本在线观看 | 亚洲伦理中文字幕 | 青春草视频在线播放 | 国产高清综合 | 国产96av| 色中文字幕在线观看 | 操操综合网 | 欧美激情精品久久久久 | 丁香六月在线 | 日韩av在线免费播放 | 天天干天天综合 | 国产一区二区精品在线 | 欧美日韩国产精品一区二区三区 | 国际精品久久久久 | 国产精品v a免费视频 | 日本中文字幕免费观看 | 免费看黄的 | 国产精品一区久久久久 | 欧美精品亚洲二区 | 欧美日韩高清 | 六月丁香综合网 | av免费看av| 久久综合天天 | 欧美一区二区在线看 | 久久综合毛片 | 欧美日韩免费在线观看视频 | 中文不卡视频 | av在线一级 | 在线免费国产视频 | 中文字幕一区三区 | avav片| 黄色软件视频大全免费下载 | 精品久久在线 | 色噜噜色噜噜 | 亚洲最大免费成人网 | 欧美专区国产专区 | 国产精品高清免费在线观看 | 精品一区二区免费在线观看 | 黄色av电影免费观看 | 欧美怡红院视频 | 天堂久久电影网 | 五月婷婷丁香色 | 国产精品永久免费观看 | 亚洲人在线 | 青青河边草手机免费 | 伊人亚洲综合 | 久久99婷婷 | 亚洲成人av一区二区 | 久久精品永久免费 | 91视频88av| 99综合视频 | 国产视频精品视频 | 五月天伊人网 | 亚洲综合成人婷婷小说 | 一区二区中文字幕在线 | 国产一区二区在线观看视频 | av免费网| 免费看成人| 一区二区三区在线免费观看 | 久久激情视频 | 成人在线免费看视频 | 粉嫩一区二区三区粉嫩91 | 人人干免费 | 麻豆国产网站入口 | 亚洲国产精品视频在线观看 | 欧美日韩在线网站 | 国产精品乱看 | 91在线视频在线观看 | jizzjizzjizz亚洲 | 国产亚洲日本 | 日韩精品久久久久久久电影竹菊 | 中文字幕成人网 | 欧美一级久久久久 | 亚洲一区动漫 | 韩国av电影在线观看 | 精品国产一区二区三区四区在线观看 | 精品国产亚洲在线 | 一区在线免费观看 | 国产午夜精品视频 | 婷婷国产v亚洲v欧美久久 | 天天插伊人 | 天天爽综合网 | 国产精品人成电影在线观看 | 99精品视频在线观看播放 | 免费看片网站91 | 亚洲第一中文字幕 | 国产亚洲精品久久久久久移动网络 | 国产手机在线观看 | 国内外成人免费在线视频 | 久久精品欧美一 | 在线色资源 | 国产精品久久久久久久久岛 | 久久精品久久久久 | 久久久精品视频网站 | 欧美一二三在线 | 黄色福利| 成人在线观看你懂的 | av黄色国产 | 最新极品jizzhd欧美 | 国产一级二级三级视频 | 91精品国产自产在线观看永久 | 91精品一 | 伊人永久| 久久精品99国产 | 日韩一级电影在线 | 久久黄色免费观看 | 成人黄色在线观看视频 | 久久无码精品一区二区三区 | 一区二区三区免费在线 | 久热电影 | 国产一区视频在线 | 久久婷婷精品 | 在线视频亚洲 | 久久久在线观看 | 欧美日韩视频在线观看一区二区 | 国产精品久久久久久久久久久久午 | 1区2区3区在线观看 三级动图 | 欧美日韩69 | 日韩欧美在线一区 | 日韩免费中文字幕 | 日本婷婷色 | 久久夜色精品亚洲噜噜国4 午夜视频在线观看欧美 | 日韩免费视频线观看 | 日韩高清av在线 | 日韩一级成人av | 中文字幕在线观看免费 | 国产91精品在线播放 | 国产999精品久久久久久绿帽 | 在线 视频 一区二区 | 久草在线一免费新视频 | 少妇18xxxx性xxxx片| 国产1区2区3区在线 亚洲自拍偷拍色图 | 97精品国产一二三产区 | 久久免费一 | 91久久国产自产拍夜夜嗨 | 性色va | 精品国产一区二区三区在线观看 | 在线免费观看欧美日韩 | 中文字幕在线视频一区二区 | 久久午夜色播影院免费高清 | 在线精品在线 | 日韩欧美在线观看一区二区 | 在线观看国产一区二区 | 免费一级片久久 | 77国产精品 | 欧美日韩中文字幕在线视频 | 国内精品久久久久国产 | 亚洲精品88欧美一区二区 | 97国产在线视频 | 国产精品久久久久影院日本 | 久久国产精品系列 | 久久综合射 | 国产视频日本 | av线上看| 国产裸体视频网站 | 三上悠亚在线免费 | 成人黄色大片在线观看 | 日韩黄色一区 | 久久人人干| 欧美一级片在线 | 91欧美精品| 婷婷伊人五月天 | 九九精品视频在线看 | 国产亚洲在 | 久久精品网站免费观看 | 中文字幕免费在线 | 国产成人av网址 | 欧美日韩国产精品一区二区三区 | 天天射,天天干 | 天天操天天操天天操天天操 | 亚洲国产影院av久久久久 | 国产色综合天天综合网 | 日本精品久久久久中文字幕 | 午夜精品一二区 | 精品在线免费观看 | 日韩欧美综合精品 | 久久精品视频一 | 日本中文乱码卡一卡二新区 | 国产一性一爱一乱一交 | 亚洲久在线 | 国产精品精品久久久久久 | 国产中文字幕在线播放 | 精品人妖videos欧美人妖 | 久人人| 91中文字幕永久在线 | 亚洲资源在线网 | 在线观看免费黄色 | 亚洲国产一区在线观看 | 天天干亚洲 | 久草在在线视频 | 欧美在线观看视频一区二区三区 | 亚洲综合欧美日韩狠狠色 | 成人手机在线视频 | 亚洲一二区视频 | 国产日本亚洲高清 | 伊人久在线| 久久精品二区 | 日韩免费电影一区二区三区 | 玖玖爱在线观看 | 97操碰| 久久免费在线观看视频 | 一本一道波多野毛片中文在线 | 91女人18片女毛片60分钟 | 欧美va日韩va | 国产日韩欧美综合在线 | 九九精品视频在线观看 | 一级黄色大片在线观看 | 麻花天美星空视频 | 成人片在线播放 | 亚洲精品在线播放视频 | 亚洲撸撸 | 麻豆视屏 | 成人小视频在线观看免费 | 国产精品专区在线观看 | 天天躁天天操 | 亚洲精品视频观看 | 国产在线国偷精品产拍免费yy | 久久精品xxx| 成人观看 | 亚洲精品777| 久久视频一区二区 | 免费的成人av | 二区三区中文字幕 | 青草视频在线播放 | www久久99| 天天干天天做天天操 | 在线观看视频亚洲 | 在线观看你懂的网站 | 亚洲国产精品99久久久久久久久 | 97av影院| 99久久激情 | 成人午夜影院 | 亚洲开心激情 | 99久久精品无码一区二区毛片 | 亚洲国产一区二区精品专区 | 在线播放国产精品 | 奇米影视8888 | 在线观看中文字幕网站 | 亚洲国产片 | 欧美日韩国产在线观看 | 天天干天天操天天 | 中文字幕久久精品一区 | av超碰在线| 玖玖视频精品 | 青青草视频精品 | 久久伊人免费视频 | 国产亚洲精品美女久久 | 美女在线黄 | 国产精品久久久久av福利动漫 | 在线观看亚洲免费视频 | 久久久精品成人 | 久久亚洲欧美 | 男女激情片在线观看 | 日韩一区在线免费观看 | 99视频在线精品免费观看2 | 免费成人在线网站 | 亚洲综合黄色 | 黄色软件在线观看免费 | 808电影免费观看三年 | 99久久99久久综合 | 中文一区在线 | 国产精品不卡在线观看 | 夜夜爱av| 欧美日韩国产一区 | www.天天射 | 天天做日日做天天爽视频免费 | 午夜色影院 | 日韩午夜电影网 | 欧美资源在线观看 | 亚洲成人二区 | 午夜精品剧场 | 欧美激情综合色综合啪啪五月 | 97色在线观看免费视频 | 91av网址 | 91免费高清视频 | 欧美日韩免费观看一区=区三区 | 成人禁用看黄a在线 | 免费色网 | 成人一区影院 | 国产一级二级av | 啪啪小视频网站 |