午夜视频免费看_日韩三级电影网站_国产精品久久一级_亚洲一级在线播放_人妻体内射精一区二区三区_91夜夜揉人人捏人人添红杏_91福利在线导航_国产又粗又猛又黄又爽无遮挡_欧美日韩一区在线播放_中文字幕一区二区三区四区不卡 _日日夜夜精品视频免费观看_欧美韩日一区二区三区

主頁 > 知識庫 > pytorch教程resnet.py的實現文件源碼分析

pytorch教程resnet.py的實現文件源碼分析

熱門標簽:獲客智能電銷機器人 不錯的400電話辦理 徐州天音防封電銷卡 佛山防封外呼系統收費 南昌辦理400電話怎么安裝 鄭州智能外呼系統運營商 湛江電銷防封卡 哈爾濱外呼系統代理商 電話機器人適用業務

調用pytorch內置的模型的方法

import torchvision
model = torchvision.models.resnet50(pretrained=True)

這樣就導入了resnet50的預訓練模型了。如果只需要網絡結構,不需要用預訓練模型的參數來初始化

那么就是:

model = torchvision.models.resnet50(pretrained=False)

如果要導入densenet模型也是同樣的道理

比如導入densenet169,且不需要是預訓練的模型:

model = torchvision.models.densenet169(pretrained=False)

由于pretrained參數默認是False,所以等價于:

model = torchvision.models.densenet169()

不過為了代碼清晰,最好還是加上參數賦值。

解讀模型源碼Resnet.py

包含的庫文件

import torch.nn as nn
import math
import torch.utils.model_zoo as model_zoo

該庫定義了6種Resnet的網絡結構

包括

__all__ = ['ResNet', 'resnet18', 'resnet34', 'resnet50',  'resnet101',  'resnet152']

每種網絡都有訓練好的可以直接用的.pth參數文件

__all__ = ['ResNet', 'resnet18', 'resnet34', 'resnet50',  'resnet101',  'resnet152']

Resnet中大多使用3*3的卷積定義如下

def conv3x3(in_planes, out_planes, stride=1):   
"""3x3 convolution with padding"""   
return nn.Conv2d(in_planes, out_planes, kernel_size=3, 
stride=stride, padding=1, bias=False)

該函數繼承自nn網絡中的2維卷積,這樣做主要是為了方便,少寫參數參數由原來的6個變成了3個

輸出圖與輸入圖長寬保持一致

如何定義不同大小的Resnet網絡

Resnet類是一個基類,
所謂的"Resnet18", ‘resnet34', ‘resnet50', ‘resnet101', 'resnet152'只是Resnet類初始化的時候使用了不同的參數,理論上我們可以根據Resnet類定義任意大小的Resnet網絡
下面先看看這些不同大小的Resnet網絡是如何定義的

定義Resnet18

def resnet18(pretrained=False, **kwargs):  
"""
Constructs a ResNet-18 model.    
Args:    
pretrained (bool):If True, returns a model pre-trained on ImageNet   
"""    
model = ResNet(BasicBlock, [2, 2, 2, 2], **kwargs)    
if pretrained:        
    model.load_state_dict(model_zoo.load_url(model_urls['resnet18']))   
 return model

定義Resnet34

def resnet34(pretrained=False, **kwargs):    
"""Constructs a ResNet-34 model.   
Args:        pretrained (bool): If True, returns a model pre-trained on ImageNet    """   
model = ResNet(BasicBlock, [3, 4, 6, 3], **kwargs)  
if pretrained:        
    model.load_state_dict(model_zoo.load_url(model_urls['resnet34']))    
 return model

我們發現Resnet18和Resnet34的定義幾乎是一樣的,下面我們把Resnet18,Resnet34,Resnet50,Resnet101,Resnet152,不一樣的部分寫在一塊進行對比

model = ResNet(BasicBlock, [2, 2, 2, 2], **kwargs)    #Resnet18
model = ResNet(BasicBlock, [3, 4, 6, 3], **kwargs)    #Resnet34
model = ResNet(Bottleneck, [3, 4, 6, 3], **kwargs)    #Eesnt50
model = ResNet(Bottleneck, [3, 4, 23, 3], **kwargs)  #Resnet101
model = ResNet(Bottleneck, [3, 8, 36, 3], **kwargs)  #Resnet152

代碼看起來非常的簡潔工整,

其他resnet18、resnet101等函數和resnet18基本類似,差別主要是在:

