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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 人工智能 > 目标检测 >内容正文

目标检测

【目标检测实验系列】使用yolov3 spp训练西工大遥感数据集NWPU VHR-10(包括如何将NWPU VHR-10转为VOC格式和yolov3 spp实验调试的详细步骤,且附上训练完的权重文件)

發布時間:2024/3/13 目标检测 132 豆豆

目錄

    • 1. 文章主要內容
    • 2. 西工大數據集轉換為VOC格式數據集
      • 2.1 VOC數據集結構
      • 2.2 西工大數據集
      • 2.3 轉換格式
        • 2.3.1 構建與VOC類似的數據集文件結構(文件夾名可以自定義)
        • 2.3.2 數據預處理
    • 3. yolov3 spp 訓練NWPU-VHR-10 dataset
      • 3.1 源碼下載及其相關準備文件
      • 3.2 VOC格式數據集轉換為yolo格式
    • 4. yolov3 spp 項目參數解析、如何獲取best.pt以及定位到對應的epoch
      • 4.1 yolov3 spp 項目部分參數解析
      • 4.2 如何獲取best.pt以及定位到對應的epoch
    • 5. 本篇小結

1. 文章主要內容

? ? ? ?此篇博客為[目標檢測實驗系列]的首篇博客,該系列主要記錄在目標檢測實驗過程中的詳細步驟和所思所想,歡迎大家互相交流。

? ? ? ?本篇博客參考的主要內容來源于
? ? ? ?大彤小憶–使用Python將NWPU VHR-10數據集的格式轉換成VOC2007數據集的格式
? ? ? ?霹靂吧啦Wz–YOLOv3 SPP源碼解析-1代碼使用簡介

? ? ? ?本篇博客主要涉及兩個主體內容。第一個:將西工大遙感數據集NWPU VHR-10的格式轉為VOC通用的數據集。第二個:再次將轉換后的VOC格式的數據集轉變成yolov3 spp所需要格式的數據集,之后調試項目內容,達到成功跑通項目的要求。(通讀本篇博客大概需要10分鐘左右的時間)。

2. 西工大數據集轉換為VOC格式數據集

2.1 VOC數據集結構

? ? ? ?VOC通用數據集格式如下圖所示:

? ? ? ?特別注意以下幾點內容

? ? ? ?1.這里的箭頭表示的文件夾由外到內,比如VOCdevkit文件夾包含了VOC2012文件,而VOC2012文件夾包含Annotations、ImageSets和JPEGImages

? ? ? ?2.這里的VOC2012文件夾名字也可以換成VOC2007,代表不同的版本。事實上,只要保證整體的文件夾結構沒有問題,所有的文件夾名字都可以自定義,只需要在對應的模型代碼中指定好自定義的文件夾名字。

? ? ? ?3.和Annotations、ImageSets和JPEGImages同級目錄下,還有兩個文件夾SegmentationClass、SegementionObject。因為這里用不到,所以不過多贅述。各個文件內容代表什么,請各位同學自己研究。

2.2 西工大數據集

? ? ? ?特別注意:西工大數據集-(提取密碼:1234)
? ? ? ?西工大NWPU VHR-10數據集包含10種類別,其主要結構如下圖所示:
? ? ? ?特別注意以下幾點內容

? ? ? ?1.groud truth文件夾內容是坐標信息以及所對應的類別;positive image set文件夾內容是正樣本的圖片; negative image set文件夾內容是負樣本的圖片

2.3 轉換格式

2.3.1 構建與VOC類似的數據集文件結構(文件夾名可以自定義)

? ? ? ?本篇博客構建的文件結構如下圖所示:(用于存放轉換后的數據集)

2.3.2 數據預處理

? ? ? ?因為NWPU VHR-10數據集的positive image set圖片內容是從001.jpg-650.jpg,而negative image set圖片內容是從001.jpg到150.jpg。首先,需要將正樣本的數據和負樣本的數據合并,并且重寫進行順序編號處理,改成000001.jpg-000800.jpg。其中positive image set文件夾內的圖片被重命名為000001.jpg-000650.jpg,negative image set文件夾內的圖片被重命名為000651.jpg-000800.jpg。
? ? ? ?最后將這800張圖片存放在D:/deeplearning-by-liaohuan/object-detection/datasets/NWPU-VHR-10 dataset/nwpu-10/voc-nwpu-10/JPEGImages(注意:這里的文件夾路徑是自定義的,需按照每個同學文件夾的實際絕對路徑填寫),具體的轉換代碼如下所示:

import os import shutildef imag_rename(old_path, new_path,start_number = 0):filelist = os.listdir(old_path) # 該文件夾下所有的文件(包括文件夾)if os.path.exists(new_path) == False:os.mkdir(new_path)for file in filelist: # 遍歷所有文件Olddir = os.path.join(old_path, file) # 原來的文件路徑if os.path.isdir(Olddir): # 如果是文件夾則跳過continuefilename = os.path.splitext(file)[0] # 文件名filetype = os.path.splitext(file)[1] # 文件擴展名if filetype == '.jpg':Newdir = os.path.join(new_path, str(int(filename) + start_number).zfill(6) + filetype) # 用字符串函數zfill 以0補全所需位數shutil.copyfile(Olddir, Newdir)if __name__ == "__main__":# 解決positive image set文件夾中的重命名問題,start_number = 0old_path = "D:/deeplearning-by-liaohuan/object-detection/datasets/NWPU-VHR-10 dataset/positive image set/"new_path = "D:/deeplearning-by-liaohuan/object-detection/datasets/NWPU-VHR-10 dataset/nwpu-10/voc-nwpu-10/JPEGImages"imag_rename(old_path, new_path)# 解決negative image set文件夾中的重命名問題,start_number = 650old_path = "D:/deeplearning-by-liaohuan/object-detection/datasets/NWPU-VHR-10 dataset/negative image set/"new_path = "D:/deeplearning-by-liaohuan/object-detection/datasets/NWPU-VHR-10 dataset/nwpu-10/voc-nwpu-10/JPEGImages"imag_rename(old_path,new_path,start_number = 650)print("done!")

? ? ? ?特別注意以下幾點內容

? ? ? ?1.代碼需要修改的部分在main函數里面,分別是old_path、new_path一共兩對。其中old_path分別對應于西工大數據集的positive image set、negative image set文件夾路徑,而new_path對應于轉換合并后創建的新文件夾路徑,上面有提到。

? ? ? ?接下來處理Annoatations文件夾的內容:將NWPU VHR-10數據集的ground truth文件夾內的標注信息txt文件轉換為與VOC2007數據集的Annotations文件夾內的標注信息xml文件格式相同的xml文件,并重命名為000001.xml-000650.xml;由于negative image set文件夾內的圖片沒有對應的標注信息文件,所以生成包含圖片的size信息、不包含object的bounding box信息的xml文件,并命名為000651.xml-000800.xml,并且存放在路徑為D:/deeplearning-by-liaohuan/object-detection/datasets/NWPU-VHR-10 dataset/nwpu-10/voc-nwpu-10/Annoatations下(和上面一樣,這里也是自定義的路徑),具體的代碼如下所示:

