亭亭五月天在线观看,亭亭五月天在线观看,国产最新av一区二区,国产 高清 中文字幕,99re热久久亚洲综合精品成人,熟妇 一区二区三区,一级做a爰片性色毛片武则天,美女的骚穴视频播放,国产美女午夜免费视频

首頁>國內(nèi) > 正文

環(huán)球觀察:醫(yī)學(xué)圖像的深度學(xué)習(xí)的完整代碼示例:使用Pytorch對MRI腦掃描的圖像進行分割

2023-05-05 11:16:47來源:DeepHub IMBA

圖像分割是醫(yī)學(xué)圖像分析中最重要的任務(wù)之一,在許多臨床應(yīng)用中往往是第一步也是最關(guān)鍵的一步。在腦MRI分析中,圖像分割通常用于測量和可視化解剖結(jié)構(gòu),分析大腦變化,描繪病理區(qū)域以及手術(shù)計劃和圖像引導(dǎo)干預(yù),分割是大多數(shù)形態(tài)學(xué)分析的先決條件。


(相關(guān)資料圖)

本文我們將介紹如何使用QuickNAT對人腦的圖像進行分割。使用MONAI, PyTorch和用于數(shù)據(jù)可視化和計算的常見Python庫,如NumPy, TorchIO和matplotlib。

本文將主要設(shè)計以下幾個方面:

設(shè)置數(shù)據(jù)集和探索數(shù)據(jù)處理和準備數(shù)據(jù)集適當(dāng)?shù)哪P陀?xùn)練創(chuàng)建一個訓(xùn)練循環(huán)評估模型并分析結(jié)果

完整的代碼會在本文最后提供。

設(shè)置數(shù)據(jù)目錄

使用MONAI的第一步是設(shè)置MONAI_DATA_DIRECTORY環(huán)境變量指定目錄,如果未指定將使用臨時目錄。

directory = os.environ.get("MONAI_DATA_DIRECTORY") root_dir = tempfile.mkdtemp() if directory is None else directory print(root_dir)
設(shè)置數(shù)據(jù)集

將CNN模型擴展到大腦分割的主要挑戰(zhàn)之一是人工注釋的訓(xùn)練數(shù)據(jù)的有限性。作者引入了一種新的訓(xùn)練策略,利用沒有手動標(biāo)簽的大型數(shù)據(jù)集和有手動標(biāo)簽的小型數(shù)據(jù)集。

首先,使用現(xiàn)有的軟件工具(例如FreeSurfer)從大型未標(biāo)記數(shù)據(jù)集中獲得自動生成的分割,然后使用這些工具對網(wǎng)絡(luò)進行預(yù)訓(xùn)練。在第二步中,使用更小的手動注釋數(shù)據(jù)[2]對網(wǎng)絡(luò)進行微調(diào)。

IXI數(shù)據(jù)集由581個健康受試者的未標(biāo)記MRI T1掃描組成。這些數(shù)據(jù)是從倫敦3家不同的醫(yī)院收集來的。使用該數(shù)據(jù)集的主要缺點是標(biāo)簽不是公開可用的,因此為了遵循與研究論文中相同的方法,本文將使用FreeSurfer為這些MRI T1掃描生成分割。

FreeSurfer是一個用于分析和可視化結(jié)構(gòu)的軟件包。下載和安裝說明可以在這里找到??梢灾苯邮褂昧恕皉econ-all”命令來執(zhí)行所有皮層重建過程。

盡管FreeSurfer是一個非常有用的工具,可以利用大量未標(biāo)記的數(shù)據(jù),并以監(jiān)督的方式訓(xùn)練網(wǎng)絡(luò),但是掃描生成這些標(biāo)簽需要長達5個小時,所以我們這里直接使用OASIS數(shù)據(jù)集來訓(xùn)練模型,OASIS數(shù)據(jù)集是一個較小的數(shù)據(jù)集,具有公開可用的手動注釋。

OASIS是一個向科學(xué)界免費提供大腦神經(jīng)成像數(shù)據(jù)集的項目。OASIS-1是由39個受試者的橫斷面組成的數(shù)據(jù)集,獲取方式如下:

resource = "https://download.nrg.wustl.edu/data/oasis_cross-sectional_disc1.tar.gz" md5 = "c83e216ef8654a7cc9e2a30a4cdbe0cc"  compressed_file = os.path.join(root_dir, "oasis_cross-sectional_disc1.tar.gz") data_dir = os.path.join(root_dir, "Oasis_Data") if not os.path.exists(data_dir):     download_and_extract(resource, compressed_file, data_dir, md5)
數(shù)據(jù)探索

如果你打開" oasis_crosssectional_disc1 .tar.gz ",你會發(fā)現(xiàn)每個主題都有不同的文件夾。例如,對于主題OAS1_0001_MR1,是這樣的:

鏡像數(shù)據(jù)文件路徑:disc1\OAS1_0001_MR1\PROCESSED\MPRAGE\T88_111\ oas1_0001_mr1_mpr_n4_anon_111_t88_masked_ggc .img

標(biāo)簽文件:disc1\OAS1_0001_MR1\FSL_SEG\OAS1_0001_MR1_mpr_n4_anon_111_t88_masked_gfc_fseg.img

數(shù)據(jù)加載和預(yù)處理

下載數(shù)據(jù)集并將其提取到臨時目錄后,需要對其進行重構(gòu),我們希望我們的目錄看起來像這樣:

所以需要按照下面的步驟加載數(shù)據(jù):

將。img文件轉(zhuǎn)換為。nii文件并保存到新文件夾中:創(chuàng)建兩個新文件夾。Oasis_Data_Processed包括每個受試者的處理過的MRI T1掃描,Oasis_Labels_Processed包括相應(yīng)的標(biāo)簽。

new_path_data= root_dir + "/Oasis_Data_Processed/" if not os.path.exists(new_path_data):   os.makedirs(new_path_data)  new_path_labels= root_dir + "/Oasis_Labels_Processed/" if not os.path.exists(new_path_labels):   os.makedirs(new_path_labels)

然后就是對其進行操作:

for i in [x for x in range(1, 43) if x != 8 and x != 24 and x != 36]:   if i < 7 or i == 9:     filename = root_dir + "/Oasis_Data/disc1/OAS1_000"+ str(i) + "_MR1/PROCESSED/MPRAGE/T88_111/OAS1_000" + str(i) + "_MR1_mpr_n4_anon_111_t88_masked_gfc.img"   elif i == 7:     filename = root_dir + "/Oasis_Data/disc1/OAS1_000"+ str(i) + "_MR1/PROCESSED/MPRAGE/T88_111/OAS1_000" + str(i) + "_MR1_mpr_n3_anon_111_t88_masked_gfc.img"   elif i==15 or i==16 or i==20 or i==24 or i==26 or i==34 or i==38 or i==39:     filename = root_dir + "/Oasis_Data/disc1/OAS1_00"+ str(i) + "_MR1/PROCESSED/MPRAGE/T88_111/OAS1_00" + str(i) + "_MR1_mpr_n3_anon_111_t88_masked_gfc.img"   else:     filename = root_dir + "/Oasis_Data/disc1/OAS1_00"+ str(i) + "_MR1/PROCESSED/MPRAGE/T88_111/OAS1_00" + str(i) + "_MR1_mpr_n4_anon_111_t88_masked_gfc.img"   img = nib.load(filename)   nib.save(img, filename.replace(".img", ".nii"))   i = i+1

具體代碼就不再粘貼了,有興趣的看看最后的完整代碼。下一步就是讀取圖像和標(biāo)簽文件名

image_files = sorted(glob(os.path.join(root_dir + "/Oasis_Data_Processed", "*.nii"))) label_files = sorted(glob(os.path.join(root_dir + "/Oasis_Labels_Processed", "*.nii"))) files = [{"image": image_name, "label": label_name} for image_name, label_name in zip(image_files, label_files)]

為了可視化帶有相應(yīng)標(biāo)簽的圖像,可以使用TorchIO,這是一個Python庫,用于深度學(xué)習(xí)中多維醫(yī)學(xué)圖像的加載、預(yù)處理、增強和采樣。

image_filename = root_dir + "/Oasis_Data_Processed/OAS1_0001_MR1_mpr_n4_anon_111_t88_masked_gfc.nii" label_filename = root_dir + "/Oasis_Labels_Processed/OAS1_0001_MR1_mpr_n4_anon_111_t88_masked_gfc_fseg.nii" subject = torchio.Subject(image=torchio.ScalarImage(image_filename), label=torchio.LabelMap(label_filename)) subject.plot()

下面就是將數(shù)據(jù)分成3部分——訓(xùn)練、驗證和測試。將數(shù)據(jù)分成三個不同的類別的目的是建立一個可靠的機器學(xué)習(xí)模型,避免過擬合。

我們將整個數(shù)據(jù)集分成三個部分:

Train: 80%,Validation: 10%,Test: 10%

train_inds, val_inds, test_inds = partition_dataset(data = np.arange(len(files)), ratios = [8, 1, 1], shuffle = True)  train = [files[i] for i in sorted(train_inds)] val = [files[i] for i in sorted(val_inds)] test = [files[i] for i in sorted(test_inds)]  print(f"Training count: {len(train)}, Validation count: {len(val)}, Test count: {len(test)}")

因為模型需要的是二維切片,所以將每個切片保存在不同的文件夾中,如下圖所示。這兩個代碼單元將訓(xùn)練集的每個MRI體積的切片保存為“.png”格式。

Save coronal slices for training images dir = root_dir + "/TrainData" os.makedirs(os.path.join(dir, "Coronal")) path = root_dir + "/TrainData/Coronal/"  for file in sorted(glob(os.path.join(root_dir + "/TrainData", "*.nii"))):   image=torchio.ScalarImage(file)   data = image.data   filename = os.path.basename(file)   filename = os.path.splitext(filename)   for i in range(0, 208):     slice = data[0, :, i]     array = slice.numpy()     data_dir = root_dir + "/TrainData/Coronal/" + filename[0] + "_slice" + str(i) + ".png"     plt.imsave(fname = data_dir, arr = array, format = "png", cmap = plt.cm.gray)

同理,下面是保存標(biāo)簽:

dir = root_dir + "/TrainLabels" os.makedirs(os.path.join(dir, "Coronal")) path = root_dir + "/TrainLabels/Coronal/"  for file in sorted(glob(os.path.join(root_dir + "/TrainLabels", "*.nii"))):   label = torchio.LabelMap(file)   data = label.data   filename = os.path.basename(file)   filename = os.path.splitext(filename)   for i in range(0, 208):     slice = data[0, :, i]     array = slice.numpy()     data_dir = root_dir + "/TrainLabels/Coronal/" + filename[0] + "_slice" + str(i) + ".png"     plt.imsave(fname = data_dir, arr = array, format = "png")
為訓(xùn)練和驗證定義圖像的變換處理

在本例中,我們將使用Dictionary Transforms,其中數(shù)據(jù)是Python字典。