1、構建網絡結構的時候block的參數不一樣,比如resnet18中是[2, 2, 2, 2],resnet101中是[3, 4, 23, 3]。

2、調用的block類不一樣,比如在resnet50、resnet101、resnet152中調用的是Bottleneck類,而在resnet18和resnet34中調用的是BasicBlock類,這兩個類的區別主要是在residual結果中卷積層的數量不同,這個是和網絡結構相關的,后面會詳細介紹。

3、如果下載預訓練模型的話,model_urls字典的鍵不一樣,對應不同的預訓練模型。因此接下來分別看看如何構建網絡結構和如何導入預訓練模型。

Resnet類

構建ResNet網絡是通過ResNet這個類進行的。ResNet類是繼承PyTorch中網絡的基類:torch.nn.Module。

構建Resnet類主要在于重寫 init() forward() 方法。

我們構建的所有網絡比如:VGG,Alexnet等都需要重寫這兩個方法,這兩個方法很重要

看起來Resne類是整個文檔的核心

下面我們就要研究一下Resnet基類是如何實現的

Resnet類采用了pytorch定義網絡模型的標準結構,包含

iinit()方法: 定義了網絡的各個層
forward()方法: 定義了前向傳播過程

這兩個方法的用法,這個可以查看pytorch的官方文檔就可以明白

在Resnet類中,還包含一個自定義的方法make_layer()方法

是用來構建ResNet網絡中的4個blocks

_make_layer方法的第一個輸入block是BottleneckBasicBlock

第二個輸入是該blocks的輸出channel

第三個輸入是每個blocks中包含多少個residual子結構,因此layers這個列表就是前面resnet50的[3, 4, 6, 3]。

_make_layer方法中比較重要的兩行代碼是:

layers.append(block(self.inplanes, planes, stride, downsample))

該部分是將每個blocks的第一個residual結構保存在layers列表中。

 for i in range(1, blocks): layers.append(block(self.inplanes, planes))

該部分是將每個blocks的剩下residual 結構保存在layers列表中,這樣就完成了一個blocks的構造。這兩行代碼中都是通過Bottleneck這個類來完成每個residual的構建

接下來介紹Bottleneck類

class ResNet(nn.Module):
    def __init__(self, block, layers, num_classes=1000):
        self.inplanes = 64
        super(ResNet, self).__init__()
        self.conv1 = nn.Conv2d(3, 64, kernel_size=7, stride=2, padding=3,
                               bias=False)
        self.bn1 = nn.BatchNorm2d(64)
        self.relu = nn.ReLU(inplace=True)
        self.maxpool = nn.MaxPool2d(kernel_size=3, stride=2, padding=1)
        self.layer1 = self._make_layer(block, 64, layers[0])
        self.layer2 = self._make_layer(block, 128, layers[1], stride=2)
        self.layer3 = self._make_layer(block, 256, layers[2], stride=2)
        self.layer4 = self._make_layer(block, 512, layers[3], stride=2)
        self.avgpool = nn.AvgPool2d(7, stride=1)
        self.fc = nn.Linear(512 * block.expansion, num_classes)
        for m in self.modules():
            if isinstance(m, nn.Conv2d):
                n = m.kernel_size[0] * m.kernel_size[1] * m.out_channels
                m.weight.data.normal_(0, math.sqrt(2. / n))
            elif isinstance(m, nn.BatchNorm2d):
                m.weight.data.fill_(1)
                m.bias.data.zero_()
    def _make_layer(self, block, planes, blocks, stride=1):
        downsample = None
        if stride != 1 or self.inplanes != planes * block.expansion:
            downsample = nn.Sequential(
                nn.Conv2d(self.inplanes, planes * block.expansion,
                          kernel_size=1, stride=stride, bias=False),
                nn.BatchNorm2d(planes * block.expansion),
            )
        layers = []
        layers.append(block(self.inplanes, planes, stride, downsample))
        self.inplanes = planes * block.expansion
        for i in range(1, blocks):
            layers.append(block(self.inplanes, planes))
        return nn.Sequential(*layers)
    def forward(self, x):
        x = self.conv1(x)
        x = self.bn1(x)
        x = self.relu(x)
        x = self.maxpool(x)
        x = self.layer1(x)
        x = self.layer2(x)
        x = self.layer3(x)
        x = self.layer4(x)
        x = self.avgpool(x)
        x = x.view(x.size(0), -1)
        x = self.fc(x)
        return x