from lxml.etree import Element,SubElement,tostring from xml.dom.minidom import parseString import xml.dom.minidom import os import sys from PIL import Image# 處理NWPU VHR-10數據集中的txt標注信息轉換成 xml文件 # 此處的path應該傳入的是NWPU VHR-10數據集文件夾下面的ground truth文件夾的目錄 # 即 path = "E:/Remote Sensing/Data Set/NWPU VHR-10 dataset/ground truth" def deal(path):files=os.listdir(path) # files獲取所有標注txt文件的文件名# 此處可以自行設置輸出路徑 按照VOC數據集的格式,xml文件應該輸出在數據集文件下面的Annotations文件夾下面outpath = "D:/deeplearning-by-liaohuan/object-detection/datasets/NWPU-VHR-10 dataset/nwpu-10/voc-nwpu-10/Annoatations/"# 如果輸出文件夾不存在,就創建它if os.path.exists(outpath) == False:os.mkdir(outpath)# 遍歷所有的txt標注文件,一共650個txt文件for file in files:filename=os.path.splitext(file)[0] # 獲取ground truth文件夾中標注txt文件的文件名,比如如果文件名為001.txt,那么filename = '001'sufix=os.path.splitext(file)[1]# 獲取標注txt文件的后綴名 判斷是否為txtif sufix=='.txt': # 標注txt文件中每一行代表一個目標,(x1,y1),(x2,y2),class_number來表示xmins=[] ymins=[]xmaxs=[]ymaxs=[]names=[]# num,xmins,ymins,xmaxs,ymaxs,names=readtxt(path + '/' + file) # 調用readtxt文件獲取信息,轉到readtxt函數path_txt = path + '/' + file # 獲取txt標注文件的路徑信息# 打開txt標注文件with open(path_txt, 'r') as f:contents = f.read() # 將txt文件的信息按行讀取到contents列表中objects=contents.split('\n') # 以換行劃分每一個目標的標注信息,因為每一個目標的標注信息在txt文件中為一行 for i in range(objects.count('')): objects.remove('') # 將objects中的空格移除num=len(objects) # 獲取一個標注文件的目標個數,objects中一個元素代表的信息就是一個檢測目標 # 遍歷 objects列表,獲取每一個檢測目標的五維信息for objecto in objects: xmin=objecto.split(',')[0] # xmin = '(563'xmin=xmin.split('(')[1] # xmin = '563' 可能存在空格xmin=xmin.strip() # strip函數去掉字符串開頭結尾的空格符ymin=objecto.split(',')[1] # ymin = '478)'ymin=ymin.split(')')[0] # ymin = '478' 可能存在空格ymin=ymin.strip() # strip函數去掉字符串開頭結尾的空格符xmax=objecto.split(',')[2] # xmax同理xmax=xmax.split('(')[1]xmax=xmax.strip()ymax=objecto.split(',')[3] # ymax同理ymax=ymax.split(')')[0]ymax=ymax.strip()name=objecto.split(',')[4] # 與上 同理name=name.strip()if name=="1 " or name=="1": # 將數字信息轉換成label字符串信息name='airplane'elif name=="2 "or name=="2":name='ship'elif name== "3 "or name=="3":name='storage tank'elif name=="4 "or name=="4":name='baseball diamond'elif name=="5 "or name=="5":name='tennis court'elif name=="6 "or name=="6":name='basketball court'elif name=="7 "or name=="7":name='ground track field'elif name=="8 "or name=="8":name='harbor'elif name=="9 "or name=="9":name='bridge'elif name=="10 "or name=="10":name='vehicle' else:print(path) # print(xmin,ymin,xmax,ymax,name)xmins.append(xmin)ymins.append(ymin)xmaxs.append(xmax)ymaxs.append(ymax)names.append(name)filename_fill = str(int(filename)).zfill(6) # 將xml的文件名填充為6位數,比如1.xml就改為000001.xmlfilename_jpg = filename_fill + ".jpg" # 由于xml中存儲的文件名為000001.jpg,所以還得對所有的NWPU數據集中的圖片進行重命名print(filename_fill)dealpath = outpath + filename_fill +".xml"# 注意,經過重命名轉換之后,圖片都存放在E:/Remote Sensing/Data Set/VOCdevkit2007/VOC2007/JPEGImages/中imagepath = "D:/deeplearning-by-liaohuan/object-detection/datasets/NWPU-VHR-10 dataset/nwpu-10/voc-nwpu-10/JPEGImages/" + filename_fill + ".jpg"with open(dealpath, 'w') as f:img=Image.open(imagepath) # 根據圖片的地址打開圖片并獲取圖片的寬 和 高width=img.size[0]height=img.size[1]# 將圖片的寬和高以及其他和VOC數據集向對應的信息writexml(dealpath,filename_jpg,num,xmins,ymins,xmaxs,ymaxs,names, height, width)# 同時也得給negative image set文件夾下面的所有負樣本圖片生成xml標注negative_path = "D:/deeplearning-by-liaohuan/object-detection/datasets/NWPU-VHR-10 dataset/negative image set/"negative_images = os.listdir(negative_path)for file in negative_images:filename = file.split('.')[0] # 獲取文件名,不包括后綴名filename_fill = str(int(filename) + 650).zfill(6) # 將xml的文件名填充為6位數。同時加上650,比如1.xml就改為00001.xmlfilename_jpg = filename_fill + '.jpg' # 比如第一個負樣本001.jpg的filename_jpg 為000651.jpg## 重命名為6位數print(filename_fill)## 生成不含目標的xml文件dealpath = outpath + filename_fill +".xml"# 注意,經過重命名轉換之后,圖片都存放在E:/Remote Sensing/Data Set/VOCdevkit2007/VOC2007/JPEGImages/中imagepath = "D:/deeplearning-by-liaohuan/object-detection/datasets/NWPU-VHR-10 dataset/nwpu-10/voc-nwpu-10/JPEGImages/" + filename_fill + ".jpg"with open(dealpath, 'w') as f:img = Image.open(imagepath)width = img.size[0]height = img.size[1]# 將寬高和空的目標標注信息寫入xml標注writexml(dealpath,filename_jpg,num = 0,xmins = [],ymins = [],xmaxs = [],ymaxs = [],names = [],width=width,height=height)# NWPU數據集中標注的五維信息 (x1,y1) denotes the top-left coordinate of the bounding box, # (x2,y2) denotes the right-bottom coordinate of the bounding box # 所以 xmin = x1 ymin = y1, xmax = x2, ymax = y2 同時要注意這里的相對坐標是以圖片左上角為坐標原點計算的 # VOC數據集對于包圍框標注的格式是bounding-box(包含左下角和右上角xy坐標# 將從txt讀取的標注信息寫入到xml文件中 def writexml(path,filename,num,xmins,ymins,xmaxs,ymaxs,names,height, width):# Nwpu-vhr-10 < 1000*600node_root=Element('annotation')node_folder=SubElement(node_root,'folder')node_folder.text="VOC2007"node_filename=SubElement(node_root,'filename')node_filename.text="%s" % filenamenode_size=SubElement(node_root,"size")node_width = SubElement(node_size, 'width')node_width.text = '%s' % widthnode_height = SubElement(node_size, 'height')node_height.text = '%s' % heightnode_depth = SubElement(node_size, 'depth')node_depth.text = '3'for i in range(num):node_object = SubElement(node_root, 'object')node_name = SubElement(node_object, 'name')node_name.text = '%s' % names[i]node_name = SubElement(node_object, 'pose')node_name.text = '%s' % "unspecified"node_name = SubElement(node_object, 'truncated')node_name.text = '%s' % "0"node_difficult = SubElement(node_object, 'difficult')node_difficult.text = '0'node_bndbox = SubElement(node_object, 'bndbox')node_xmin = SubElement(node_bndbox, 'xmin')node_xmin.text = '%s'% xmins[i]node_ymin = SubElement(node_bndbox, 'ymin')node_ymin.text = '%s' % ymins[i]node_xmax = SubElement(node_bndbox, 'xmax')node_xmax.text = '%s' % xmaxs[i]node_ymax = SubElement(node_bndbox, 'ymax')node_ymax.text = '%s' % ymaxs[i]xml = tostring(node_root, pretty_print=True) dom = parseString(xml)with open(path, 'wb') as f:f.write(xml)returnif __name__ == "__main__":# path指定的是標注txt文件所在的路徑path = "D:/deeplearning-by-liaohuan/object-detection/datasets/NWPU-VHR-10 dataset/ground truth"deal(path)print("done!")