train_images_coronal = [] for file in sorted(glob(os.path.join(root_dir + "/TrainData/Coronal", "*.png"))):   train_images_coronal.append(file) train_images_coronal = natsort.natsorted(train_images_coronal)  train_labels_coronal = [] for file in sorted(glob(os.path.join(root_dir + "/TrainLabels/Coronal", "*.png"))):   train_labels_coronal.append(file) train_labels_coronal= natsort.natsorted(train_labels_coronal)  val_images_coronal = [] for file in sorted(glob(os.path.join(root_dir + "/ValData/Coronal", "*.png"))):   val_images_coronal.append(file) val_images_coronal = natsort.natsorted(val_images_coronal)  val_labels_coronal = [] for file in sorted(glob(os.path.join(root_dir + "/ValLabels/Coronal", "*.png"))):   val_labels_coronal.append(file) val_labels_coronal = natsort.natsorted(val_labels_coronal)  train_files_coronal = [{"image": image_name, "label": label_name} for image_name, label_name in zip(train_images_coronal, train_labels_coronal)] val_files_coronal = [{"image": image_name, "label": label_name} for image_name, label_name in zip(val_images_coronal, val_labels_coronal)]

現(xiàn)在我們將應(yīng)用以下變換:

LoadImaged:加載圖像數(shù)據(jù)和元數(shù)據(jù)。我們使用" PILReader "來加載圖像和標(biāo)簽文件。ensure_channel_first設(shè)置為True,將圖像數(shù)組形狀轉(zhuǎn)換為通道優(yōu)先。

Rotate90d:我們將圖像和標(biāo)簽旋轉(zhuǎn)90度,因為當(dāng)我們下載它們時,它們方向是不正確的。

ToTensord:將輸入的圖像和標(biāo)簽轉(zhuǎn)換為張量。

NormalizeIntensityd:對輸入進行規(guī)范化。

train_transforms = Compose(      [         LoadImaged(keys = ["image", "label"], reader=PILReader(converter=lambda image: image.convert("L")), ensure_channel_first = True),         Rotate90d(keys = ["image", "label"], k = 2),         ToTensord(keys = ["image", "label"]),         NormalizeIntensityd(keys = ["image"])      ]  )  val_transforms = Compose(      [         LoadImaged(keys = ["image", "label"], reader=PILReader(converter=lambda image: image.convert("L")), ensure_channel_first = True),         Rotate90d(keys = ["image", "label"], k = 2),         ToTensord(keys = ["image", "label"]),         NormalizeIntensityd(keys = ["image"])      ]  )

MaskColorMap將我們定義了一個新的轉(zhuǎn)換,將相應(yīng)的像素值以一種格式映射為多個標(biāo)簽。這種轉(zhuǎn)換在語義分割中是必不可少的,因為我們必須為每個可能的類別提供二元特征。One-Hot Encoding將對應(yīng)于原始類別的每個樣本的特征賦值為1。

因為OASIS-1數(shù)據(jù)集只有3個大腦結(jié)構(gòu)標(biāo)簽,對于更詳細的分割,理想的情況是像他們在研究論文中那樣對28個皮質(zhì)結(jié)構(gòu)進行注釋。在OASIS-1下載說明中,可以找到使用FreeSurfer獲得的更多大腦結(jié)構(gòu)的標(biāo)簽。

所以本文將分割更多的神經(jīng)解剖結(jié)構(gòu)。我們要將模型的參數(shù)num_classes修改為相應(yīng)的標(biāo)簽數(shù)量,以便模型的輸出是具有N個通道的特征映射,等于num_classes。

為了簡化本教程,我們將使用以下標(biāo)簽,比OASIS-1但是要比FreeSurfer的少:

Label 0:BackgroundLabel 1:LeftCerebralExteriorLabel 2:LeftWhiteMatterLabel 3:LeftCerebralCortex

所以MaskColorMap的代碼如下:

class MaskColorMap(Enum):    Background = (30)    LeftCerebralExterior = (91)    LeftWhiteMatter = (137)    LeftCerebralCortex = (215)
數(shù)據(jù)集和數(shù)據(jù)加載

數(shù)據(jù)集和數(shù)據(jù)加載器從存儲中提取數(shù)據(jù),并將其分批發(fā)送給訓(xùn)練循環(huán)。這里我們使用monai.data.Dataset加載之前定義的訓(xùn)練和驗證字典,并對輸入數(shù)據(jù)應(yīng)用相應(yīng)的轉(zhuǎn)換。dataloader用于將數(shù)據(jù)集加載到內(nèi)存中。我們將為訓(xùn)練和驗證以及每個視圖定義一個數(shù)據(jù)集和數(shù)據(jù)加載器。

為了方便演示,我們使用通過使用torch.utils.data.Subset,在指定的索引處創(chuàng)建一個子集,只是用部分數(shù)據(jù)訓(xùn)練加快演示速度。

train_dataset_coronal = Dataset(data=train_files_coronal, transform = train_transforms) train_loader_coronal = DataLoader(train_dataset_coronal, batch_size = 1, shuffle = True)  val_dataset_coronal = Dataset(data = val_files_coronal, transform = val_transforms) val_loader_coronal = DataLoader(val_dataset_coronal, batch_size = 1, shuffle = False)  # We will use a subset of the dataset subset_train = list(range(90, len(train_dataset_coronal), 120)) train_dataset_coronal_subset = torch.utils.data.Subset(train_dataset_coronal, subset_train) train_loader_coronal_subset = DataLoader(train_dataset_coronal_subset, batch_size = 1, shuffle = True)  subset_val = list(range(90, len(val_dataset_coronal), 50)) val_dataset_coronal_subset = torch.utils.data.Subset(val_dataset_coronal, subset_val) val_loader_coronal_subset = DataLoader(val_dataset_coronal_subset, batch_size = 1, shuffle = False)
定義模型

給定一組MRI腦掃描I = {I1,…In}及其對應(yīng)的分割S = {S1,…Sn},我們想要學(xué)習(xí)一個函數(shù)fseg: I -> S。我們將這個函數(shù)表示為F-CNN模型,稱為QuickNAT:

QuickNAT由三個二維f - cnn組成,分別在coronal, axial, sagittal視圖上操作,然后通過聚合步驟推斷最終的分割結(jié)果,該分割結(jié)果由三個網(wǎng)絡(luò)的概率圖組合而成。每個F-CNN都有一個編碼器/解碼器架構(gòu),其中有4個編碼器和4個解碼器,并由瓶頸層分隔。最后一層是帶有softmax的分類器塊。該架構(gòu)還包括每個編碼器/解碼器塊內(nèi)的殘差鏈接。

class QuickNat(nn.Module):     """    A PyTorch implementation of QuickNAT     """      def __init__(self, params):         """        :param params: {"num_channels":1,                        "num_filters":64,                        "kernel_h":5,                        "kernel_w":5,                        "stride_conv":1,                        "pool":2,                        "stride_pool":2,                        "num_classes":28                        "se_block": False,                        "drop_out":0.2}        """         super(QuickNat, self).__init__()          # from monai.networks.blocks import squeeze_and_excitation as se         # self.cSE = ChannelSELayer(num_channels, reduction_ratio)          # self.encode1 = sm.EncoderBlock(params, se_block_type=se.SELayer.CSSE)         # params["num_channels"] = params["num_filters"]         # self.encode2 = sm.EncoderBlock(params, se_block_type=se.SELayer.CSSE)         # self.encode3 = sm.EncoderBlock(params, se_block_type=se.SELayer.CSSE)         # self.encode4 = sm.EncoderBlock(params, se_block_type=se.SELayer.CSSE)         # self.bottleneck = sm.DenseBlock(params, se_block_type=se.SELayer.CSSE)         # params["num_channels"] = params["num_filters"] * 2         # self.decode1 = sm.DecoderBlock(params, se_block_type=se.SELayer.CSSE)         # self.decode2 = sm.DecoderBlock(params, se_block_type=se.SELayer.CSSE)         # self.decode3 = sm.DecoderBlock(params, se_block_type=se.SELayer.CSSE)         # self.decode4 = sm.DecoderBlock(params, se_block_type=se.SELayer.CSSE)          # self.encode1 = EncoderBlock(params, se_block_type=se.ChannelSELayer)         self.encode1 = EncoderBlock(params, se_block_type=se.SELayer.CSSE)         params["num_channels"] = params["num_filters"]         self.encode2 = EncoderBlock(params, se_block_type=se.SELayer.CSSE)         self.encode3 = EncoderBlock(params, se_block_type=se.SELayer.CSSE)         self.encode4 = EncoderBlock(params, se_block_type=se.SELayer.CSSE)         self.bottleneck = DenseBlock(params, se_block_type=se.SELayer.CSSE)         params["num_channels"] = params["num_filters"] * 2         self.decode1 = DecoderBlock(params, se_block_type=se.SELayer.CSSE)         self.decode2 = DecoderBlock(params, se_block_type=se.SELayer.CSSE)         self.decode3 = DecoderBlock(params, se_block_type=se.SELayer.CSSE)         self.decode4 = DecoderBlock(params, se_block_type=se.SELayer.CSSE)         params["num_channels"] = params["num_filters"]         self.classifier = ClassifierBlock(params)      def forward(self, input):         """        :param input: X        :return: probabiliy map         """          e1, out1, ind1 = self.encode1.forward(input)         e2, out2, ind2 = self.encode2.forward(e1)         e3, out3, ind3 = self.encode3.forward(e2)         e4, out4, ind4 = self.encode4.forward(e3)          bn = self.bottleneck.forward(e4)          d4 = self.decode4.forward(bn, out4, ind4)         d3 = self.decode1.forward(d4, out3, ind3)         d2 = self.decode2.forward(d3, out2, ind2)         d1 = self.decode3.forward(d2, out1, ind1)         prob = self.classifier.forward(d1)          return prob      def enable_test_dropout(self):         """        Enables test time drop out for uncertainity        :return:        """         attr_dict = self.__dict__["_modules"]         for i in range(1, 5):             encode_block, decode_block = (                 attr_dict["encode" + str(i)],                 attr_dict["decode" + str(i)],            )             encode_block.drop_out = encode_block.drop_out.apply(nn.Module.train)             decode_block.drop_out = decode_block.drop_out.apply(nn.Module.train)      @property     def is_cuda(self):         """        Check if model parameters are allocated on the GPU.        """         return next(self.parameters()).is_cuda      def save(self, path):         """        Save model with its parameters to the given path. Conventionally the        path should end with "*.model".         Inputs:        - path: path string        """         print("Saving model... %s" % path)         torch.save(self.state_dict(), path)      def predict(self, X, device=0, enable_dropout=False):         """        Predicts the output after the model is trained.        Inputs:        - X: Volume to be predicted        """         self.eval()         print("tensor size before transformation", X.shape)          if type(X) is np.ndarray:             # X = torch.tensor(X, requires_grad=False).type(torch.FloatTensor)             X = (                 torch.tensor(X, requires_grad=False)                .type(torch.FloatTensor)                .cuda(device, non_blocking=True)            )         elif type(X) is torch.Tensor and not X.is_cuda:             X = X.type(torch.FloatTensor).cuda(device, non_blocking=True)          print("tensor size ", X.shape)          if enable_dropout:             self.enable_test_dropout()          with torch.no_grad():             out = self.forward(X)          max_val, idx = torch.max(out, 1)         idx = idx.data.cpu().numpy()         prediction = np.squeeze(idx)         print("prediction shape", prediction.shape)         del X, out, idx, max_val         return prediction
損失函數(shù)