下面我們分別看看這兩個過程:

網絡的forward過程

 def forward(self, x):                                #x代表輸入
        x = self.conv1(x)                             #進過卷積層1
        x = self.bn1(x)                                #bn1層
        x = self.relu(x)                                #relu激活
        x = self.maxpool(x)                         #最大池化
        x = self.layer1(x)                            #卷積塊1
        x = self.layer2(x)                           #卷積塊2
        x = self.layer3(x)                          #卷積塊3
        x = self.layer4(x)                          #卷積塊4
        x = self.avgpool(x)                     #平均池化
        x = x.view(x.size(0), -1)               #二維變成變成一維向量
        x = self.fc(x)                             #全連接層
        return x

里面的大部分我們都可以理解,只有layer1-layer4是Resnet網絡自己定義的,
它也是Resnet殘差連接的精髓所在,我們來分析一下layer層是怎么實現的

殘差Block連接是如何實現的

從前面的ResNet類可以看出,在構造ResNet網絡的時候,最重要的是 BasicBlock這個類,因為ResNet是由residual結構組成的,而 BasicBlock類就是完成residual結構的構建。同樣 BasicBlock還是繼承了torch.nn.Module類,且重寫了__init__()和forward()方法。從forward方法可以看出,bottleneck就是我們熟悉的3個主要的卷積層、BN層和激活層,最后的out += residual就是element-wise add的操作。

這部分在 BasicBlock類中實現,我們看看這層是如何前向傳播的

def forward(self, x):
        residual = x
        out = self.conv1(x)
        out = self.bn1(out)
        out = self.relu(out)
        out = self.conv2(out)
        out = self.bn2(out)
        if self.downsample is not None:
            residual = self.downsample(x)
        out += residual
        out = self.relu(out)
        return out

我畫個流程圖來表示一下

畫的比較丑,不過基本意思在里面了,

根據論文的描述,x是否需要下采樣由x與out是否大小一樣決定,

假如進過conv2和bn2后的結果我們稱之為 P

假設x的大小為wHchannel1

如果P的大小也是wHchannel1

則無需下采樣
out = relu(P + X)
out的大小為W * H *(channel1+channel2),

如果P的大小是W/2 * H/2 * channel

則X需要下采樣后才能與P相加,
out = relu(P+ X下采樣)
out的大小為W/2 * H/2 * (channel1+channel2)

BasicBlock類和Bottleneck類類似,前者主要是用來構建ResNet18和ResNet34網絡,因為這兩個網絡的residual結構只包含兩個卷積層,沒有Bottleneck類中的bottleneck概念。因此在該類中,第一個卷積層采用的是kernel_size=3的卷積,就是我們之前提到的conv3x3函數。

下面是BasicBlock類的完整代碼

class BasicBlock(nn.Module):
    expansion = 1
    def __init__(self, inplanes, planes, stride=1, downsample=None):
        super(BasicBlock, self).__init__()
        self.conv1 = conv3x3(inplanes, planes, stride)
        self.bn1 = nn.BatchNorm2d(planes)
        self.relu = nn.ReLU(inplace=True)
        self.conv2 = conv3x3(planes, planes)
        self.bn2 = nn.BatchNorm2d(planes)
        self.downsample = downsample
        self.stride = stride
    def forward(self, x):
        residual = x
        out = self.conv1(x)
        out = self.bn1(out)
        out = self.relu(out)
        out = self.conv2(out)
        out = self.bn2(out)
        if self.downsample is not None:
            residual = self.downsample(x)
        out += residual
        out = self.relu(out)
        return out

以上就是pytorch教程resnet.py的實現文件源碼解讀的詳細內容,更多關于pytorch源碼解讀的資料請關注腳本之家其它相關文章!

您可能感興趣的文章:
  • PyTorch實現ResNet50、ResNet101和ResNet152示例
  • Keras實現DenseNet結構操作
  • 關于Keras Dense層整理
  • Python機器學習從ResNet到DenseNet示例詳解

標簽:安康 蕪湖 呂梁 吉安 廣西 紹興 懷化 蘭州