? ? ? ?特別注意以下幾點內容
? ? ? ?1.代碼里只需要修改outpath 、negative_path、imagepath、path這四個變量的路徑值(也就是代碼里面所有和路徑相關的變量,都需要改成自己的實際路徑) ,其他不需要修改。修改后Annotations文件夾的部分內容如下:



? ? ? ?最后我們來處理ImageSets文件夾,我們對NWPU VHR-10數據集進行劃分,劃分為train、val、trainval、test四個文件(其中train代表訓練集數據信息,val代表驗證集數據信息,trainval代表訓練和驗證集合并的數據信息,test為測試集數據的信息)。需要注意到trainval、test組成了整個數據集的信息,仔細分清楚各個之間的關系。我們給出劃分數據集信息的代碼,劃分后的數據集信息存放在D:/deeplearning-by-liaohuan/object-detection/datasets/NWPU-VHR-10 dataset/nwpu-10/voc-nwpu-10/ImageSets/Main文件夾里面(注意:這里的路徑同樣是自定義路徑,不再做過多解釋),具體的代碼如下:

import os import randomtrainval_percent = 0.8 # 表示訓練集和驗證集(交叉驗證集)所占總圖片的比例 train_percent = 0.75 # 訓練集所占交叉驗證集的比例 xmlfilepath = 'D:/deeplearning-by-liaohuan/object-detection/datasets/NWPU-VHR-10 dataset/nwpu-10/voc-nwpu-10/Annotations' txtsavepath = 'D:/deeplearning-by-liaohuan/object-detection/datasets/NWPU-VHR-10 dataset/nwpu-10/voc-nwpu-10/ImageSets/Main' total_xml = os.listdir(xmlfilepath)num = 650 # 有目標的圖片數 list = range(num) tv = int(num * trainval_percent) # xml文件中的交叉驗證集數 tr = int(tv * train_percent) # xml文件中的訓練集數,注意,我們在前面定義的是訓練集占交叉驗證集的比例 trainval = random.sample(list, tv) train = random.sample(trainval, tr)ftrainval = open('D:/deeplearning-by-liaohuan/object-detection/datasets/NWPU-VHR-10 dataset/nwpu-10/voc-nwpu-10/ImageSets/Main/trainval.txt', 'w') ftest = open('D:/deeplearning-by-liaohuan/object-detection/datasets/NWPU-VHR-10 dataset/nwpu-10/voc-nwpu-10/ImageSets/Main/test.txt', 'w') ftrain = open('D:/deeplearning-by-liaohuan/object-detection/datasets/NWPU-VHR-10 dataset/nwpu-10/voc-nwpu-10/ImageSets/Main/train.txt', 'w') fval = open('D:/deeplearning-by-liaohuan/object-detection/datasets/NWPU-VHR-10 dataset/nwpu-10/voc-nwpu-10/ImageSets/Main/val.txt', 'w')for i in list:name = total_xml[i][:-4] + '\n'if i in trainval:ftrainval.write(name)if i in train:ftrain.write(name)else:fval.write(name)else:ftest.write(name)for i in range(150):num = str(651 + i).zfill(6) + '\n'ftest.write(num)ftrainval.close() ftrain.close() fval.close() ftest.close()print("done!")

? ? ? ?特別注意以下幾點內容
? ? ? ?1.代碼里修改的變量為xmlfilepath 、txtsavepath 、ftrainval、ftest、ftrain和fval.
? ? ? ?2.由于NWPU-VHR-10 dataset中只有positive image set文件夾中的650張圖片包含目標的標注信息,所以訓練集train及驗證集val只能在從這650張圖片中劃分,negative image set文件夾中的150張圖片不包含目標的標注信息,劃分在測試集test中.
? ? ? ?3.代碼中的trainval_percent 代表trainval.txt所占總數據集的比例,train_percent 代表在train.txt所占trainval.txt數據集(這里的總數據集是650張圖片,不包括不標注的150張圖片)的比例,千萬別搞混了,這里的比例自己也可以進行修改!這樣我們就成功的將西工大數據集轉為VOC格式的數據集了。最后,ImageSets的Main文件夾的內容為:

3. yolov3 spp 訓練NWPU-VHR-10 dataset

3.1 源碼下載及其相關準備文件

? ? ? ?前提說明:以下操作都在本地環境OK的情況下進行的,如果沒有配置好環境,請根據下面源碼鏈接里環境配置一欄一一配置完成
? ? ? ?首先下載yolov3 spp 源碼(yolov3 spp源碼鏈接),之后準備新建一個pascal_voc_classes.json放在源碼的data文件夾下(注意:如果源碼里面本來存在pascal_voc_classes.json,那么修改其內容如下即可),因為我們這里使用的NWPU-VHR-10 dataset數據集,所以種類一共有10類,其json文件的代碼如下所示:

{"airplane": 1,"ship": 2,"storage tank": 3,"baseball diamond": 4,"tennis court": 5,"basketball court": 6,"ground track field": 7,"harbor": 8,"bridge": 9,"vehicle": 10 }

? ? ? ?其json文件在源代碼的目錄擺放位置如下圖所示(data文件夾里面其他文件暫時先別管,后面會生成):


3.2 VOC格式數據集轉換為yolo格式