神經(jīng)網(wǎng)絡(luò)的訓(xùn)練需要一個損失函數(shù)來計算模型誤差。訓(xùn)練的目標(biāo)是最小化預(yù)測輸出和目標(biāo)輸出之間的損失。我們的模型使用Dice Loss 和Weighted Logistic Loss的聯(lián)合損失函數(shù)進行優(yōu)化,其中權(quán)重補償數(shù)據(jù)中的高類不平衡,并鼓勵正確分割解剖邊界。

優(yōu)化器

優(yōu)化算法允許我們繼續(xù)更新模型的參數(shù)并最小化損失函數(shù)的值,我們設(shè)置了以下的超參數(shù):

學(xué)習(xí)率:初始設(shè)置為0.1,10次后降低1階。這可以通過學(xué)習(xí)率調(diào)度器來實現(xiàn)。

權(quán)重衰減:0.0001。

批量大?。?。

動量:設(shè)置為0.95的高值,以補償由于小批量大小而產(chǎn)生的噪聲梯度。

訓(xùn)練網(wǎng)絡(luò)

現(xiàn)在可以訓(xùn)練模型了。對于QuickNAT需要在3個(coronal, axial, sagittal)2d切片上訓(xùn)練3個模型。然后再聚合步驟中組合三個模型的概率生成最終結(jié)果,但是本文中只演示在coronal視圖的2D切片上訓(xùn)練一個F-CNN模型,因為其他兩個與之類似。

num_epochs = 20 start_epoch = 1  val_interval = 1  train_loss_epoch_values = [] val_loss_epoch_values = []  best_ds_mean = -1 best_ds_mean_epoch = -1  ds_mean_train_values = [] ds_mean_val_values = [] # ds_LCE_values = [] # ds_LWM_values = [] # ds_LCC_values = []  print("START TRAINING. : model name = ", "quicknat")  for epoch in range(start_epoch, num_epochs):     print("==== Epoch ["+ str(epoch) + " / "+ str(num_epochs)+ "] DONE ====")        checkpoint_name = CHECKPOINT_DIR + "/checkpoint_epoch_" + str(epoch) + "." + CHECKPOINT_EXTENSION     print(checkpoint_name)     state = {                 "epoch": epoch,                 "arch": "quicknat",                 "state_dict": model_coronal.state_dict(),                 "optimizer": optimizer.state_dict(),                 "scheduler": scheduler.state_dict(),            }     save_checkpoint(state = state, filename = checkpoint_name)      print("\n==== Epoch [ %d / %d ] START ====" % (epoch, num_epochs))      steps_per_epoch = len(train_dataset_coronal_subset) / train_loader_coronal_subset.batch_size      model_coronal.train()     train_loss_epoch = 0     val_loss_epoch = 0     step = 0      predictions_train = []     labels_train = []      predictions_val = []     labels_val = []          for i_batch, sample_batched in enumerate(train_loader_coronal_subset):       inputs = sample_batched["image"].type(torch.FloatTensor)       labels = sample_batched["label"].type(torch.LongTensor)        # print(f"Train Input Shape: {inputs.shape}")        labels = labels.squeeze(1)       _img_channels, _img_height, _img_width = labels.shape       encoded_label= np.zeros((_img_height, _img_width, 1)).astype(int)        for j, cls in enumerate(MaskColorMap):           encoded_label[np.all(labels == cls.value, axis = 0)] = j        labels = encoded_label       labels = torch.from_numpy(labels)       labels = torch.permute(labels, (2, 1, 0))        # print(f"Train Label Shape: {labels.shape}")       # plt.title("Train Label")       # plt.imshow(labels[0, :, :])       # plt.show()        optimizer.zero_grad()       outputs = model_coronal(inputs)       loss = loss_function(outputs, labels)                loss.backward()       optimizer.step()       scheduler.step()        with torch.no_grad():         _, batch_output = torch.max(outputs, dim = 1)         # print(f"Train Prediction Shape: {batch_output.shape}")         # plt.title("Train Prediction")         # plt.imshow(batch_output[0, :, :])         # plt.show()          predictions_train.append(batch_output.cpu())         labels_train.append(labels.cpu())         train_loss_epoch += loss.item()         print(f"{step}/{len(train_dataset_coronal_subset) // train_loader_coronal_subset.batch_size}, Training_loss: {loss.item():.4f}")         step += 1          predictions_train_arr, labels_train_arr = torch.cat(predictions_train), torch.cat(labels_train)          # print(predictions_train_arr.shape)          dice_metric(predictions_train_arr, labels_train_arr)      ds_mean_train = dice_metric.aggregate().item()     ds_mean_train_values.append(ds_mean_train)         dice_metric.reset()      train_loss_epoch /= step     train_loss_epoch_values.append(train_loss_epoch)     print(f"Epoch {epoch + 1} Train Average Loss: {train_loss_epoch:.4f}")          if (epoch + 1) % val_interval == 0:        model_coronal.eval()       step = 0        with torch.no_grad():          for i_batch, sample_batched in enumerate(val_loader_coronal_subset):           inputs = sample_batched["image"].type(torch.FloatTensor)           labels = sample_batched["label"].type(torch.LongTensor)            # print(f"Val Input Shape: {inputs.shape}")            labels = labels.squeeze(1)           integer_encoded_labels = []           _img_channels, _img_height, _img_width = labels.shape           encoded_label= np.zeros((_img_height, _img_width, 1)).astype(int)            for j, cls in enumerate(MaskColorMap):               encoded_label[np.all(labels == cls.value, axis = 0)] = j            labels = encoded_label           labels = torch.from_numpy(labels)           labels = torch.permute(labels, (2, 1, 0))            # print(f"Val Label Shape: {labels.shape}")           # plt.title("Val Label")           # plt.imshow(labels[0, :, :])           # plt.show()            val_outputs = model_coronal(inputs)            val_loss = loss_function(val_outputs, labels)            predicted = torch.argmax(val_outputs, dim = 1)            # print(f"Val Prediction Shape: {predicted.shape}")           # plt.title("Val Prediction")           # plt.imshow(predicted[0, :, :])           # plt.show()                    predictions_val.append(predicted)           labels_val.append(labels)            val_loss_epoch += val_loss.item()           print(f"{step}/{len(val_dataset_coronal_subset) // val_loader_coronal_subset.batch_size}, Validation_loss: {val_loss.item():.4f}")           step += 1            predictions_val_arr, labels_val_arr = torch.cat(predictions_val), torch.cat(labels_val)            dice_metric(predictions_val_arr, labels_val_arr)           # dice_metric_batch(predictions_val_arr, labels_val_arr)                      ds_mean_val = dice_metric.aggregate().item()         ds_mean_val_values.append(ds_mean_val)         # ds_mean_val_batch = dice_metric_batch.aggregate()         # ds_LCE = ds_mean_val_batch[0].item()         # ds_LCE_values.append(ds_LCE)         # ds_LWM = ds_mean_val_batch[1].item()         # ds_LWM_values.append(ds_LWM)         # ds_LCC = ds_mean_val_batch[2].item()         # ds_LCC_values.append(ds_LCC)          dice_metric.reset()               # dice_metric_batch.reset()              if ds_mean_val > best_ds_mean:             best_ds_mean = ds_mean_val             best_ds_mean_epoch = epoch + 1             torch.save(model_coronal.state_dict(), os.path.join(BESTMODEL_DIR, "best_metric_model_coronal.pth"))             print("Saved new best metric model coronal")          print(             f"Current Epoch: {epoch + 1} Current Mean Dice score is: {ds_mean_val:.4f}"             f"\nBest Mean Dice score: {best_ds_mean:.4f} "             # f"\nMean Dice score Left Cerebral Exterior: {ds_LCE:.4f} Mean Dice score Left White Matter: {ds_LWM:.4f} Mean Dice score Left Cerebral Cortex: {ds_LCC:.4f} "             f"at Epoch: {best_ds_mean_epoch}"        )      val_loss_epoch /= step     val_loss_epoch_values.append(val_loss_epoch)     print(f"Epoch {epoch + 1} Average Validation Loss: {val_loss_epoch:.4f}")  print("FINISH.")

代碼也是傳統(tǒng)的Pytorch的訓(xùn)練步驟,就不詳細解釋了

繪制損失和精度曲線

訓(xùn)練曲線表示模型的學(xué)習(xí)情況,驗證曲線表示模型泛化到未見實例的情況。我們使用matplotlib來繪制圖形。還可以使用TensorBoard,它使理解和調(diào)試深度學(xué)習(xí)程序變得更容易,并且是實時的。

epoch = range(1, num_epochs + 1)  # Plot Loss Curves plt.figure(figsize=(18, 6)) plt.subplot(1, 3, 1) plt.plot(epoch, train_loss_epoch_values, label="Training Loss") plt.plot(epoch, val_loss_epoch_values, label="Validation Loss") plt.title("Training and Validation Loss") plt.xlabel("Epoch") plt.legend() plt.figure() plt.show()  # Plot Train Dice Coefficient Curve plt.figure(figsize=(18, 6)) plt.subplot(1, 3, 2) x = [(i + 1) for i in range(len(ds_mean_train_values))] plt.plot(x, ds_mean_train_values, "blue", label = "Train Mean Dice Score") plt.title("Training Mean Dice Coefficient") plt.xlabel("Epoch") plt.ylabel("Mean Dice Score") plt.show()  # Plot Validation Dice Coefficient Curve plt.figure(figsize=(18, 6)) plt.subplot(1, 3, 3) x = [(i + 1) for i in range(len(ds_mean_val_values))] plt.plot(x, ds_mean_val_values, "orange", label = "Validation Mean Dice Score") plt.title("Validation Mean Dice Coefficient") plt.xlabel("Epoch") plt.ylabel("Mean Dice Score") plt.show()

在曲線中,我們可以看到模型是過擬合的,因為驗證損失上升而訓(xùn)練損失下降。這是深度學(xué)習(xí)算法中一個常見的陷阱,其中模型最終會記住訓(xùn)練數(shù)據(jù),而無法對未見過的數(shù)據(jù)進行泛化。

避免過度擬合的技巧:

用更多的數(shù)據(jù)進行訓(xùn)練:更大的數(shù)據(jù)集可以減少過擬合。數(shù)據(jù)增強:如果我們不能收集更多的數(shù)據(jù),我們可以應(yīng)用數(shù)據(jù)增強來人為地增加數(shù)據(jù)集的大小。添加正則化:正則化是一種限制我們的網(wǎng)絡(luò)學(xué)習(xí)過于復(fù)雜的模型的技術(shù),因此可能會過度擬合。評估網(wǎng)絡(luò)