巨人網絡通訊聲明:本文標題《pytorch教程resnet.py的實現文件源碼分析》,本文關鍵詞  pytorch,教程,resnet.py,的,實現,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《pytorch教程resnet.py的實現文件源碼分析》相關的同類信息!
  • 本頁收集關于pytorch教程resnet.py的實現文件源碼分析的相關信息資訊供網民參考!
  • 推薦文章
    国产精品污视频| 97视频在线观看网址| 久久久成人网| 日韩亚洲欧美中文字幕| 精品免费一区二区三区蜜桃| 久久久成人精品视频| 欧洲精品一区二区| 国产偷v国产偷v亚洲高清| 日韩黄色影视| 欧日韩不卡在线视频| 精品国产3级a| 精品久久久久久亚洲国产300 | 夜夜狠狠擅视频| 久久99精品久久久久久久久久| 精品对白一区国产伦| 久久久www成人免费毛片麻豆| 色综合久久久无码中文字幕波多| 97精品国产97久久久久久久久久久久| 欧美aaa级片| 亚洲图片都市激情| 5278欧美一区二区三区| 精品电影一区二区三区| 亚洲欧美综合在线精品| 亚洲精品一区二区口爆| 波多野结衣加勒比| 国产精品免费一区二区三区在线观看 | 色综合久久久888| 欧美性高清videossexo| 99久久久无码国产精品| 日韩在线 中文字幕| 97超碰免费在线观看| www.在线观看av| 国产精品91久久久久久| 亚洲欧美一区二区三区久久| 亚洲无人区一区| 91偷拍与自偷拍精品| 久久最新视频| 黄色片网站在线免费观看| 97人妻精品一区二区三区免| 亚洲激情在线观看视频| 国产人妻人伦精品| 91精品久久久久久久久不口人| 亚洲精品日韩欧美| 欧美三级资源在线| 伊人开心综合网| 91在线免费视频观看| 狠狠v欧美v日韩v亚洲ⅴ| 久久久xxx| h狠狠躁死你h高h| 欧美卡一卡二卡三| 快灬快灬一下爽蜜桃在线观看| 九九热精品在线播放| 欧美一级视频在线播放| 日韩三级电影免费观看| 精品日本一区二区| 成人欧美一区二区| 青青草精品毛片| 亚洲精品国精品久久99热一| 九九热这里只有在线精品视| 日韩h在线观看| 色欧美日韩亚洲| 一区二区三区四区在线| 国产精品久久网站| 中文字幕不卡一区| 欧美国产欧美亚州国产日韩mv天天看完整| 卡一卡二国产精品| 久久一日本道色综合久久| 亚洲男女视频在线观看| 人妻一区二区三区四区| 国产浮力第一页| 激情综合网五月天| 永久免费未满蜜桃| 亚洲国产一二三精品无码| 国产精品视频久久久| 在线性视频日韩欧美| 欧美一区二区三区视频在线| 亚洲国产一区二区三区青草影视| 成人av影院在线| 免费日本视频一区| 亚洲国产精品一| 日韩欧美高清在线观看| 欧美高清视频一区二区三区| 国产成人综合在线| 亚洲成人久久一区| 日本老师69xxx| 无码内射中文字幕岛国片| 欧美偷拍一区二区三区| 特级毛片www| 国产91精品一区| 日本一区二区成人| 欧美日韩国产天堂| 国产做受高潮69| 国产精品三级美女白浆呻吟| 91免费欧美精品| 国产成人精品一区二区在线| 特级西西444www大精品视频| 中文字幕第22页| www,av在线| 超碰男人的天堂| 一区二区三区伦理片| 免费人成又黄又爽又色| 破处女黄色一级片| 日产欧产va高清| 日韩久久精品视频| www.久久视频| 亚洲男人第一av| 区一区二在线观看| 国产麻豆免费观看| 国产一区欧美一区| 久久久99精品久久| 午夜精品久久久久久久久久 | 欧美黑人性视频| 国产精品久久久久77777| 久久精品毛片| 精品处破学生在线二十三| www.毛片.com| 91丨国产丨九色丨pron| 国产精品理伦片| 日韩一区二区三区视频在线 | 一区二区三区不卡视频| 久久久久久成人精品| 亚洲熟妇av一区二区三区| 精品99在线观看| 91丨porny丨首页| 亚洲欧美日韩精品| 国产成人精品无码播放| 四虎永久在线精品免费网址| 亚洲国产精彩中文乱码av在线播放| 久久久久久久久久久一区| 制服 丝袜 综合 日韩 欧美| 久久一区二区视频| 日韩色av导航| 精品人妻一区二区乱码| 粉嫩绯色av一区二区在线观看| 欧美精品少妇videofree| 成人在线免费观看av| 一级黄色a视频| 精品乱码亚洲一区二区不卡| 国产精品沙发午睡系列| 中文字幕在线观看第二页| 日韩一区二区三| 欧美精品七区| 国产精品国产三级国产aⅴ9色| 日韩中文字幕免费视频| 免费人成在线观看视频播放| 日韩美一区二区| 黄网动漫久久久| 成人看片视频| 日韩黄色片网站| 日韩一区二区三区精品视频| 欧美女人性生活视频| 五月天婷婷在线观看| xxxxx91麻豆| 999精品免费视频| 亚洲视频在线一区| 日本在线播放一区| 黄色av小说在线观看| 久久av中文字幕| 奇米网一区二区| 亚洲精品中文字幕乱码三区| 日韩aⅴ视频一区二区三区| 黄色美女一级片| 最近免费中文字幕视频2019 | 欧美亚洲成人网| 日韩高清dvd碟片| 在线不卡免费欧美| 欧美xxxxxbbbbb| 999精品网站| 日韩精品电影在线观看| 国产亚洲一区精品| 国产一二三四五区| 欧美理论电影在线| 不用播放器的免费av| 亚洲第一狼人社区| 日韩一级在线免费观看| 亚洲视频免费在线观看| 国产精品无码免费专区午夜| 99在线精品免费| 亚洲成人一区二区三区| jlzzjlzz亚洲日本少妇| 一区二区视频在线播放| 久久综合av免费| 一区二区精品国产| 91丝袜国产在线播放| 欧美成人午夜激情视频| 中文字幕在线观看视频www| 一区二区激情小说| 熟女少妇精品一区二区| 玉足女爽爽91| 精品久久久久久久免费人妻| 中文字幕亚洲在| avav在线播放| 欧美韩国日本不卡| 激情五月六月婷婷| 国产精品免费av| 九九九九免费视频| 亚洲综合自拍偷拍| 国产激情在线观看视频| 亚洲国产综合在线| 三级一区二区三区| 色婷婷精品大视频在线蜜桃视频| 日本中文字幕精品—区二区| 欧美日韩在线视频一区二区| 日韩欧美中文在线视频| 欧美精品自拍偷拍动漫精品| 亚洲自拍第二页| 性欧美xxxx视频在线观看| 精品成人免费视频| 中文字幕不卡av| 91精品国产乱码在线观看| 亚洲精品一区二区在线| 性生交大片免费全黄| 中日韩美女免费视频网站在线观看| 少妇熟女视频一区二区三区 | 久久久久久久av麻豆果冻| 阿v天堂2017| 椎名由奈av一区二区三区| 日韩不卡一二区| 一区二区三区在线高清| 扒开伸进免费视频| 日韩天堂在线观看| 青青草原免费观看| 日韩免费av一区二区| 青娱乐精品视频在线| 好吊色欧美一区二区三区视频 | 在线视频一区二区免费| 欧美成人短视频| 色综合久久悠悠| 久久综合婷婷| 中文字幕av导航| 欧美午夜视频在线观看| 人妻无码一区二区三区免费| 欧美精品videosex性欧美| 午夜影院免费视频| 国产日本欧美在线| 一区二区欧美视频| 免费一级特黄3大片视频| 久久久噜噜噜久久中文字免| 99在线精品视频免费观看20| 看欧美日韩国产| 久久综合色综合88| 午夜影院免费版| 色婷婷av一区二区三区在线观看 | 免费看av软件| 欧美综合久久久| 欧美成人aaa片一区国产精品| 国产美女扒开尿口久久久| 91免费看`日韩一区二区| 午夜免费视频网站| 免费av一区二区| 午夜精产品一区二区在线观看的| 一本色道久久综合狠狠躁的推荐| 中国美女乱淫免费看视频| 国产一区二区日韩精品欧美精品| 肥臀熟女一区二区三区| 欧美激情专区| 亚洲午夜久久久久久久久电影院 | 亚洲片av在线| 日韩精品免费专区| 精品91一区二区三区| 欧美一区二区三区公司| 人人干人人干人人干| 51国偷自产一区二区三区| 亚洲综合一二区| 国产精品第二十页| 欧美精品一区二区三区四区五区 | 九九视频免费在线观看| 国产精品成人v| 亚洲精选视频免费看| 国产盗摄一区二区三区在线| 国产精品久久久一区二区三区| 黄色成人av在线| 在线观看免费国产视频| 国产欧美亚洲日本| 欧美日韩三级在线| 欧美熟妇另类久久久久久不卡 | 亚洲成人精品在线播放| 日韩av电影免费观看高清| 欧美极品少妇xxxxⅹ高跟鞋 | 热久久最新地址| 日韩欧美国产wwwww| 日本不卡视频在线观看| 日本免费观看网站| 日韩视频一区在线| 毛片一区二区三区| 手机免费av片| 国产成人精品在线播放| 亚洲444eee在线观看| 美日韩一二三区| 综合久久国产| 亚洲精品久久久一区二区三区| 国产综合色在线| 国产精品伦子伦| 精品久久精品久久| 欧美日韩国产综合久久| 人人妻人人玩人人澡人人爽| 国产精品欧美激情在线观看 | 亚洲综合男人的天堂| 久久9999久久免费精品国产| 日韩电影天堂视频一区二区| 欧美一级高清片在线观看| 日韩av在线播放中文字幕| 无码精品一区二区三区在线播放| 国产精品二区在线观看| 日韩欧美一区二区不卡| 福利一区福利二区| 国产一级视频在线观看| 亚洲va韩国va欧美va精四季| 久久九九免费视频| 亚洲男人的天堂网| 伊人久久综合视频| 毛片在线视频观看| 51午夜精品视频| 精品视频在线免费看| 大白屁股一区二区视频| 天堂中文在线网| 日本一本二本在线观看| 欧美亚洲在线视频| 色综合咪咪久久| 国产麻豆精品theporn| 日本一二三区不卡| 女人被男人躁得好爽免费视频| 欧美伦理91i| 色综合久久综合网| 国产精品乡下勾搭老头1| 黄色三级生活片| 久久精品二区| 久久久久久久久久久91| 欧美成人欧美edvon| 亚洲国产裸拍裸体视频在线观看乱了 | 精品亚洲一区二区三区在线观看| 亚洲色图欧洲色图婷婷| 精品中文字幕一区二区| 一区二区三区免费在线视频| 九九热久久免费视频| 中文字幕精品一区二区三区在线| 一区二区三区四区五区视频| 国产日韩欧美视频在线| 精品国产欧美一区二区三区成人| 宅男噜噜噜66一区二区66| 亚洲精品欧美专区| www.成人在线| 蜜桃av一区二区在线观看| 国产情侣av在线| 波多野结衣视频网站| 国产又粗又猛又爽又黄的视频小说| 视频免费1区二区三区| 国内精品国产三级国产99| 久久久婷婷一区二区三区不卡| 国产成人综合久久| 久久成年人免费电影| 亚洲大胆人体在线| 精品久久久久久久久中文字幕| 国产欧美一区二区精品仙草咪| 国内精品免费在线观看| 欧美熟妇另类久久久久久不卡| 中文在线最新版天堂| 国产午夜视频在线| 亚洲欧美国产毛片在线| 国产亚洲精品久久久久久无几年桃 | 色婷婷av一区二区三区之红樱桃 | 制服丝袜成人动漫| 欧美日韩国产综合新一区| 亚洲欧美日韩在线| 久久精品日韩一区二区三区| 国产99一区视频免费| 精品综合免费视频观看| 日韩电影在线看| 日韩精彩视频在线观看| 国产91久久久| 久久国产日本精品| 丰满人妻一区二区三区免费| 一道本无吗一区| www.黄色国产| 污视频网站免费观看| 日韩高清中文字幕一区| 韩国毛片一区二区三区| 精久久久久久久久久久| 久久精品理论片| 蜜臀av性久久久久蜜臀aⅴ| 国产在线xxxx| 91在线国产电影| 国产精品永久免费在线| 成人久久一区二区| 91在线色戒在线| 国产精品伊人日日| 欧美午夜欧美| 国产系列第一页| 在线观看国产一区| 亚洲小视频在线播放| 免费超爽大片黄| 中文字幕第21页| 伊人久久久久久久久| 国产在线观看无码免费视频| 大地资源二中文在线影视观看 | 国产三级欧美三级| 成人一区在线看| 成人h动漫精品一区二| 久久女同精品一区二区| 一区二区中文字幕在线| 亚洲成人1区2区| 欧美高清视频在线高清观看mv色露露十八| 日韩你懂的电影在线观看| 中文字幕最新精品| 国产ts一区二区| 欧美日韩在线精品| 国产亚洲欧美在线视频| 成人性生活免费看| 亚洲精品男人的天堂| 久久尤物视频|