? ? ? ?使用源碼根目錄當中trans_voc2yolo.py腳本進行轉換,并在源碼下的data文件夾下生成my_data_label.names標簽文件.執行腳本前,需要根據自己的路徑修改trans_voc2yolo.py中的一些參數:(特別注意:這里的voc_root、voc_version正好對應于我們在上一部分處理得到的VOC格式的西工大數據集的最外面兩層的文件夾名字,其他的路徑按照以下代碼照搬即可

voc_root = "nwpu-10" voc_version = "voc-nwpu-10"# 轉換的訓練集以及驗證集對應txt文件 train_txt = "train.txt" val_txt = "val.txt"# 轉換后的文件保存目錄 save_file_root = "./my_yolo_dataset"# label標簽對應json文件 label_json_path = './data/pascal_voc_classes.json'

? ? ? ?轉換之后生成my_data_label.names標簽文件、以及train、val文件夾,其中文件夾內的labels為圖片的標簽,而image為圖片的路徑信息,生成的內容如下圖所示:



? ? ? ?然后,我們先來處理一下源碼cfg文件夾下的yolov3-spp.cfg文件,這里我們需要修改兩個參數,分別是如下代碼的filters、classes,特別注意:我們的種類是10,所以classes為10,filters的計算公式為(classes + 5)x3,所以filters為45.

[convolutional] size=1 stride=1 pad=1 filters=45 activation=linear[yolo] mask = 6,7,8 anchors = 10,13, 16,30, 33,23, 30,61, 62,45, 59,119, 116,90, 156,198, 373,326 classes=10 num=9 jitter=.3 ignore_thresh = .7 truth_thresh = 1 random=1

? ? ? ?之后使用源碼根目錄下的calculate_dataset.py腳本生成my_train_data.txt文件、my_val_data.txt文件以及my_data.data文件,并生成新的my_yolov3.cfg文件,執行腳本前,需要修改以下參數:

train_annotation_dir = "./my_yolo_dataset/train/labels" val_annotation_dir = "./my_yolo_dataset/val/labels" classes_label = "./data/my_data_label.names" cfg_path = "./cfg/yolov3-spp.cfg"

? ? ? ?特別注意:這里的train_annotation_dir、val_annotation_dir、classes_label、cfg_path 在之前的操作中都已經生成,只需要根據實際路徑進行相關修改(如果一直跟著我的操作,則不需要修改路徑)

? ? ? ?運行calculate_dataset.py腳本之后,會在data文件夾下生成my_train_data.txt文件、my_val_data.txt文件以及my_data.data文件,并在cfg文件夾下生成新的my_yolov3.cfg文件,如下圖所示:

? ? ? ?特別注意:至此,我們已經將NWPU-VHR-10 dataset的VOC格式數據集轉換成了yolo格式的數據集.

4. yolov3 spp 項目參數解析、如何獲取best.pt以及定位到對應的epoch

? ? ? ?首先,我們在上面yolov3 spp源碼鏈接預訓練權重下載地址一欄,下載相應的權重,博主使用的是yolov3-spp-ultralytics-512.pt權重,并存放在根目錄下的weight文件夾下,如下圖所示:

4.1 yolov3 spp 項目部分參數解析

? ? ? ?為了成功啟動項目,首先我們在項目中定位到train.py文件,找到如下代碼所在位置,將nw設置為0,因為博主是在windows下跑項目,所以需要設置為0:

nw = 0 # min([os.cpu_count(), batch_size if batch_size > 1 else 0, 8]) # number of workers windows默認設置為0

? ? ? 繼續在train.py文件的關注以下代碼:

if __name__ == '__main__':parser = argparse.ArgumentParser()parser.add_argument('--epochs', type=int, default=200)parser.add_argument('--batch-size', type=int, default=8)parser.add_argument('--cfg', type=str, default='cfg/my_yolov3.cfg', help="*.cfg path")parser.add_argument('--data', type=str, default='data/my_data.data', help='*.data path')parser.add_argument('--hyp', type=str, default='cfg/hyp.yaml', help='hyperparameters path')parser.add_argument('--multi-scale', type=bool, default=True,help='adjust (67%% - 150%%) img_size every 10 batches')parser.add_argument('--img-size', type=int, default=512, help='test size')parser.add_argument('--rect', action='store_true', help='rectangular training')parser.add_argument('--savebest', type=bool, default=True, help='only save best checkpoint')parser.add_argument('--notest', action='store_true', help='only test final epoch')parser.add_argument('--cache-images', action='store_true', help='cache images for faster training')parser.add_argument('--weights', type=str, default='weights/yolov3-spp-ultralytics-512.pt',help='initial weights path')parser.add_argument('--name', default='', help='renames results.txt to results_name.txt if supplied')parser.add_argument('--device', default='cuda:0', help='device id (i.e. 0 or 0,1 or cpu)')parser.add_argument('--single-cls', action='store_true', help='train as single-class dataset')parser.add_argument('--freeze-layers', type=bool, default=False, help='Freeze non-output layers')parser.add_argument('--seed', type=int, default=42,help='Random seed.')# 是否使用混合精度訓練(需要GPU支持混合精度)parser.add_argument("--amp", default=False, help="Use torch.cuda.amp for mixed precision training")opt = parser.parse_args()# 檢查文件是否存在opt.cfg = check_file(opt.cfg)opt.data = check_file(opt.data)opt.hyp = check_file(opt.hyp)print(opt)with open(opt.hyp) as f:hyp = yaml.load(f, Loader=yaml.FullLoader)print('Start Tensorboard with "tensorboard --logdir=runs", view at http://localhost:6006/')tb_writer = SummaryWriter(comment=opt.name)seed_torch(opt.seed)train(hyp)

? ? ? ?特別注意以下幾點:
? ? ? ?1.epoch為項目訓練的次數,batch_size為批量數,cfg指定到我們生成的my_yolov3.cfg(自己數據集生成的配置文件)路徑,其他的都是類似.

? ? ? ?2.代碼中的–seed是我后來添加進去的,這是為了能夠復現實驗效果而編寫的(注意,即使固定了隨機種子,兩次同樣的實驗也不保證實驗數據完全一樣,還有很大因素會影響最終的實驗結果,只能說盡可能減少兩次相同實驗的數據誤差),建議加上,其在seed_torch(opt.seed)中調用,seed_torch的函數也申明在train.py中(seed的具體取值可以自定義),代碼如下所示:

def seed_torch(seed=42):seed = int(seed)random.seed(seed)os.environ['PYTHONHASHSEED'] = str(seed)np.random.seed(seed)torch.manual_seed(seed)torch.cuda.manual_seed(seed)torch.cuda.manual_seed_all(seed)torch.backends.cudnn.deterministic = Truetorch.backends.cudnn.benchmark = Falsetorch.backends.cudnn.enabled = False

? ? ? ?3.特別注意到–savebest參數,我這里設置的是true,是因為我的需求只要最好生成的權重文件best.pt;如果想要每一個epoch的權重文件,設置為False即可

4.2 如何獲取best.pt以及定位到對應的epoch

? ? ? ?訓練完成之后,會生成一個best.pt存放在weight文件夾下,可yolov3 spp 項目本身不會告訴這個best.pt對應于哪一個epoch,因為我的需求是尋找到best.pt所對應epoch的map。我們在train.py文件夾中找到了best.pt即為map(0.5-0.9-all)最大一個所對應的epoch的權重,如下所示:

? ? ? ?仔細的發現,在訓練完畢之后,會生成存放每一個epoch控制臺輸出的信息在根目錄下的resultxxxx.txt文件中(xxxx中間代表的是數字,每個人或許都不相同),我們利用這個文件導入到excel表格中,找到第二列即為map(0.5-0.9-all)的值,這樣再通過excel表格公式就可以計算出這一列最大的值所對應的epoch,從而獲取到對應的map等相關數據。

5. 本篇小結

? ? ? ?本篇博客主要分析了從NWPU-VHR-10 dataset格式轉換為VOC,再次轉換為yolo格式,以及在模型配置、模型參數解析方法的內容,通過仔細一步步的實驗,完成了相關實驗要求。

? ? ? ?之所以比較啰嗦、詳細的寫實驗文章,最重要的是記錄實驗的所思所想。而且對于本人基礎比較差,網上的一些博客跳躍比較大,不太適合我,所以本人就詳細、一步步的記錄和分析實驗的心路歷程,希望能夠讓大家和自己能順心的閱讀。如在復現本文博客中有任何問題,請在評論區進行交流,這樣大家就會有更多的收獲,博主也會及時的進行交流。最后文末附上本人訓練好的權重文件,供大家以需要時使用

? ? ? ?本人訓練好的權重文件best.pt(提取密碼:1234)

總結

以上是生活随笔為你收集整理的【目标检测实验系列】使用yolov3 spp训练西工大遥感数据集NWPU VHR-10(包括如何将NWPU VHR-10转为VOC格式和yolov3 spp实验调试的详细步骤,且附上训练完的权重文件)的全部內容,希望文章能夠幫你解決所遇到的問題。

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

在线午夜电影神马影院 | 日韩精品中文字幕有码 | 99久久er热在这里只有精品15 | 国产精品一区二区免费视频 | 99久久99久久精品免费 | 九九免费在线观看 | 欧美成人性网 | 国产精品久久一区二区三区不卡 | 四虎成人精品永久免费av九九 | 午夜视频日本 | 中文字幕 第二区 | 国产欧美日韩视频 | 99精品久久久久久久久久综合 | 精品国产一区二区久久 | 国产精品一区二区av麻豆 | 91精品国产成 | 在线观看av片 | 国产欧美三级 | 91av播放| 精品在线免费观看 | 96av在线视频 | 久久久蜜桃 | 外国av网 | 91毛片在线| 丁香六月欧美 | 五月在线 | 精品人人人人 | 伊人婷婷 | 亚洲精品视频网址 | 成人免费网站在线观看 | 中文字幕视频观看 | 果冻av在线 | 在线观看av小说 | 国产香蕉视频 | 久久婷婷国产 | 久草精品免费 | 欧美日韩亚洲第一 | 欧美日韩亚洲国产一区 | 欧美日韩一区二区三区不卡 | 国产精品久久久久影院 | 2018亚洲男人天堂 | 精品视频不卡 | 亚洲精品在线观看免费 | 伊人一级 | 一本一道波多野毛片中文在线 | 日韩高清一区 | 亚洲手机av | 福利精品在线 | 91成人精品一区在线播放69 | 91精品在线播放 | 久久草在线免费 | 久久1电影院| 久久久久激情视频 | 在线播放亚洲激情 | 亚洲夜夜综合 | 久久视频精品在线观看 | 国产aa精品 | 婷婷精品在线 | 久久视频 | 亚洲 综合 专区 | 天天射天天添 | 久久草在线精品 | 麻豆传媒视频在线免费观看 | 麻豆系列在线观看 | 人人操日日干 | 丝袜护士aⅴ在线白丝护士 天天综合精品 | 91成年人在线观看 | 色www.| 中文久久精品 | 九九免费观看全部免费视频 | 色五丁香 | 激情视频91 | 91成年人网站 | 91传媒激情理伦片 | 在线免费观看一区二区三区 | 久久激情小视频 | 五月天婷婷狠狠 | 99精品国产aⅴ | 国产精品麻豆果冻传媒在线播放 | 日韩成人免费在线电影 | 午夜视频福利 | 蜜桃久久久 | 国产成人精品三级 | 九九热只有这里有精品 | 91人人爽人人爽人人精88v | 欧美日韩国产二区 | 99久久精品免费看国产麻豆 | 在线观看免费版高清版 | 欧美精品乱码久久久久 | 久久久久97国产 | 青青河边草观看完整版高清 | 国内外成人在线视频 | 久久欧美在线电影 | 国产69久久精品成人看 | 有码中文字幕在线观看 | 欧美激情综合五月色丁香 | 亚洲精品中文在线资源 | 久久成人在线视频 | av三级av | 久久乱码卡一卡2卡三卡四 五月婷婷久 | 日韩久久久久久久久久 | 激情www | 中文字幕麻豆 | 97人人超碰在线 | 久久久精品影视 | 日韩伦理片一区二区三区 | 色五月色开心色婷婷色丁香 | 国产精品丝袜久久久久久久不卡 | 日韩在线观看中文字幕 | 中文在线www| 国产在线视频资源 | 成年人免费观看在线视频 | 国产一级性生活 | 91在线精品秘密一区二区 | 精品一区二区免费视频 | 精品国产aⅴ麻豆 | 伊人小视频| 亚洲精品av在线 | 久久久网站 | 国产手机精品视频 | 国产一区二区在线观看视频 | 看片的网址 | 色婷婷97| 成人av av在线 | 狠狠操综合网 | 在线观看免费av片 | 亚洲成a人片在线观看中文 中文字幕在线视频第一页 狠狠色丁香婷婷综合 | 日韩欧美在线综合网 | 中文字幕中文字幕在线一区 | 日韩免费高清在线 | 91 中文字幕 | 超碰97在线看 | 日韩精品在线播放 | 久久黄色片 | 日本精品久久久久 | www在线免费观看 | 狠狠色狠狠色综合日日92 | 亚洲国产中文字幕在线观看 | zzijzzij亚洲日本少妇熟睡 | 精品在线观看一区二区 | 在线中文字幕av观看 | 欧美精品久久人人躁人人爽 | 国产黄色在线 | 欧美淫aaa免费观看 日韩激情免费视频 | 狠狠干美女| 欧美国产日韩在线视频 | 热九九精品| 日韩欧美在线中文字幕 | 国产精品第72页 | 中文字幕在线观看亚洲 | 亚洲精品网页 | 999视频精品 | 免费看黄视频 | 日韩二区在线观看 | 免费观看第二部31集 | 日韩av女优视频 | 国产特级毛片aaaaaaa高清 | 国产福利中文字幕 | 91av福利视频 | 国产91对白在线播 | 菠萝菠萝蜜在线播放 | 亚洲国产日韩av | 日韩激情在线 | 亚洲国产99 | 黄色网中文字幕 | 久久精精品视频 | 成人香蕉视频 | 亚洲精品一区二区三区四区高清 | 久久免费视频7 | 91精品在线观看视频 | 麻豆影视网站 | 婷婷久久五月天 | 久久精品系列 | 久久成人免费电影 | 久草在线中文视频 | 亚洲精品中文字幕在线观看 | 天天插天天干天天操 | 国产无吗一区二区三区在线欢 | 韩日av一区二区 | 久草香蕉在线视频 | 日韩免费一级a毛片在线播放一级 | 国产精品视频免费 | 狠狠色丁香婷婷综合久小说久 | 美女视频黄是免费的 | 天天干,夜夜操 | 欧美亚洲国产精品久久高清浪潮 | 免费福利视频导航 | 久久国产手机看片 | 国产精品一区二区果冻传媒 | 日韩视频在线播放 | 亚洲欧美视频在线 | 日韩 国产 | 激情av一区二区 | 在线观看色网 | 国产成人中文字幕 | 激情网站五月天 | 国产视频久久久 | 日韩精品高清视频 | 国产精品国产三级国产aⅴ无密码 | 香蕉视频免费看 | av免费福利 | 欧美精品在线免费 | 日韩三级一区 | 亚洲精品视频在线观看网站 | 日韩精品高清不卡 | 久久久久二区 | 国产精品第三页 | 精品国产成人在线影院 | 久久精品视频国产 | 日韩视频免费观看高清完整版在线 | 99精品视频一区二区 | 五月天激情开心 | 中文字幕第一页在线视频 | 在线观看的黄色 | 97在线精品 | 日韩视频中文字幕在线观看 | 伊人成人久久 | 国产午夜精品福利视频 | 天天射网 | 日韩在线观看中文字幕 | 久久久久北条麻妃免费看 | 成人黄色免费在线观看 | 国产精品入口66mio女同 | 日韩精品中文字幕在线播放 | 亚洲欧美va | 五月婷网站 | 免费成人在线观看视频 | 久久久久久久久综合 | 久久99爱视频 | 亚洲精品国产综合99久久夜夜嗨 | 91一区在线观看 | 久久精品免费电影 | 中文国产在线观看 | 夜夜爽88888免费视频4848 | 国产伦精品一区二区三区在线 | 久久五月天色综合 | 亚洲久草在线视频 | 视频在线观看日韩 | 午夜精品久久久久久久久久 | 超碰在线日韩 | 日韩精品免费在线视频 | 中文字幕在线观看视频一区二区三区 | 欧美91精品久久久久国产性生爱 | 欧美激情第一页xxx 午夜性福利 | 午夜电影久久 | 国产白浆在线观看 | 久久国产精品久久精品国产演员表 | 国产精品尤物视频 | 久久免费电影网 | 国产日韩欧美在线观看 | 国产成人av| 精品一区二区av | 国产精品99蜜臀久久不卡二区 | 91精品国产一区二区在线观看 | 日本mv大片欧洲mv大片 | 97免费在线观看视频 | 日日爽| 亚洲色影爱久久精品 | 91丨九色丨蝌蚪丰满 | 在线精品亚洲一区二区 | 国产va在线| 国产美女搞久久 | 欧美日韩不卡一区二区三区 | 美女黄视频免费 | 国内精品视频久久 | 亚洲精品美女视频 | 激情网婷婷 | 黄色成人小视频 | 亚洲精品美女 | 免费三级骚 | 国产日韩在线视频 | av导航福利 | 色网站国产精品 | 欧美成人猛片 | 国产一级黄 | 欧美午夜久久久 | 国产精品自在线 | 狠狠干五月天 | 国产精品乱码久久久久久1区2区 | 欧亚久久 | 国产精品久久久毛片 | 中文字幕一区二区三区久久 | 久草在线电影网 | 色99中文字幕 | 狠狠天天 | 久久久精品国产一区二区三区 | 九九九热 | 蜜臀91丨九色丨蝌蚪老版 | 九九综合九九 | 日本中文字幕在线一区 | 综合网伊人 | 天天se天天cao天天干 | 91视频观看免费 | 在线91精品| 日韩av一区二区在线影视 | 久久y| 西西444www大胆高清视频 | 亚洲精品福利在线观看 | 又爽又黄又刺激的视频 | www视频在线免费观看 | 中文字幕在线播放一区二区 | 国产淫片 | 亚洲丝袜一区二区 | 在线免费试看 | 探花系列在线 | 就要色综合 | av免费在线网站 | 日日精品 | 中文字幕在线视频网站 | 伊人久久在线观看 | 夜夜视频欧洲 | 欧美日韩国产一区二区在线观看 | 综合成人在线 | 超碰人人超碰 | 国产成人在线免费观看 | 色爱成人网 | 国产一级片免费视频 | 国产精品毛片一区二区在线看 | 亚洲乱码中文字幕综合 | 日韩在线视频观看免费 | 国产精品一区二区在线播放 | 91av福利视频| 伊人五月综合 | 国产高清在线免费视频 | 97**国产露脸精品国产 | 波多野结衣最新 | 精品国产乱码久久久久久久 | 中文字幕乱在线伦视频中文字幕乱码在线 | 国产成人精品综合 | 黄色免费在线看 | 免费男女羞羞的视频网站中文字幕 | 日韩最新在线视频 | av不卡中文 | 亚洲国产中文字幕 | 99热这里只有精品久久 | av天天色 | 涩涩网站在线观看 | 天天爱天天插 | 天天操天天射天天舔 | 在线国产日韩 | 国产亚洲精品久久久久久大师 | 99一区二区三区 | 日本激情中文字幕 | 久要激情网| 久久久久久国产精品999 | 97超碰在线免费 | 国产在线观看不卡 | 蜜桃麻豆www久久囤产精品 | 韩国在线视频一区 | 中文欧美字幕免费 | 成人av一二三区 | 免费久久网站 | www视频在线免费观看 | 亚洲自拍自偷 | 91免费黄视频 | 在线精品观看国产 | 久久草草热国产精品直播 | 久久国语露脸国产精品电影 | 欧美日韩国产一二三区 | 国产99在线免费 | 天天搞天天 | 在线观看一区二区精品 | 久草视频在线播放 | 国产精品久久久久永久免费观看 | av综合在线观看 | 欧美亚洲成人xxx | 亚洲国产成人久久综合 | 亚洲理论片在线观看 | 黄色三级久久 | 国产精品99久久99久久久二8 | 射久久久| 久久三级视频 | 精品一区 在线 | 国产成人精品在线 | 久久综合成人网 | 国产一级视频在线 | 亚洲成人xxx | 日韩免费三级 | 国产 精品 资源 | 色婷婷色 | 九热在线 | 中文字幕91 | 久久久国产精品一区二区三区 | 日韩在线第一区 | 不卡电影免费在线播放一区 | 九九亚洲视频 | 精品1区2区3区| 国产区 在线 | 99精品久久99久久久久 | 国产高清一区二区 | 亚洲国产操 | 欧美贵妇性狂欢 | 亚洲国产精品99久久久久久久久 | 国产美女网站视频 | 免费国产黄线在线观看视频 | 免费av影视 | 欧美成人性网 | 蜜桃麻豆www久久囤产精品 | 国产在线一区二区 | 国产成人三级 | 精品在线你懂的 | 91人人网| 天天干,天天干 | 免费看一及片 | 欧美激情xxxx | 中文十次啦| 亚洲男男gⅴgay双龙 | 一区二区 不卡 | 日韩电影黄色 | 国产成人亚洲在线观看 | 国产精品久久久久四虎 | 色噜噜噜噜 | 日韩视频在线不卡 | 人人狠狠综合久久亚洲婷 | 成人欧美一区二区三区黑人麻豆 | 麻豆传媒视频在线播放 | 在线视频 精品 | 在线看国产视频 | 日韩不卡高清 | 亚洲毛片一区二区三区 | 亚洲一区二区精品3399 | 欧美日韩中文在线观看 | 国内精品久久久久国产 | 青春草免费在线视频 | 婷婷丁香社区 | 久久深夜 | av福利免费 | 亚洲,播放 | 天天操综合网 | 亚洲精品一区二区三区四区高清 | 国产在线观看一 | 国产精品一区二区在线观看免费 | 国产精品久久久久久久久毛片 | 96久久| 日韩免费一级a毛片在线播放一级 | 国产高清成人av | 成人在线视频观看 | 少妇bbb搡bbbb搡bbbb′ | 狠狠干五月天 | 午夜精品福利影院 | 欧美最猛性xxxxx(亚洲精品) | 久久久久久高潮国产精品视 | 精品一区 在线 | 手机看国产毛片 | 国产一及片| 亚洲视频免费在线看 | 国产成人一级电影 | 久久狠狠一本精品综合网 | 国产一区国产二区在线观看 | 91av国产视频 | 亚洲精品动漫成人3d无尽在线 | 在线性视频日韩欧美 | 久久精品小视频 | 手机av在线免费观看 | 久久精品99国产精品日本 | 91麻豆精品国产91久久久更新时间 | 91精品国产麻豆 | 在线观看中文字幕一区二区 | 91久久丝袜国产露脸动漫 | 婷婷国产在线观看 | 天堂中文在线视频 | 久久国产精品视频 | 日韩欧美久久 | 国产精品18久久久久久久 | 狠狠色噜噜狠狠狠合久 | 伊人色**天天综合婷婷 | 在线免费91| 色悠悠久久综合 | 激情综合五月天 | 国产精品99久久久久久大便 | 久久久久免费网 | 亚洲国产精品成人女人久久 | 日韩网站在线看片你懂的 | 午夜久久久久久久久 | 狠狠躁夜夜躁人人爽超碰97香蕉 | 亚洲成人免费在线 | 国产精品视频大全 | 人人插人人草 | 亚洲精品国产电影 | 国产黄色免费观看 | 人人干人人爽 | 国产精品v欧美精品 | 亚洲更新最快 | 中文字幕免费一区 | 国产精品资源网 | 精品国产免费一区二区三区五区 | 99在线精品免费视频九九视 | 激情综合国产 | 免费看片黄色 | 国产精品久久久久久久久软件 | 久久久精品国产免费观看一区二区 | 新版资源中文在线观看 | 午夜av免费 | 日本中文字幕免费观看 | 久久成年人视频 | 果冻av在线 | 国产五月婷 | 国产视频在 | 国色天香在线 | 久久99精品久久久久久三级 | 天天干com| 欧美性护士 | 久久99精品国产99久久6尤 | 国产色视频网站 | 国产精品久久久久久高潮 | 在线观看免费国产小视频 | 99久久久国产精品免费99 | 人人超碰人人 | 91免费观看国产 | www.日日日.com | 青青射 | 99久久精品国产一区 | av片在线看| 黄a在线观看 | 中文字幕在线观看免费高清完整版 | 精品一二三四视频 | 天天看天天干 | 福利电影一区二区 | 精品在线视频播放 | 精品久久久久久电影 | 日日摸日日添日日躁av | 波多野结衣一区三区 | 日韩av在线网站 | 久久影视精品 | 黄色亚洲片 | 久久亚洲私人国产精品 | 久久精品中文字幕少妇 | www狠狠操| 在线观看小视频 | 久久一区二区免费视频 | 久久综合久久综合这里只有精品 | 91精品国产福利 | 免费网站v| 一区二区三区在线电影 | 亚洲免费不卡 | 91精品国产99久久久久久红楼 | 欧美午夜寂寞影院 | 久久av免费电影 | 精品福利在线视频 | 国产精品国产毛片 | 国产亚洲成人网 | 99久久久| 亚洲片在线资源 | 中文av不卡| 亚洲在线免费视频 | 日韩理论电影网 | 国产97在线观看 | 婷婷色中文字幕 | av高清一区 | 久久成人18免费网站 | 五月婷婷在线播放 | 97成人免费| 国产在线91精品 | 婷婷丁香在线 | 久久国内视频 | 最近中文字幕视频网 | 成人一区二区三区中文字幕 | 国产96在线视频 | 免费成人短视频 | 91成品人影院 | 激情综合久久 | 青青草国产精品视频 | 香蕉视频在线免费 | 亚洲欧美日韩一二三区 | 国产在线观看一区 | 久草视频视频在线播放 | 国产精品久久久久久久久久久免费 | 亚洲va男人天堂 | 日韩精品一区二区三区免费观看视频 | 国产色资源 | 欧美国产在线看 | 在线精品视频在线观看高清 | 操一草 | www.久久成人 | 激情在线网址 | 亚洲精品国产精品乱码不99热 | 国产精品欧美久久久久无广告 | 视频直播国产精品 | 最新影院| 成人综合婷婷国产精品久久免费 | 青青草国产免费 | 91网站免费观看 | 91中文在线视频 | 久久永久视频 | 婷婷激情5月天 | 国产伦精品一区二区三区照片91 | 97超碰人人澡 | 五月激情亚洲 | 国产伦精品一区二区三区高清 | 99国产精品久久久久久久久久 | 久久久久久久久久网 | www.国产在线观看 | 在线影视 一区 二区 三区 | 亚洲精品国产精品国产 | 天天色.com| 韩日三级av | 99国产视频| 日韩精品久久久免费观看夜色 | 欧美午夜精品久久久久 | 午夜黄网 | 黄色三级在线看 | bayu135国产精品视频 | 国产精品久久久久久久毛片 | 欧美天堂久久 | 国产免费一区二区三区最新 | 91在线播放视频 | 国产精品久久二区 | 中文字幕免费国产精品 | www.色午夜,com | 国产精品一区二区精品视频免费看 | 成人免费观看完整版电影 | 国产v在线 | 69av免费视频 | 精品视频一区在线观看 | www,黄视频| 精品国产亚洲一区二区麻豆 | 婷婷激情小说网 | 中字幕视频在线永久在线观看免费 | 天天色婷婷 | 日韩在线视频免费看 | 婷婷去俺也去六月色 | 99精品国产免费久久久久久下载 | 日本久久精品 | 中文字幕日本特黄aa毛片 | 国产一区二区不卡视频 | 免费av在线播放 | av大片免费在线观看 | 国产精品免费视频网站 | 亚洲精品视频www | 亚洲欧美成人在线 | 国产精品av电影 | 精品欧美一区二区在线观看 | 热久久视久久精品18亚洲精品 | 91网免费看 | 日韩最新理论电影 | aaa日本高清在线播放免费观看 | 日韩欧美一区视频 | 久久激五月天综合精品 | 欧美一级特黄aaaaaa大片在线观看 | 深夜免费小视频 | 天天操天天干天天爽 | 中文在线免费视频 | 综合国产视频 | 最近日韩免费视频 | 国产一级视频在线 | 中文字幕有码在线 | 一区视频在线 | 玖玖视频 | 不卡视频一区二区三区 | 欧美日韩国产二区 | 91cn国产在线 | 一级片在线 | 日日综合 | av在线永久免费观看 | 伊人狠狠操| 久久毛片网 | 中文字幕乱在线伦视频中文字幕乱码在线 | 丁香激情综合国产 | 国产专区在线看 | 亚洲免费观看视频 | 欧美激情视频三区 | 99久久精品国产观看 | 日韩欧美综合 | 欧美精品被 | 亚洲欧洲精品在线 | 开心婷婷色 | 久99久在线视频 | 成人亚洲网 | 九九热av| 波多野结衣一区二区三区中文字幕 | 亚洲视频aaa| 色视频网站在线观看一=区 a视频免费在线观看 | 午夜av影院| 久久久www成人免费精品 | 色插综合 | 免费视频成人 | 久久色中文字幕 | 成年人在线观看免费视频 | 色婷婷综合久久久中文字幕 | 国产精品毛片一区二区在线 | 一区二区欧美激情 | 91免费视频黄 | 国产一区视频在线 | 国产精品成人久久 | 综合色伊人 | 亚州成人av在线 | 中文字幕 欧美性 | 久久激情日本aⅴ | www.在线观看视频 | 在线观看色网 | 久久久久久久久久久成人 | 中文字幕免费高 | 日日夜色| 日韩欧美在线中文字幕 | 99久在线精品99re8热视频 | 女人18毛片90分钟 | 伊人天天综合 | 国产在线播放一区二区三区 | 天天艹天天爽 | 四虎永久免费网站 | 在线网址你懂得 | 天天看天天干天天操 | 91.dizhi永久地址最新 | 99久久精品免费看国产一区二区三区 | 中文字幕色综合网 | 免费成人黄色av | 国产精品小视频网站 | 国产原创在线观看 | 国产成人精品av在线观 | 91亚洲精品在线 | 天天射网站| 久久久国产一区二区三区 | 亚洲丝袜一区 | 四虎成人网 | 国产精品18久久久久久久 | 人人爱夜夜操 | av中文字幕在线播放 | 日本少妇久久久 | 国产日韩欧美在线影视 | 久草网站在线 | 免费视频一级片 | 亚洲激情 欧美激情 | 国产免费资源 | 婷婷色狠狠 | 日韩在线观看一区 | 在线一区av| 97超碰在线免费观看 | www.看片网站 | 99久久毛片 | 国产色在线视频 | 日日摸日日添夜夜爽97 | 成人在线免费视频 | 日韩精品欧美一区 | 91在线精品观看 | 国产精品视频免费看 | 国产精品日韩高清 | 国产精品久久久影视 | 欧美亚洲另类在线视频 | 国产成人久久久77777 | 国产精品一区二区麻豆 | 97超碰在线人人 | 免费福利在线观看 | 中文字幕欧美日韩va免费视频 | 亚洲国产精品影院 | 人人草人| 国产黄色精品网站 | 婷婷亚洲综合 | 欧美日韩国产色综合一二三四 | 四虎在线观看精品视频 | 91视频啊啊啊 | 国产三级香港三韩国三级 | 久久国产精品偷 | 国产精品美女久久久久久久久 | 国产精品乱码一区二区视频 | 精品一二三区视频 | 天干啦夜天干天干在线线 | 亚洲精品在线一区二区 | 日日夜夜精品免费观看 | 国产精品美女久久久久久久久久久 | 色噜噜噜噜 | 午夜少妇| av看片在线观看 | 99久热精品 | 婷婷综合| 五月婷婷天堂 | 免费观看国产视频 | 日韩精品一区二区免费 | 超碰人人草人人 | 97超碰超碰久久福利超碰 | 97超碰人人澡 | 日韩中文在线视频 | 久久99国产精品自在自在app | 国产在线小视频 | 中文字幕之中文字幕 | 91重口视频| www视频在线免费观看 | 日韩av影视在线观看 | 久久久久久久国产精品影院 | 视频在线观看91 | 久久久免费av | 性日韩欧美在线视频 | 亚州精品天堂中文字幕 | 天天干天天操天天入 | 最近中文字幕高清字幕在线视频 | 夜夜夜夜夜夜操 | 99热.com| 精品亚洲视频在线观看 | 91黄色免费网站 | 亚洲电影av在线 | 亚洲视频 视频在线 | 四虎永久免费网站 | 国产精品亚洲精品 | 91伊人| 日日夜夜免费精品 | 久久人人爽人人爽人人片av免费 | 亚洲精品国精品久久99热 | 亚洲精品中文字幕在线观看 | 亚州成人av在线 | 午夜久久影视 | 视频一区在线免费观看 | 国产一区二区综合 | 亚洲美女免费精品视频在线观看 | 日韩精品专区在线影院重磅 | 日韩视频免费观看高清完整版在线 | 在线三级av| 亚洲精品视频免费看 | 天天爱天天干天天爽 | 国内少妇自拍视频一区 | 三级黄色理论片 | 成人黄色av网站 | 亚洲日本一区二区在线 | 天堂av在线网址 | 日韩在线视频精品 | 91精品黄色| 在线看av的网址 | 免费高清国产 | 激情欧美日韩一区二区 | 欧美日本高清视频 | 精品天堂av | 性色av免费看 | 久久久精品国产一区二区电影四季 | 亚洲黄色片在线 | 国产一区二区免费在线观看 | 黄网站色视频免费观看 | 在线观看日韩免费视频 | 久久男人中文字幕资源站 | 最新超碰在线 | 欧美精品一区二区在线播放 | 欧美日韩视频一区二区 | 国产精品第一视频 | 黄色网在线免费观看 | 色综合咪咪久久网 | 国产区精品在线观看 | 欧美精品成人在线 | 日韩在线视频观看免费 | 香蕉视频网站在线观看 | 在线电影日韩 | 日本在线中文在线 | 91 在线视频播放 | 91av99| 一级α片免费看 | 日韩av男人的天堂 | 麻豆视频观看 | www.日本色 | 天天干夜夜夜 | 欧美色综合久久 | 黄色在线网站噜噜噜 | 久久黄色网址 | 欧美日本国产在线观看 | 成人免费xxxxxx视频 | 欧美成人手机版 | 成年人免费电影 | 玖玖玖在线观看 | 在线免费观看一区二区三区 | 亚洲欧美精品一区二区 | 97高清免费视频 | 欧美巨大荫蒂茸毛毛人妖 | 99精品视频免费观看视频 | 麻豆一级视频 | 国产999在线观看 | 精品国产一区二区三区在线观看 | 国产无套视频 | 成人亚洲网 | 午夜精品久久久久久99热明星 | 久久综合国产伦精品免费 | 久久久久免费精品 | 中文字幕国产视频 | 国产成人333kkk | 丁香花在线观看免费完整版视频 | 久久久久99精品成人片三人毛片 | 久青草视频在线观看 | 久久99亚洲热视 | 二区三区中文字幕 | 在线视频久久 | 亚洲精品免费在线播放 | 日日操网 | 四虎成人精品在永久免费 | 亚洲资源在线网 | 最近中文字幕免费视频 | 免费的黄色的网站 | 欧美激情视频一二区 | 999成人精品| 国产精品完整版 | 在线免费成人 | 国产网站在线免费观看 | 一区二区亚洲精品 | 日日干日日色 | 国产中文字幕在线免费观看 | 高潮久久久 | 国产免费久久久久 | 精品视频久久 | 日韩激情小视频 | a级片在线播放 | 亚洲天天做 | 开心色婷婷 | 日韩美女免费线视频 | 91精品视频网站 | 亚洲精品久久久久久久不卡四虎 | 99久久久国产精品免费观看 | 国产情侣一区 | 91精品网站在线观看 | 婷婷伊人综合亚洲综合网 | 免费看国产黄色 | www久久九 | 久久系列 | 一区二区三区日韩在线观看 | 成年人免费电影在线观看 | 午夜私人影院久久久久 | 日韩a级免费视频 | 91免费视频黄 | 亚洲尺码电影av久久 | 日韩精品高清视频 | 亚洲日韩中文字幕在线播放 | 国产免费a | 中文字幕在线国产精品 | 亚洲国产精品久久久久久 | 国产黄网在线 | 久久综合九色综合久99 | 久久久精品久久日韩一区综合 | 久久综合福利 | 人人爽人人爽人人爽人人爽 | 国产精品专区在线 | 国产视频欧美视频 | 久久久久久久久爱 | 精品999国产| 国产中文字幕视频在线 | 在线免费观看国产 | 精品一区二区在线播放 | 国产专区在线播放 | 免费网站观看www在线观看 | 免费又黄又爽的视频 | 91av视频播放 | 中文字幕在线观看完整版 | 亚洲美女在线一区 | 精品国产乱码 | 国产精品视频地址 | 成人毛片一区二区三区 | 欧美一二三视频 | 丁香婷婷在线 | 18久久久久久 | av一区二区在线观看中文字幕 | 中文字幕免费在线 | 精品三级av | 久久国产热| 精品一区二区在线观看 | 欧美不卡视频在线 | 亚洲成av片人久久久 | 亚州国产精品 | 99热这里精品 | 国产中文字幕在线播放 | 国产最新91 | 亚洲视频 一区 | 综合网伊人 | 97超碰色 | 日韩精品一区二区三区电影 | 国产精品美女久久久久久网站 | 最新国产精品久久精品 | 成人在线免费观看网站 | 国产福利一区二区三区在线观看 | 97精品久久 | 97视频人人澡人人爽 | 中文字幕亚洲国产 | 午夜精品久久久久久久久久 | 日韩欧美精品在线观看视频 | 一区二区三区四区五区六区 | 日韩视频在线不卡 | 久久久99久久 | 狠狠操天天干 | 九九热免费观看 | 最新av观看 | 日本九九视频 | 亚洲播放一区 | 久久 地址| 香蕉免费 | 天天操天天操天天操天天 | 在线 成人 | 91视视频在线直接观看在线看网页在线看 | 久久久久成人精品 | 国产免费三级在线观看 | 国产精品久久久久aaaa | 91九色网址 | 久久试看 | 国产福利精品一区二区 | 精品欧美一区二区精品久久 | 亚洲午夜不卡 | 九九亚洲精品 | 欧美极品少妇xxxx | 精品国产乱子伦一区二区 | 亚洲综合色激情五月 | 色com | 国产日韩中文字幕在线 | 精品国产a | 亚洲视频axxx| 成人小视频在线 | 91天堂素人约啪 | 亚洲日本va午夜在线影院 | 波多野结衣在线播放视频 | 国产黄色高清 |