我們?nèi)绾味攘磕P偷男阅?一個成功的預(yù)測是一個最大限度地擴大預(yù)測和真實之間的重疊。

這一目標(biāo)的兩個相關(guān)但不同的指標(biāo)是Dice和Intersection / Union (IoU)系數(shù),后者也被稱為Jaccard系數(shù)。兩個指標(biāo)都在0(無重疊)和1(完全重疊)之間。

這兩種指標(biāo)都可以用于類似的情況,但是區(qū)別在于Dice Score傾向于平均表現(xiàn),而IoU則幫助你理解最壞情況下的表現(xiàn)。

我們可以逐個類地檢查度量標(biāo)準,或者取所有類的平均值。這里將使用monai.metrics.DiceMetric來計算分數(shù)。一個更通用的方法是使用torchmetrics,但是因為這里使用了monai框架,所以就直接使用它內(nèi)置的函數(shù)了。

我們可以看到Dice得分曲線的行為相當(dāng)不尋常。主要是因為驗證平均Dice得分高于1,這是不可能的,因為這個度量是在0和1之間。我們無法確定這種行為的主要原因,但我們建議在多類問題中為每個類單獨提供度量計算,并始終提供可視化示例以進行可視化評估。

結(jié)果分析

最后我們要看看模型是如何推廣到未知數(shù)據(jù)的這個模型預(yù)測的幾乎所有東西都是左腦白質(zhì),一些像素是左腦皮層。盡管它的預(yù)測似乎是正確的,但仍有很大的改進空間,因為我們的模型太小了,可以選擇更深的模型獲得更好的效果。

總結(jié)

在本文中,我們介紹了如何訓(xùn)練QuickNAT來完成具有挑戰(zhàn)性的大腦分割任務(wù)。我們盡可能遵循作者在他們的研究論文中解釋的學(xué)習(xí)策略,這是本教程為了方便演示只在最簡單的步驟上進行了演示,文本的完整代碼:

https://github.com/inesdv26/Brain-Segmentation

關(guān)鍵詞:

相關(guān)新聞

Copyright 2015-2020   三好網(wǎng)  版權(quán)所有 聯(lián)系郵箱:435 22 640@qq.com  備案號: 京ICP備2022022245號-21
中文字幕精品人妻久久久久| 午夜精品老牛av一区二区三区| 日韩激情文学在线视频| 欧美日韩国产在线中文字幕| 99久久精品视频16| 青娱乐这里只有精品| 成人午夜av电影网| 91在线九色porny| 亚洲高清免费在线观看视频| 69av精品国产探花| 九九六视频,这里只有精品| 又爽又粗又猛又色又黄视频| 亚洲精品综合欧美精品综合| 亚洲乱码av一区二区蜜桃av| 超碰在线免费观看视频97| 懂色av之国产精品| 青青免费观看视频| 日本不卡视频一二三区| 亚洲熟女人妻自拍在线视频 | 蜜桃tv一区二区三区| 中文字幕福利视频在线一区| 4438全国成人免费视频| 蜜桃臀av在线一区二区| 中文字幕免费啪啪啪| 欧美啪啪一区二区三区| 欧美在线观看一区二区不卡| 亚洲成人自拍av在线| 精品欧美乱码久久久| 99精品视频在线在线观看| 最新国产午夜激情视频| 亚洲欧美成人激情在线| 午夜夫妻性生活视频| 天天插天天干天天狠| 国产精品igao为爱寻找激情| 夏目彩春av在线看| 男插女视频大全免费| 亚洲欧美成人午夜一区二区| 蜜乳av中文字幕一区二区| 亚洲一区二区三区无码在线| 欧美日韩久久丝袜在线| 老熟妇一区二区三区v∧88| 99精品久久99久久久久一| 日本人妻少妇xxxxxxx| 国产男女无套?免费网站下载| 一区二区三区资源视频| 日本老熟老熟妇七十路| 亚洲一区在线视频观看地址| 欧美一级特黄大片在线| 日韩久久九九精品视频| 免费绝清毛片a在线播放| 在线免费观看欧美小视频| 午夜福利午夜福利影院| 久久内射天天玩天天懂色| 超peng视频在线免费播放97| 日韩国产欧美一区二区三区粉嫩| 亚洲综合一区二区三区四区| 亚洲午夜国产末满十八岁勿进网站| 不卡在线一区二区三区| 97视频人人爱麻豆| 日韩成人精品久久久免费看| 日本有码精品一区二区三区| 日本午夜福利免费在线播放| av里面的动作是真进去吗| 国产熟女五十路一区二区三区| 色999日韩偷自拍拍免费| 亚洲欧美日韩中文视频| av中文字幕国产精品| 欧美一级日韩一级亚洲一级va| 亚洲欧美成人激情在线| 国长拍拍视频免费孕妇| 四虎精品久久免费最新| 亚洲成人av在线一区二区| 制服丝袜 中文字幕 日韩| 亚洲美女a级黄色在线播放| 公侵犯人妻中文字幕巨| 99久久国语露脸国产精品| 自拍偷拍色图亚洲天堂| 天堂在线中文字幕av| 麻豆午夜激情在线观看| 妈妈的朋友2中文字幕在线| 黄片视频免费观看视频| 亚洲精品色图1234| 青青在线视频看看| 免费看日韩黄视频在线观看| 午夜野花视频在线观看| 青青免费观看视频| 91佛爷视频在线观看| 丰满人妻被猛烈进入中文字幕| 人妻系列在线免费视频| 午夜福利片无码10000| 欧美成人久久久桃色aa| 夜夜骚av一二三区| 午夜久久久久欠久久久久| 羞羞漫画无限免费观看秋蝉| 久久精品四虎夜夜拍拍拍| 99久久免费播放在线观看视频| 亚洲欧美韩国日本一区二区| 在线观看2022av| 北野中文字幕一区二区| 国产av嗯嗯啊啊av| 夜色17s精品人妻熟女av| 不用付费特黄特色亚洲特级黄色片| 欧美日韩综合精品无人区| 日韩免费黄色片在线观看| 日本不卡视频一二三区| 亚洲熟妇在线视频观看| 亚洲a区在线免费观看| 亚洲国产美女主播在线观看| 午夜国产一区二区三区| 国产精品久久久久久成人久| 亚州av嫩草av极品在线观看| 9久re热视频在线精品| 亚洲av激情综合网| 午夜精品久久秘?18免费观看| 久久av色噜噜ai换脸| 日韩av熟妇在线观看| 伊人网国产在线播放| 人人妻人人爽人人爽欧美一区| 欧美日本在线免费视频| 亚洲午夜国产末满十八岁勿进网站| 伊人网在线免费观看| 99亚偷拍自图区亚洲| av 资源在线播放| 久久久久久久久久久久久国产| 亚洲国产精品自产拍在线观看| av网页免费在线观看| 国产91九色视频在线观看| 18福利视频在线观看| 女人扒开逼让男人操| 四季av人妻一区二区三区| 抽插小穴啊啊啊视频| 一区二区三区国产在线成人av| 中文字幕国产一区在线视频| 亚洲av日韩久久网站| 成人av中文字幕在线看| 黑人大巨屌操美女逼| 婷婷色综合五月天视频| 天天搞天天操天天干| 亚洲人成小说网站色| 国产精品美女免费视频观看| 黑鸡巴肏少妇逼视频| 亚洲精品色图1234| 天海翼亚洲一区在线观看| 青娱乐不卡视频在线| 丰满少妇高潮喷水视频| 久久久久久久岛国免费观看| 欧美第一激情综合网欧美激情| 国产农村乱子伦精精品视频| 九九视频在线观看全部| 抽插小穴啊啊啊视频| 少妇被中出一区二区| 亚洲欧美成人午夜一区二区| 伊人精品久久一区二区| 亚洲成人,国产精品| 国产精品内射婷婷一级| 欧美大鸡吧男操女啊啊啊视频 | 免费的啪啪视频软件| 国产不卡免费在线观看| 天天干夜夜爽狠狠操| 狠狠干狠狠操免费视频| 国产主播诱惑毛片av| 91精品视频在线观看视频| xxnxx国产美女| 美女激情久久久久久久| 高清欧美色欧美综合网站| 1区3区4区产品乱入视频| 中国精品人妻一区二区| 秋霞成人午夜鲁丝一区二区三区| 欧美日韩在线观看免费播放| 18禁男女啪啪啪无遮挡| 久草视频在线看免费| 亚洲av在线免费播放| 都市激情校园春色 亚洲| 51vv精品视频在线观看| xxxx69在线观看视频| 天天干夜夜爽狠狠操| 我爱搞在线观看视频| 河北全程露脸对白自拍| 亚洲女人自熨在线视频| 香港日本台湾经典三级| 亚洲欧美另类校园春色| 七色福利视频在线观看| av 资源在线播放| 亚洲欧美另类丝袜另类自拍| 超peng视频在线免费播放97| 天天曰天天摸天天爽| 亚洲第一页欧美第一页| 97视频人人爱麻豆| 午夜在线成人免费电影| 亚洲精品久久久人妻| 黑人大巨屌操美女逼| 男人的天堂aⅴ在线| 青青操天堂在线观看视频| 一区二区三区国产在线成人av| 日本老熟老熟妇七十路| 夫亡人妻被强干中文字幕| 青青青青青爽视频在线| 久操资源在线免费播放| 大尺度av毛片在线网址| 男人的天堂av中文字幕| 欧美性感美女热舞视频| 青娱乐免费视频一二三| 亚洲中文字幕无线乱码人妻精品| 天天干夜夜操夜夜骑| a级黄片免费观看| 日韩一级欧美一级片| 欧美亚洲国产一区二区| av在线男人的天堂亚洲| 青青免费观看视频| aa福利影视在线观看| 久久久久高潮白浆久久| 一区二区三区观看在线| 精品视频一区二区三区◇| 日本香港韩国三级黄色| 久久久人妻免费视频| 在线观看2022av| 亚洲欧美精品日韩偷拍| 天天操天天舔天天射天天日天天干| 中国精品人妻一区二区| 午夜精品久久秘?18免费观看| 大乳人妻一区二区三区| 日本a级2020在线观看| 亚洲少妇色小说综合| 2020精品视频在线| 亚洲免费午夜污福利| 日本特级黄片免费观看| 日本a级2020在线观看 | 中文字幕福利视频第四页| 亚洲色大WWW永久网站| 麻豆出品视频在线观看| 免费的啪啪视频软件| 美女激情久久久久久久| 日本高清 中文字幕| 亚洲少妇色小说综合| 日本一本午夜在线播放| 色网站在线观看免费| 日本韩国欧美在线视频| 亚洲蜜桃久久久久久| 天天色 天天操 天天好逼| 亚洲国产日韩a在线欧美| 日本成人福利电影网| 亚洲熟女少妇中文字幕系列| 亚洲第一页欧美第一页| 久久久久性感美女偷拍视频| 男人av一区二区三区| 欧美日本在线免费视频| xxoo福利视频导航| 大尺度av毛片在线网址| 68福利精品在线视频| 18禁男女啪啪啪无遮挡| 91色老久久精品偷偷蜜臀| 女生裸体视频免费网站| 天天干天天操天天日天天日| 中文字幕欧美人妻在线.| 77亚洲视频在线观看| 最新国产精品综合网高清| 污网址在线观看视频| 黑人大巨屌操美女逼| 久久热在线免费观看| 日本高清在线观看不卡视频| 中文字幕日韩人妻在线三区| 91污污在线观看视频| 亚洲国产精品自拍偷拍视频在线 | 欧美猛少妇色ⅹⅹⅹⅹⅹ猛叫| 亚成区一区二区人妻熟女| 91在线九色porny| 国产肥胖熟女又色又爽免费视频 | 亚洲欧美精品海量播放| 国产熟女五十路一区二区三区| 欧美男女一区二区三区| 懂色av之国产精品| 68福利精品在线视频| 亚洲美女黄色福利视频网站大全| 亚洲激情噜噜噜久久久| 中文字幕一区二区人妻视频| 亚洲国产日韩精品在线| 中文字幕综合网91| 全国熟妇精品一区二区免费视频| 国产福利一区二区三区在线观看| 人妻少妇视频系列视频在线| 夜夜爽夜夜操夜夜爱| 韩国在线播放一区二区三区| 99久久国产精品免费消防器材| 欧美 日韩 精品 中文| 亚洲精品色图1234| 亚洲制服丝袜美腿在线| 青娱乐不卡视频在线| 日韩av熟妇在线观看| 国产 亚洲 欧美 自拍| 伊人网在线欧美日韩在线| 日本欧美高清在线观看视频| 精品国产久久久久午夜精品av| 狠狠操av一区二区三区| 国际精品熟女一区二区| 日韩激情亚洲国产欧美另类激情 | 亚洲第一成年偷拍视频| 干逼又爽又黄又免费的视频| 亚洲午夜熟女在线观看| 大尺度久久久久久久| 大成色亚洲一二三区| 天天插天天透天天爽| 人妻少妇的va视频| 欧美大胆a级视频秒播| 高清av在线婷一区二区色日韩| 福利视频导航在线观看| 亚洲av 综合av| 人妻激情偷乱一区二区三区av| 国产免费久久精品99re丫丫| 大香蕉尹人在线最新| 亚洲高清一区二区三区久久| caopeng97在线观看视频| 国产视频成人一区二区| 成人十欧美亚洲综合在线| 男女真人做带声音视频图片| 97成人老师在线视频| 亚洲第一区av中文字幕| 91人妻人人爽色啊啊啊| 男人资源站中文字幕| 午夜偷拍的视频久久久免费大全 | 91在线九色porny| 我爱搞在线观看视频| 操死你美女在线视频| 一区二区三区内射美女| 亚洲情色777中文字幕| 午夜精品视频免费观看| 中文字幕在线观看av观看| 手机看片1024精品国产| 中文字幕福利视频第四页| 国产剧情av在线免费观看| 韩日一级人添人人澡人人妻精品| 一级做性色a爱片久久片| 青青国产95免看视频| 日韩黄色在线观看网站上 | 精品不卡一区二区三区| 亚洲色图日韩在线视频观看| 一区二区三区四区久久久久韩日 | 人妻中文字幕亚洲在线| 国内销魂老女人老泬| 中出小骚货在线观看| 日韩精品视频一区二区三区在线| 精品国产人伦一区二区三区| 青娱乐这里只有精品| 一二三四区国产在线观看| 裸日本资源在线午夜| 中文字幕久久久国产| 男女啪啪啪网站在线观看免费| 台湾18禁久久久久久久激情视频| 天天干夜夜爽狠狠操| 91国产精品乱码久久久久久| 精品国产久久久久午夜精品av| 中文字幕av特黄毛片| 在线观看2022av| 大乳人妻一区二区三区| av在线观看视频免费| 欧美男女一区二区三区| 中文字幕亚洲无线乱码| 亚洲欧美另类校园春色| 网站在线观看蜜臀91| 午夜8050免费小说| 亚洲精品1卡2卡3卡| 先锋人妻啪啪中文字幕| 国际日韩日韩日韩日韩日韩| 亚洲一区在线视频观看地址| 性感人妻 中文字幕| 97精品久久久久久无码人妻 | 在线中文字幕人妻av| 高清国产美女a一级毛片| 久久热在线免费观看| 色老头一区二区三区四区五区| 亚洲成人三级黄色片| 91性高湖久久久久久久久久| 欧美黑人性猛交小矮人| 国产igao激情在线视频入口| 午夜一区二区三区视频在线观看 | 亚洲美女a级黄色在线播放| 福利小视频免费在线| 欧美日本国产一区二区| 老司机免费视频福利0| 久久99精品热在线观看| 91色乱一区二区三区| 亚洲精品1卡2卡3卡| 婷婷综合缴情亚洲五月伊人| 夜夜骚av一二三区| 日本福利视频网站导航| av无限看熟女人妻另类av| 欧美最新一区二区三区| 污网址在线观看视频| 青青青免费手机视频在线观看| 自拍偷拍亚洲综合第一页| 国产精品网站亚洲发布| 天天夜夜久久精品综合| 亚洲男人天堂最新网址大全 | 中文字幕观看中文字幕免费| 精品国产无乱码一区二区三区| 九九热视频1这里只有精品| 亚洲第一成年偷拍视频| 色网站在线观看免费| aa福利影视在线观看| 女人高潮潮呻吟喷水网站| 一二三四区国产在线观看| 亚洲一区亚洲二区成人福利| 欧美猛少妇色ⅹⅹⅹⅹⅹ猛叫| 中文字幕在线观看av观看| 九十九步都是爱最后一步是尊严| 人妻中文字幕亚洲在线| 欧美强奸视频在线观看| 精品不卡一区二区三区| 亚洲午夜精品一级毛片app| 久久久久久免费观看av| avgo成人短视频| 青娱乐免费视频一二三| 午夜福利片无码10000| 青娱乐这里只有精品| 亚洲成a人77777| 欧美精品乱码99久久蜜桃免费| 欧美精品999不卡| 久久99嫩草99久久精品| 夜夜骚av一二三区| 午夜情色一区二区三区| 另类欧美激情校园春色| 2020国产成人精品视频| 国产激情免费在线视频| 91精品视频在线观看视频| 伦理在线观看未删减中文字幕| 国产在线小视频一区二区| 一区二区三区 国产日韩欧美| 99在线视频精品观看高| 中文人妻av一区二区三区| www,日韩av,com| 岳的大肥屁熟妇五十路| 首页欧美日韩中文字幕| 天天操天天日天天插天天舔| 亚洲一区二区在线视频观看免费| 老色鬼精品视频在线观看播放| 91在线九色porny| 日韩欧美一区二区三区免费看| 2018中文字字幕人妻| 欧美国产精品久久久免费| 黄很色很在线免费视频网站| 538欧美在线观看一区二区三区| 人妻色综合aaaaaa网| 92午夜免费福利视频www| 91精品久久久久久久99蜜月| 人妻色综合aaaaaa网| 9662av在线视频| 国长拍拍视频免费孕妇| 国产剧情av在线免费观看| 日韩欧美中文字幕老司机三分钟| 午夜国产免费视频亚洲| 91福利高清在线播放| 亚洲免费午夜污福利| 亚洲最强的25个城市| 成人免费视频现网站99在线观看| 99久久国产精品免费消防器材| 91美女在线观看视频| 久久久久久久岛国免费观看| 福利视频免费在线播放| 亚洲中文字幕在线视频观看二区 | 小妹妹爱大棒棒免费观看视频| 天天干天天弄天天日| 亚洲国产美女主播在线观看| 国产精品 亚洲欧美 自拍偷拍| 91精品国产综合99| 午夜精品久久秘?18免费观看| 91亚洲最新蜜桃在线| 在线观看网站伊人网| 秋霞成人午夜鲁丝一区二区三区| 欧美日本在线免费视频| 快使劲弄我视频在线播放| 国产福利一区二区三区在线观看| 插鸡视频免费网站在线播放| 人妻系列中文字幕大乳丰满人妻| 夜夜操夜夜爱夜夜摸| 91色乱一区二区三区| 国产熟女五十路一区二区三区| 亚洲黄色成人一级片| 桃色成人开心激情网| 亚洲一级熟妇丰满的女人| av大尺度一区二区三区| 日本一道中文字幕99| 首页欧美日韩中文字幕| 干逼又爽又黄又免费的视频| 亚洲第一区av中文字幕| 人人妻人人爽人人爽欧美一区 | 国产一级一国产一级毛片| 先锋人妻啪啪中文字幕| 国产伦理二区三区在干嘛呢| 911美女片黄在线观看| 国产igao激情在线视频入口| 不卡高清一区二区三区| av中文字幕国产精品| 日本特级黄片免费观看| 日本午夜福利免费在线播放| 亚洲国产精品自产拍在线观看| 69国产精品成人aaaaa片| 日本午夜福利免费在线播放| 美女av色播在线播放| 国产精美视频精品视频精品| 日日躁夜夜躁狠狠操| 欧美一区二区三区爽爽| 国产资源网站在线播放| 99久久免费播放在线观看视频| 亚洲av中文无码网站| 999精品视频免费在线观看| 大尺度av毛片在线网址| 国产精品乱码高清在线观看h| v天堂国产精品久久| 国产精品性感美女视频| 天天摸天天舔天天操天天日| 久99久视频免费观看中文字幕| 日韩人妻中文字幕二区 | 亚洲午夜熟女在线观看| 亚洲韩精品一区二区三区| 国产视频成人自拍蝌蚪视频| 韩日一级人添人人澡人人妻精品| 亚洲成年人精品国产| 国产天堂av不卡网| 精品国产久久久久午夜精品av| 亚洲一区二区三区四区入口| 中文字幕久久久国产| 精品国模一区二区三区欧美| 精品精品精品精品精品污污污污| 五月天男人的天堂中文字幕| 熟女人妻aⅴ一区二区三| 国际精品熟女一区二区| 大香蕉尹人在线最新| 亚洲最大的自拍偷拍网| 极品少妇高潮喷水日出白浆| 妈妈的朋友中字在线免费观看| 大奶熟妇激情操逼逼| 黑人大巨屌操美女逼| 亚洲综合一区二区三区四区| 新亚洲天堂男子av| 人妻免费视频黄片在线视频| 久久久久久久精品乱码| 亚洲欧美日韩电影一区| 亚洲美女色www色| 黄色片黄色片黄色片黄色片黄色| 欧美色区国产日韩亚洲区| 69精品互换人妻4p| 亚洲一区亚洲二区成人福利| 快使劲弄我视频在线播放| 蜜桃臀少妇白色紧身裤细高跟| 天堂av在线最新地址| 五月天色婷婷狠狠爱| 伊人久久综合国产精品| 1级黄色片在线观看| 有码一区二区三区四区五区 | 亚洲欧洲无码一区2区无码| 鸡巴在里面福利视频在线观看| 久久久精品人妻无码专区不卡 | xxnxx国产美女| 91香蕉国产亚洲一二三区| 中文字幕av特黄毛片| 久久免费视频ww一区| 2020国产成人精品视频| 性感美女极品18禁网站在线| 97精品国产91久久久| 国产igao激情在线视频入口| 97人妻人人揉人人躁人人夜夜爽 | 91久久久久久最新网站| 97成人老师在线视频| 天天色天天射天天日天天干| 免费在线观看黄色小网站| 成人午夜麻豆大胆视频| 国产男人的天堂一区| 天天躁狠狠躁狠狠躁性色| 亚洲a级视频在线播放| 午夜92福利1000| 天天操天天舔天天射天天日天天干 | 成人黄色录像在线观看| 亚洲另类激情视频在线看| 网友自拍第一页99热| 丰满放荡熟妇在线播放| 亚洲高清免费在线观看视频| 一区二区三区国产在线成人av| 天天操天天射天天操天天日| 97超碰人人爽人人做| 欧美一级特黄大片做受99| 久草久热这里只有精品| 天天日天天亲天天操| 人妻色综合aaaaaa网| 网友自拍第一页99热| 美女网站视频久久精品| 91porny九色视频偷拍| 在线观看中文字幕视频成人| 黑人和日本人av一区二区| 亚洲理论在线a中文字幕97| 人妻系列级片在线观看视频| 岛国av成人午夜高清| 欧美精品激情在线不卡| 日韩无码国产一区二区| 综合激情网,激情五月| 亚洲精品一区二区gif| 宅男噜噜噜66国产在线观看| 色噜噜噜噜色噜噜色合久一| 亚洲激情噜噜噜久久久| 一区二区九日韩美女| 大屁股熟女一区二区视频| 91污污在线观看视频| 人妻中文字幕亚洲在线| 伊人网在线欧美日韩在线| 操人妻人妻天天爽天天偷| 精品国产人伦一区二区三区| 在线免费观看欧美小视频 | 青青青青午夜手机国产视频| 日本高清有码在线视频| 不用付费特黄特色亚洲特级黄色片 | 91亚洲最新蜜桃在线| 国产黑色丝袜 在线日韩欧美| 伊人情人成综合视频| 玖玖资源站在线观看亚洲| 亚洲综合一区二区三区四区| www国产亚洲精品久久久| 国产精品久久久久精品三级18| xxnxx国产美女| 亚洲免费在线不卡视频| 在线 激情 亚洲 视频| 中字幕人妻熟女人妻a62v网| 久99久视频免费观看中文字幕| 丝袜美女诱惑佐佐三上| 午夜在线观看一级毛| 日本福利网站一区二区| 91超碰国产在线观看| 福利小视频免费在线| 女同性恋av在线播放| 一区二区三区婷婷中文字幕| 国产一区二区手机在线观看| 夏目彩春av在线看| 亚洲在线观看中文字幕av| 欧美黑人1区2区3区| 国产激情在线观看一区二区三区| 中文字幕熟女人妻一区| 福利在线国产小视频| 50熟妇一区二区三区| 天天操天天日天天碰| 91精品资源在线观看| 熟女国内精品一区二区三区| 亚洲成人五月婷婷久久综合| 中文字幕在线观看亚洲情色| 99在线视频精品观看高| 特级aaaaa黄色片| 91日本精产品一区二区三区| 91九色人妻在线播放| 日本高清久久人人爽| 呻吟求饶的人妻中文字幕| 国产农村乱子伦精精品视频| 操死你美女在线视频| 免费看一级高潮喷水片| 一级做性色a爱片久久片| 欧美国产精品久久久免费| 在线能看视频你懂的| 欧美日韩精品aaa| 亚洲中文字幕最新地址| 中文字幕综合网91| 99国产精品国产精品毛片19| 手机视频在线观看一区| 绿巨人浩克在线视频观看| 看女人大BB群伦交| 人妻少妇视频系列视频在线| 国产视频成人自拍蝌蚪视频 | 全国熟妇精品一区二区免费视频| 欧美在线观看一区二区不卡| 69国产在线视频网站| 久久国产半精品99精品国产| avjpm亚洲伊人久久| 亚洲|久久久久久一二三区丝袜| 欧美vr专区日韩vr专区| 国产一区两区三区福利小视频| 欧美一级aaaaaaa片| 天天插天天透天天爽| 顶级欧美色妇xxxx| 一区二区三区午夜福利在线| av在线中文字幕在线| 快使劲弄我视频在线播放| 9999久久久久老熟妇二区| 天堂网免费在线电影| 天天透天天舔天天操| 女生裸体视频免费网站| 色丁香久久激情综合网| 成年人黄色日本视频| 99国产精品久久99久久久| 免费啪啪啪网站在线观看| 人妻系列在线免费视频| 日韩久久不卡免费视频| 一区二区三区av免费天天看| 68视频在线免费观看| 在线免费观看欧美小视频| 亚洲第一区av中文字幕| 天天操天天舔天天做| 核xp工厂精品久久亚洲| 青青青免费手机视频在线观看| 亚洲成人偷拍自拍在线| 亚洲黄色成人一级片| 亚洲激情视频在线观看免费| 911精产国品一二三产区区| 国产视频1区2区3区| 欧美精品一区二区三区观看| 大香蕉在线欧美在线视频| 亚洲色图日韩在线视频观看| 可在线免费观看av| 美女妩媚午夜诱惑网站| 欧美精品熟妇免费在线| 网友自拍第一页99热| 国产视频成人自拍蝌蚪视频| 久久人妻诱惑我视频| 老司机伊人99久久精品| av天堂a亚洲va天堂va里番| 午夜福利国产精品久久久久| 51vv精品视频在线观看| 国产igao激情在线视频入口| 久久久人妻免费视频| 男女啪啪啪网站在线观看免费| 色999日韩偷自拍拍免费| 亚洲午夜精品视频节目| 自拍偷拍 亚洲性图 欧美另类| 妈妈的朋友2中文字幕在线| 天天天天天天天天干夜夜| 中文乱码字幕人妻熟女人妻| 亚洲唯美激情综合四射| 夜夜爽夜夜操夜夜爱| 亚洲av日韩久久网站| 男女爱爱好爽视频免费看| 亚洲精品一区二区gif| 精产国品一二三产品区别91| 亚洲人人爽人人澡起碰av| 一二三四区国产在线观看| 亚洲一区二区在线激情| 99国产精品久久99久久久| 熟妇人妻av无码中文字幕| 最新国产精品拍在线观看| 91超碰国产在线观看| 精品国产久久久久午夜精品av| 国产高清在线观看av| 91九色国产在线视频| 欧美亚洲国产一区二区| 天天弄天天草天天日天天| 偷拍欧美日韩另类图片| 熟妇高潮久久久久久久| 亚洲最大先锋资源采集站| 欧美成人红桃视频在线观看| 亚洲成年人精品国产| 91九色国产在线视频| 天天综合久久无人区| 国产 亚洲 欧美 自拍| 核xp工厂精品久久亚洲| 国产精品视频网站污污污| 女生裸体视频免费网站| 亚洲精品一区二区gif| 国产在线观看一区二区三区四区| 亚洲乱熟女一区二区三区影片| 老牛影视在线一区二区三区| 插鸡视频免费网站在线播放| 亚洲男人天堂最新网址大全 | 中文在线字幕免费观看日韩视频| 青青青在线视频免费播放| 日韩久久不卡免费视频| 亚洲成人动漫av在线| 久久久久九九九九九12| 99久久国语露脸国产精品| 女人的天堂av在线网| 伊人网国产在线播放| 伊人网在线观看 视频一区| 欧美丝袜亚洲国产日韩| 免费在线观看黄色小网站| 欧美性受黑人猛交裸体视频| av一区二区三区蜜桃| 国内精品一区二区2021在线| 制服丝袜 中文字幕 日韩| av日韩视频在线观看| 免费看日韩黄视频在线观看| 日韩欧美一区二区三区免费看| 色丁香久久激情综合网| 亚洲成人自拍图片网站| 欧美日韩福利视频网| 亚洲高清免费在线观看视频| 污视频在线观看地址| 女生抠逼自慰啊啊啊啊啊啊啊下载 | 人妻色综合aaaaaa网| 久久中文字幕av一区二区| 亚洲色图日韩在线视频观看| 美女激情久久久久久久| 日本美女爱爱视频网站| 亚洲av毛片在在线播放| 日本四十路人妻熟女| 九热精品视频在线观看| 日本欧美亚洲国产啊啊啊| 黄很色很在线免费视频网站 | 日本亚洲精品视频在线观看| av里面的动作是真进去吗| 天堂网成人av电影| 日韩加勒比精品在线看| 国产成人在线观看视频播放| 中文字幕久久久国产| 亚洲韩精品一区二区三区| 啊不行啊操逼好爽大鸡吧视频| 蜜桃臀少妇白色紧身裤细高跟| 日韩加勒比精品在线看| 欧美精品激情在线不卡| 99久久久久久亚洲精品免费| 国模伊人久久精品一区二区三区| 天天透天天舔天天操| 成年人免费福利在线| 欧美日韩不卡视频合集| 天天想要天天操天天干| 国产精品中文字幕丝袜| av无限看熟女人妻另类av| 免费啪啪啪网站在线观看| 亚洲av中文免费在线| yellow在线亚洲精品一区| 夜夜躁婷婷av蜜桃妖| 9420高清视频在线观看国语版| 日本高清有码在线视频| 高潮喷水一区二区三区| 小妹妹爱大棒棒免费观看视频| 亚洲一区二区偷拍女厕所| xxxx69在线观看视频| 亚洲国内精品久久久久久久| 无码人妻丰满熟妇区五路| 亚洲成人欧洲成人在线| 内地精品毛片在线观看| 老牛影视在线一区二区三区| 日本熟妇乱妇熟色视频| 欧美插插插插插插| 极品少妇高潮喷水日出白浆| 人人妻人人爽人人摸| 精品高潮呻吟久久av| 99国产精品国产精品毛片19| 国产黑色丝袜 在线日韩欧美| 欧美成人屋影院在线视频观看| 性感美女极品18禁网站在线| 熟女人妻精品视频一区| 户外露出视频在线观看| 福利一二三在线视频观看| 中文字幕一区二区三区久久久| 黄色大片一级老太太操逼| 网站在线观看蜜臀91| 中文字幕观看中文字幕免费 | 中文字幕av特黄毛片| 免费在线小视频你懂的| 免费高清av一区二区| 欧美精品乱码99久久蜜桃免费| 亚洲gay视频在线观看| 熟妇人妻丰满久久久久久久| 日韩三级精品电影久久久久 | 一区二区三区五区六区| 一区二区在线观看视频网站 | 熟女阿高潮合集一区二区| 天天操天天射天天操天天日| 99色在线观看免费观看| 国产农村乱子伦精精品视频| 天天天天天天天天干夜夜| 裸露视频免费在线观看| 狂操鸡巴小骚逼视频免费观看| 亚洲综合熟女乱中文| 五月激情婷婷四射基地| 后入日韩翘臀蜜桃臀美女| 国产精品 亚洲欧美 自拍偷拍| 日本a级2020在线观看| 51vv精品视频在线观看| 上床啪啪啪免费视频| 亚洲国产精品自产拍在线观看| 午夜免费福利老司机| 欧美大鸡吧男操女啊啊啊视频| 骚穴被阴茎插免费视频| 欧美不卡一二三区精品| 91精品在线视频免费视频| 最近最新最好看的中文字幕 | 男女真人做带声音视频图片| 不卡在线一区二区三区| 日韩人妻中文字幕二区| 黑人3p日本女优中出| 在线观看中文字幕少妇av| 日本一区二区三区区别| 亚洲资源在线免费观看| 熟妇人妻av无码中文字幕| 日本不卡视频一二三区| 91性高湖久久久久久久久久| 午夜精品久久久久久久精品乱码| 中字幕人妻熟女人妻a62v网| 日韩人妻精品久久久久| 操死你美女在线视频| 黄版视频在线免费观看| 日本高清激情乱一区二区三区| aa福利影视在线观看| 中文字幕在线字幕乱码怎么设置| aa福利影视在线观看| 情趣视频在线观看91| 99久9在线视频播放| 99久9在线视频播放| 18福利视频在线观看| 一区二区三区四区影片| 2020年亚洲男人天堂网| 在线视频自拍第三页| 漂亮人妻口爆久久精品| 天天天天天天天天干夜夜| 日韩久久九九精品视频| 欧美强奸视频在线观看| 青青青在线视频观看97| 自拍偷拍 国产激情| 裸露视频免费在线观看| 91大神福利视频网| 青青免费观看视频| 黄很色很在线免费视频网站 | 亚洲成年人精品国产| 欧美久久一区二区伊人| 色999日韩偷自拍拍免费| 黄色av网址在线播放| 裸日本资源在线午夜| a级黄片免费观看| 人妻系列中文字幕大乳丰满人妻| 精品国产av虐杀两警花| 视频在线 一区二区| 伦理在线观看未删减中文字幕| 欧美在线视频不卡一区| 国产三级自拍视频在线观看网站| 插鸡视频免费网站在线播放| 在线观看黄页网站视频网站| 宅男噜噜噜66国产在线观看| 精品一区二区三区喷水内射高潮| 中文字幕欧美人妻在线.| 亚洲国产精品青青草| 91美女在线观看视频| av无限看熟女人妻另类av| 猫咪亚洲中文在线中文字幕| 一区二区三区高清视频3| 国产不卡免费在线观看| 午夜野花视频在线观看| 一区二区三区四区久久久久韩日| 欧美成人区一区二区三| 日本亚洲精品视频在线观看| 欧美男男在线观看视频网站| 偷拍欧美日韩另类图片| 国产,亚洲,欧美综合| 国内销魂老女人老泬| 天天色天天射天天日天天干| 久久久精品人妻无码专区不卡 | 青青草原在线播放日韩| 亚洲国产中文字幕在线看| 97视频538在线观看| 美国男的操女孩的小嫩逼| 国产一区二区三区四区精| 亚洲美女色www色| 97精品视频,全部免费| 久久久人妻免费视频| 亚洲经典av中文字幕| 亚洲AV无码一二三四区在线播放| 亚洲欧美一级特黄大片| 麻豆国产精品777777在| 国产成人情侣激情视频| 国产不卡免费在线观看| 亚洲最大的自拍偷拍网| 少妇熟女天堂网av| 日本欧美视频在线免费| 天天日夜夜操人人爽| 黄色网络中文字幕日本| 国产探花自拍亚洲av| 青青青免费手机视频在线观看| 九一精品人妻一区二区三区| 999久久久人妻精品一区| 91麻豆精品国产在线| 成人人妻h在线观看| 好看的日本中文字幕在线观看二区 | 亚洲黄色成人一级片| 福利小视频免费在线| 欧美成人区一区二区三| 日日夜夜免费视频精品| ass亚洲熟女ass| 日本高清有码在线视频| 日韩欧美中文字幕老司机三分钟| 91久久久精品成人国产| 久久久国产精品免费视频网| av福利免费体验观看| 日本黄色一级电影网址| 裸露视频免费在线观看| 国产亚洲综合5388| 国产91九色视频在线观看| 青青在线免费手机播放视频| 亚洲色视频在线播放网站| 青娱乐免费最新视频| 天天干夜夜爽狠狠操| 老司机伊人99久久精品| 川上优所有中文字幕在线| 国产资源网站在线播放| 国产天堂av不卡网| 国产高清视频www夜色资源| 欧美黑人1区2区3区| 自拍偷拍色图亚洲天堂| 亚洲免费在线不卡视频| 99re这里是国产精品首页| 亚洲一区二区精品在线播放| 神马不卡视频在线视频| 精品免费一区二区三区四区视频| 亚洲成人av在线一区二区| 蜜乳av一区二区三区免费观看| 成人午夜麻豆大胆视频| 免费在线观看亚洲福利| 青青操久久综合激情| 松本菜奈实最新av在线| 丰满少妇_区二区三区| 4日日夜夜精品视频免费| 国产在线小视频一区二区| 超碰在线免费观看视频97| 天天透天天舔天天操| 高潮喷水一区二区三区| 国产成人情侣激情视频| 97人妻av人人澡人人爽| 欧美性感美女热舞视频| 亚洲欧美国产人成在线| 一区二区三区婷婷中文字幕| 国产熟妇色xxⅹ交白浆视频| 女生抠逼自慰啊啊啊啊啊啊啊下载 | 在线免费观看欧美小视频| 美国伦理片午夜理论片| 欧洲亚洲一区二区三区四区| 免费中文三级在线观看| 97香蕉久久国产超碰| 不卡一二三区别视频| 青娱乐免费最新视频| 久久久西西gogo日本美女人体| 新亚洲天堂男子av| 国产精品成人免费电影| 荣立三等功退休有什么待遇| 亚洲18片综合国产av| 成人资源中文在线观看| 欧美一级特黄大片做受99| 大乳人妻一区二区三区| ass亚洲熟女ass| 午夜美女福利视频在线| 国产肥胖熟女又色又爽免费视频| 在线观看中文字幕少妇av| 国产精品午夜无码AV体验区| 亚洲美女色www色| 欧美插插插插插插| 日韩国产欧美久久一区| 西野翔人妻中文字幕中字在| 免费中文三级在线观看| 猫咪亚洲中文在线中文字幕| 一级毛片特级毛片免费的| 放荡人妻极品少妇全集| 久久99精品热在线观看| 亚洲乱码av一区二区蜜桃av| 亚洲精品1卡2卡3卡| 欧美日韩在线观看免费播放| 全彩漫画口工18禁| 丝袜美女诱惑佐佐三上| 98热视频精品在线观看| 一级做性色a爱片久久片| 亚洲一区二区在线视频观看免费| 久久国产精品久精国产爱| 在线观看黄页网站视频网站| av 资源在线播放| 国产资源网站在线播放| ass亚洲熟女ass| 美女黄色啊啊啊啊视频| 亚洲综合天堂av网站在线观看| 新亚洲天堂男子av| 熟女俱乐部jukujoclub| 91国产精品乱码久久久久久| 外国美女舔男人坤坤| 国产成人91色精品免费看片| 99精品久久一区二区| 精品免费一区二区三区四区视频| 亚洲精品一区二区gif| 亚洲成人 国产精品| 69av精品国产探花| 日本不卡视频一二三区| 中文字幕亚洲无线乱码| 蜜臀一区二区日韩美女少妇视频| 懂色av之国产精品| 日本一区二区三区区别| 男人av一区二区三区| 啊~插得好快别揉我胸了视频| 婷婷色九月综合激情丁香| 欧美久久一区二区伊人| 都市激情校园春色 亚洲| 亚洲av激情综合网| avgo成人短视频| 日本黄色一级电影网址| 亚洲高清免费在线观看视频| 久久久久夜色国产精品电影| 日韩人妻精品久久久久| 91九色尤物无套内射| 青青草一个释放的网站| 岳母的诱惑电影在线观看| 东京热日韩av影片| 青青操天堂在线观看视频| 91精品视频在线观看视频| 中文字幕亚洲无线乱码| 久久久西西gogo日本美女人体| 亚洲成人五月婷婷久久综合| 亚洲第一区av中文字幕| 外国美女舔男人坤坤| 九色porny91国产| 精品国产污污污污免费观看| 一区二区三区婷婷中文字幕| 成人做爰av在线观看网站| 午夜精品视频免费观看| 欧美日韩高清片在线观看| 黄色片免费国产精品| 38av一区二区三区| 国产清纯一区二区在线观看| 久久久亚洲综合国产精品| 久久99嫩草99久久精品| 中文字字幕在线精品乱码| 不用付费特黄特色亚洲特级黄色片| 国产91九色视频在线观看| 亚洲av中文免费在线| 国产精品网站的黄色| 亚洲av在线免费播放| 国产经典精品欧美日韩| 午夜野花视频在线观看| 免费啪啪啪网站在线观看| 亚洲精品乱码久久久久app| 亚洲国内精品久久久久久久| 国产一区两区三区福利小视频| 天天爽天天操天天插| 69国产精品成人aaaaa片| 三区美女视频在线观看| 在线播放 日韩 av| 亚洲成人中文无码在线| 国产美女视频带a∨黄色片| 亚洲欧美精品日韩偷拍| 午夜精品视频免费观看| 中文字幕丰满子伦无码专区 | 亚洲中文字幕在线视频观看二区| 亚洲精品国品乱码久久久久| 在线中文字幕人妻av| 亚洲美女色www色| 久久久久高潮白浆久久| 川上优所有中文字幕在线| 日本高清在线观看不卡视频| 91 精品视频在线看| 成人av在线视频免费| 东京热日韩av在线| 蜜乳视频一区二区三区| 手机看片1024精品国产| 黄版视频在线免费观看| 黄色片免费国产精品| 91九色国产在线视频| 美国十次了亚洲天堂网国产| 亚洲高清一区二区三区久久| 中文字幕日韩首页欧美在线激情| 亚洲成人,国产精品| av无限看熟女人妻另类av| 亚洲午夜熟女在线观看| xxoo福利视频导航| 蜜臀一区二区日韩美女少妇视频| 欧美激情视频第一页| xxoo福利视频导航| 91偷拍被偷拍在线播放| 日韩激情亚洲国产欧美另类激情| tobu8日本高清| 有码一区二区三区四区五区| 久久久久久免费观看av| 西野翔人妻中文字幕中字在| 国产成人av在线你懂得| 欧美日本在线免费视频| 女人高潮潮呻吟喷水网站| 超碰在线观看97资源| 欧美日韩不卡视频合集| 日韩A级毛片免费视频| 最新日韩中文字幕啪啪啪| 天堂一区二区三区在线等| 性感美女人妻久久久| 国产做A爱免费视频在线观看| av男人站在线观看| 国产成人在线观看视频播放| 中文字幕亚洲乱码精品无限| 2020国产成人精品视频| 老司机在线视频福利观看| 男人资源站中文字幕| 360偷拍蜜桃臀69式| 国产91九色视频在线观看| 天天爱天天日天天爽| 夜色福利视频免费观看| 川上优所有中文字幕在线| 天天干天天操天天要| 福利美女视频在线观看| 白白色在线免费视频发布视频| 成人精品动漫一区二区| 岛国av成人午夜高清| 中文字幕亚洲乱码精品无限| 亚洲成人 国产精品| 国产igao激情在线视频入口| 日韩av水蜜桃一区二区三区| 亚洲精品1卡2卡3卡| 天天干天天操天天要| 91日本精产品一区二区三区| 午夜8050免费小说| 一二三四区国产在线观看| 岛国av成人午夜高清| 亚洲经典av中文字幕| 麻豆白洁少妇在线播放| 亚洲国产日韩精品在线| 色丁香久久激情综合网| 午夜92福利1000| 91精品国产成人久久久久久| 日韩美精品成人一区二区三区四区| 色老头一区二区三区四区五区| 日本一区二区三区区别| 日韩成人免费观看电影| 视频自拍偷拍视频自拍| 91日本精产品一区二区三区| 视频自拍偷拍视频自拍 | 久久久久久久岛国免费观看 | 亚洲国产精品一区51动漫| av日韩视频在线观看| 日韩激情亚洲国产欧美另类激情| 精品美女洗澡一区二区| 熟女一区二区视频在线| 福利在线国产小视频| 一区二区三区国产精华液区别大吗 | 国产福利三级在线观看| 亚洲午夜熟女在线观看| 一区二区三区观看在线| 男人资源站中文字幕| 天天插天天干天天狠| 中文字幕免费啪啪啪| 自拍丝袜国产欧美日韩| lutu玩弄人妻短视频| 日本黄色一级电影网址| 69xx精品久久久久| xxnxx国产美女| 天天操天天干天天谢| 久久精品四虎夜夜拍拍拍| 日本人妻熟妇丰满成熟HD系列| 每日更新日韩欧美在线| 男插女视频大全免费| 亚洲一区二区三区无码在线| 免费成人av麻豆| 川上优所有中文字幕在线| 美女福利网站在线播放| 欧美插插插插插插| 亚洲欧美另类丝袜另类自拍 | 久草久热这里只有精品| av激情四射五月婷婷| 中文字幕在线字幕乱码怎么设置| 亚欧洲乱码视频一二三区| 五月天男人的天堂中文字幕 | 亚洲国内精品久久久久久久| 9999久久久久老熟妇二区| 92午夜免费福利视频www| 日韩国产欧美久久一区| 国产美女主播av在线| 黑川堇人妻88av| 2019年中文字幕在线播放视频| xxnxx国产美女| 亚洲国产精品久久久久久无码| 麻豆国产精品777777在| 色屁屁一区二区三区在线观看| 人妻少妇视频系列视频在线 | 无码精品黑人一区二区老人| 日本高清久久人人爽| 综合久久伊人久久88 | 182tv精品免费在线观看| 中文字幕一区二区三区久久久| 日韩男女视频网站在线观看| 中文字幕在线免费观看人妻| 精品国产污污污免费入口| 亚洲精品1卡2卡3卡| 黑人侵犯人妻森泽佳奈| 天天搞天天操天天干| 丝袜美女诱惑佐佐三上| 五月婷婷伊人久久中文字幕| 日韩美精品成人一区二区三区四区 | 成年人免费黄色av| 性感人妻 中文字幕| 久草久热这里只有精品| yy4080黄色片| 天堂网成人av电影| 国产成人情侣激情视频| 69精品人妻久久久久久久久久久| 色狠狠色综合久久久绯色| 欧美成人区一区二区三| 国产成人91色精品免费看片| 日本高清在线观看不卡视频| 免费高清av一区二区| 国产中文亚洲熟女日韩| 黄片操操操操操操c| 亚洲午夜精品视频节目| 岳的大肥屁熟妇五十路| 国产极品气质外围av| 大香焦一道本一区二区三区| 久久午夜免费鲁丝片| 99久久免费播放在线观看视频| 蜜臀一区二区日韩美女少妇视频| 欧美成人一二三在线网| 搞乱在线在线观看视频| 久久久久国产精品二区| 2021国产在线视频| 日本成年视频在线免费观看| 日本老熟妇av老熟妇| 国产黄色主播网址大全在线播放| 色999日韩偷自拍拍免费| 国产av在线免费视频| 91精品国产人妻麻豆| 高清欧美色欧美综合网站| 欧美黄色一区二区三区视频| 免费24小时人妻视频| 大香焦一道本一区二区三区| 久草久热这里只有精品| 亚洲熟女一区二区六区| 51vv精品视频在线观看| 五月在线视频免费播放91| 大陆中文字幕视频在线| 中文字幕丰满子伦无码专区| 成年男女免费视频网站无毒| 亚洲gay视频在线观看| 在线观看免费啪啪啪| 在线观看视频免费一区二区三区| 亚洲天堂男人的天堂| www国产亚洲精品久久久| 汤姆提醒30秒中转进站口| 国产一区二区三区四区精| 天天色天天射天天日天天干| 亚洲精品色图1234| 美女福利视频一区二区三区四区| 国色天香一二三期区别大象| 亚洲综合天堂av网站在线观看| 免费绝清毛片a在线播放| av在线播放观看h| 婷婷一区二区三区五月丁| 一区二区三区 国产日韩欧美| 久久99精品久久久久久三级| 色就色综合偷拍区欧美在线| 国产精品无码无卡免费观| 男女啪啪啪网站在线观看免费| 国产av嗯嗯啊啊av| 欧美亚洲国产一区二区| 丝袜美腿日韩av一区| 在线人成视频免费观看尤物| 亚洲第一中文字幕成人| 大香焦一道本一区二区三区| 日韩成人免费观看电影| 成人午夜av电影网| 成熟了的熟妇毛茸茸| 亚洲欧美日韩中文在线观看| 亚洲熟女一区二区三区250p | 日本清纯中文字幕版| 松本菜奈实最新av在线| 女人扒开逼让男人操| 自拍偷自拍亚洲精品10p| 中文字幕丰满子伦无码专区| 国产大桥未久一区二区| 天天碰天天摸天天搞 | 丝袜美女诱惑佐佐三上| 久久久亚洲综合国产精品| 成人人妻h在线观看| 丝袜美腿日韩av一区| 亚洲欧美成人激情在线| 制服丝袜中文字幕熟女人妻| 天堂av在线最新地址| 亚洲欧美激情国产综合久久久| 国产 少妇 一区二区| 亚洲高清免费在线观看视频| 成人做爰av在线观看网站| 欧美大胆a级视频秒播| 免费啪啪啪网站在线观看| 蜜桃tv一区二区三区| 老熟妇一区二区三区v∧88| 日本亚洲精品视频在线观看| 全彩漫画口工18禁| 日本少妇丰满大bbb的小乳沟| 伊人精品久久一区二区| 国产精美视频精品视频精品| v天堂国产精品久久| 一区二区三区四区视频精品免费| 人妻超清中文字幕在线乱码| 亚洲欧美精品海量播放| 青娱乐免费视频一二三| 久久精品四虎夜夜拍拍拍| 久久无码高清免费视频| 欧美一级特黄大片在线| 91精品在线视频免费视频| 夜夜躁av麻豆男| 九十九步都是爱最后一步是尊严 | 大香蕉伊人97在线| 在线免费观看视频18| 国产伦理二区三区在干嘛呢| 日产国产欧美精品另类| 成人人妻h在线观看| 天天干天天日天天弄| 全国熟妇精品一区二区免费视频| 国产视频1区2区3区| 老色鬼精品视频在线观看播放| 青娱乐免费最新视频| 日本少妇人妻凌辱在线| 青青国产95免看视频| 夜夜操天天干夜夜操| 久久99嫩草99久久精品| 亚洲av中文免费在线| 91超碰九色porny| 污视频在线观看地址| 午夜国产精品免费视频| 懂色av之国产精品| 伊人网在线免费观看| 青娱乐这里只有精品| 国产精品免费看一区二区三区| 大奶熟妇激情操逼逼| 先锋人妻啪啪中文字幕| 国产自拍偷拍视频在线免费观看| 91精品综合久久久久久五月天| 最近最新最好看的中文字幕| 亚洲黄色成人一级片| 亚洲人人爽人人澡起碰av| 91久久精品美女高潮喷水白浆| 亚洲成人欧洲成人在线| 国产一级一国产一级毛片| 国产精品乱码高清在线观看h| 男人av一区二区三区| 老司机免费视频福利0| 亚洲精品乱码久久久久app| 亚洲欧美韩国日本一区二区| 天天搞天天操天天干| 偷拍欧美日韩另类图片| a级黄片免费观看| 少妇熟女天堂网av| 91精品综合久久久久久五月天| 中文字幕在线字幕乱码怎么设置| 黄色网络中文字幕日本| 欧美一区二区三区视频看| 91亚洲国产成人久久精品| 欧美日本在线免费视频| 2018中文字字幕人妻| 999国产精品视频免费看| 东京热日韩av在线| 久久久人妻免费视频| 成人人妻h在线观看| 日本美女爱爱视频网站| 成人午夜高清福利视频| 18在线观看免费观看| 一区二区九日韩美女| 91超碰九色porny| 午夜精品秘一区二区三区| 呻吟求饶的人妻中文字幕| 亚洲va999天堂va| 中文字幕日韩首页欧美在线激情| 中文乱码字幕人妻熟女人妻| 精久久久久久久久久久久| 69精品人妻久久久久久久久久久 | 福利小视频免费在线| 久久人妻诱惑我视频| 最新国产精品久久精品app| 亚洲欧美不卡专业视频| 日韩欧美一区二区三区免费看| 国产精品福利久久久久| 99re这里是国产精品首页| 可以直接看av网站| 小妹妹爱大棒棒免费观看视频 | 日本少妇熟女乱码一区二区| 开心五月综合激情婷婷| 亚成区一区二区人妻熟女| 99久久99九九九99九| 丰满少妇人妻一区二区三区蜜桃| 99re这里是国产精品首页| 最新国产午夜激情视频| 制服丝袜 中文字幕 日韩| 欧美男女一区二区三区| 天天插天天操天天射天天干| 青娱乐免费视频一二三| 国产福利一区二区三区在线观看| 美女福利网站在线播放| 天天日夜夜操人人爽| 全球高清中文字幕av| 国产夫妻视频在线观看免费| 青青国产95免看视频| 青青在线免费手机播放视频| 一二区二区不卡视频| 熟妇精品午夜久久久久| 亚洲国产精品自拍偷拍视频在线| 天天操天天干天天谢| 亚洲成人动漫av在线| 国产激情一区二区视频| 免费成人av麻豆| 69精品人妻久久久久久久久久久| 区一区二区三免费观看视频| 天天曰天天摸天天爽| 97视频人人爱麻豆| 天天在线播放日韩av| 一区二区三区四区 在线播放|