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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

详解视频中动作识别模型与代码实践

發布時間:2024/3/13 编程问答 69 豆豆
生活随笔 收集整理的這篇文章主要介紹了 详解视频中动作识别模型与代码实践 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
摘要:本案例將為大家介紹視頻動作識別領域的經典模型并進行代碼實踐。

本文分享自華為云社區《視頻動作識別》,作者:HWCloudAI。實驗目標

通過本案例的學習:

  • 掌握 C3D 模型訓練和模型推理、I3D 模型推理的方法;

注意事項

  • 本案例推薦使用TensorFlow-1.13.1,需使用?GPU?運行,請查看《ModelArts JupyterLab 硬件規格使用指南》了解切換硬件規格的方法;
  • 如果您是第一次使用 JupyterLab,請查看《ModelArts JupyterLab使用指導》了解使用方法;
  • 如果您在使用 JupyterLab 過程中碰到報錯,請參考《ModelArts JupyterLab常見問題解決辦法》嘗試解決問題。
  • 實驗步驟

    案例內容介紹

    視頻動作識別是指對一小段視頻中的內容進行分析,判斷視頻中的人物做了哪種動作。視頻動作識別與圖像領域的圖像識別,既有聯系又有區別,圖像識別是對一張靜態圖片進行識別,而視頻動作識別不僅要考察每張圖片的靜態內容,還要考察不同圖片靜態內容之間的時空關系。比如一個人扶著一扇半開的門,僅憑這一張圖片無法判斷該動作是開門動作還是關門動作。

    視頻分析領域的研究相比較圖像分析領域的研究,發展時間更短,也更有難度。視頻分析模型完成的難點首先在于,需要強大的計算資源來完成視頻的分析。視頻要拆解成為圖像進行分析,導致模型的數據量十分龐大。視頻內容有很重要的考慮因素是動作的時間順序,需要將視頻轉換成的圖像通過時間關系聯系起來,做出判斷,所以模型需要考慮時序因素,加入時間維度之后參數也會大量增加。

    得益于 PASCAL VOC、ImageNet、MS COCO 等數據集的公開,圖像領域產生了很多的經典模型,那么在視頻分析領域有沒有什么經典的模型呢?答案是有的,本案例將為大家介紹視頻動作識別領域的經典模型并進行代碼實踐。

    1. 準備源代碼和數據

    這一步準備案例所需的源代碼和數據,相關資源已經保存在 OBS 中,我們通過ModelArts SDK將資源下載到本地,并解壓到當前目錄下。解壓后,當前目錄包含 data、dataset_subset 和其他目錄文件,分別是預訓練參數文件、數據集和代碼文件等。

    import os import moxing as mox if not os.path.exists('videos'):mox.file.copy("obs://ai-course-common-26-bj4-v2/video/video.tar.gz", "./video.tar.gz")# 使用tar命令解壓資源包os.system("tar xf ./video.tar.gz")# 使用rm命令刪除壓縮包os.system("rm ./video.tar.gz") INFO:root:Using MoXing-v1.17.3- INFO:root:Using OBS-Python-SDK-3.20.7

    上一節課我們已經介紹了視頻動作識別有 HMDB51、UCF-101 和 Kinetics 三個常用的數據集,本案例選用了 UCF-101 數據集的部分子集作為演示用數據集,接下來,我們播放一段 UCF-101 中的視頻:

    video_name = "./data/v_TaiChi_g01_c01.avi"

    from IPython.display import clear_output, Image, display, HTML import time import cv2 import base64 import numpy as np def arrayShow(img):_,ret = cv2.imencode('.jpg', img) return Image(data=ret) cap = cv2.VideoCapture(video_name) while True:try:clear_output(wait=True)ret, frame = cap.read()if ret:tmp = cv2.cvtColor(frame, cv2.COLOR_BGR2RGB)img = arrayShow(frame)display(img)time.sleep(0.05)else:breakexcept KeyboardInterrupt:cap.release() cap.release()

    2. 視頻動作識別模型介紹

    在圖像領域中,ImageNet 作為一個大型圖像識別數據集,自 2010 年開始,使用此數據集訓練出的圖像算法層出不窮,深度學習模型經歷了從 AlexNet 到 VGG-16 再到更加復雜的結構,模型的表現也越來越好。在識別千種類別的圖片時,錯誤率表現如下:

    在圖像識別中表現很好的模型,可以在圖像領域的其他任務中繼續使用,通過復用模型中部分層的參數,就可以提升模型的訓練效果。有了基于 ImageNet 模型的圖像模型,很多模型和任務都有了更好的訓練基礎,比如說物體檢測、實例分割、人臉檢測、人臉識別等。

    那么訓練效果顯著的圖像模型是否可以用于視頻模型的訓練呢?答案是 yes,有研究證明,在視頻領域,如果能夠復用圖像模型結構,甚至參數,將對視頻模型的訓練有很大幫助。但是怎樣才能復用上圖像模型的結構呢?首先需要知道視頻分類與圖像分類的不同,如果將視頻視作是圖像的集合,每一個幀將作為一個圖像,視頻分類任務除了要考慮到圖像中的表現,也要考慮圖像間的時空關系,才可以對視頻動作進行分類。

    為了捕獲圖像間的時空關系,論文 I3D 介紹了三種舊的視頻分類模型,并提出了一種更有效的 Two-Stream Inflated 3D ConvNets(簡稱 I3D)的模型,下面將逐一簡介這四種模型,更多細節信息請查看原論文。

    舊模型一:卷積網絡 + LSTM

    模型使用了訓練成熟的圖像模型,通過卷積網絡,對每一幀圖像進行特征提取、池化和預測,最后在模型的末端加一個 LSTM 層(長短期記憶網絡),如下圖所示,這樣就可以使模型能夠考慮時間性結構,將上下文特征聯系起來,做出動作判斷。這種模型的缺點是只能捕獲較大的工作,對小動作的識別效果較差,而且由于視頻中的每一幀圖像都要經過網絡的計算,所以訓練時間很長。

    舊模型二:3D 卷積網絡

    3D 卷積類似于 2D 卷積,將時序信息加入卷積操作。雖然這是一種看起來更加自然的視頻處理方式,但是由于卷積核維度增加,參數的數量也增加了,模型的訓練變得更加困難。這種模型沒有對圖像模型進行復用,而是直接將視頻數據傳入 3D 卷積網絡進行訓練。

    舊模型三:Two-Stream 網絡

    Two-Stream 網絡的兩個流分別為?1 張 RGB 快照和?10 張計算之后的光流幀畫面組成的棧。兩個流都通過 ImageNet 預訓練好的圖像卷積網絡,光流部分可以分為豎直和水平兩個通道,所以是普通圖片輸入的 2 倍,模型在訓練和測試中表現都十分出色。

    光流視頻 optical flow video

    上面講到了光流,在此對光流做一下介紹。光流是什么呢?名字很專業,感覺很陌生,但實際上這種視覺現象我們每天都在經歷,我們坐高鐵的時候,可以看到窗外的景物都在快速往后退,開得越快,就感受到外面的景物就是 “刷” 地一個殘影,這種視覺上目標的運動方向和速度就是光流。光流從概念上講,是對物體運動的觀察,通過找到相鄰幀之間的相關性來判斷幀之間的對應關系,計算出相鄰幀畫面中物體的運動信息,獲取像素運動的瞬時速度。在原始視頻中,有運動部分和靜止的背景部分,我們通常需要判斷的只是視頻中運動部分的狀態,而光流就是通過計算得到了視頻中運動部分的運動信息。

    下面是一個經過計算后的原視頻及光流視頻。

    原視頻

    光流視頻

    新模型:Two-Stream Inflated 3D ConvNets

    新模型采取了以下幾點結構改進:

    • 拓展 2D 卷積為 3D。直接利用成熟的圖像分類模型,只不過將網絡中二維 $ N × N 的 filters 和 pooling kernels 直接變成的?filters?和?poolingkernels?直接變成 N × N × N $;
    • 用 2D filter 的預訓練參數來初始化 3D filter 的參數。上一步已經利用了圖像分類模型的網絡,這一步的目的是能利用上網絡的預訓練參數,直接將 2D filter 的參數直接沿著第三個時間維度進行復制 N 次,最后將所有參數值再除以 N;
    • 調整感受野的形狀和大小。新模型改造了圖像分類模型 Inception-v1 的結構,前兩個 max-pooling 層改成使用 $ 1 × 3 × 3 kernels and stride 1 in time,其他所有 max-pooling 層都仍然使用對此的 kernel 和 stride,最后一個 average pooling 層使用?kernelsandstride1intime,其他所有?max?pooling?層都仍然使用對此的?kernel?和?stride,最后一個?averagepooling?層使用 2 × 7 × 7 $ 的 kernel。
    • 延續了 Two-Stream 的基本方法。用雙流結構來捕獲圖片之間的時空關系仍然是有效的。

    最后新模型的整體結構如下圖所示:

    好,到目前為止,我們已經講解了視頻動作識別的經典數據集和經典模型,下面我們通過代碼來實踐地跑一跑其中的兩個模型:C3D 模型( 3D 卷積網絡)以及?I3D 模型(Two-Stream Inflated 3D ConvNets)。

    C3D 模型結構

    我們已經在前面的 “舊模型二:3D 卷積網絡” 中講解到 3D 卷積網絡是一種看起來比較自然的處理視頻的網絡,雖然它有效果不夠好,計算量也大的特點,但它的結構很簡單,可以構造一個很簡單的網絡就可以實現視頻動作識別,如下圖所示是 3D 卷積的示意圖:

    a) 中,一張圖片進行了 2D 卷積, b) 中,對視頻進行 2D 卷積,將多個幀視作多個通道, c) 中,對視頻進行 3D 卷積,將時序信息加入輸入信號中。

    ab 中,output 都是一張二維特征圖,所以無論是輸入是否有時間信息,輸出都是一張二維的特征圖,2D 卷積失去了時序信息。只有 3D 卷積在輸出時,保留了時序信息。2D 和 3D 池化操作同樣有這樣的問題。

    如下圖所示是一種 C3D 網絡的變種:(如需閱讀原文描述,請查看 I3D 論文 2.2 節)

    C3D 結構,包括 8 個卷積層,5 個最大池化層以及 2 個全連接層,最后是 softmax 輸出層。

    所有的 3D 卷積核為 $ 3 × 3 × 3$ 步長為 1,使用 SGD,初始學習率為 0.003,每 150k 個迭代,除以 2。優化在 1.9M 個迭代的時候結束,大約 13epoch。

    數據處理時,視頻抽幀定義大小為:$ c × l × h × w,,c 為通道數量,為通道數量,l 為幀的數量,為幀的數量,h 為幀畫面的高度,為幀畫面的高度,w 為幀畫面的寬度。3D 卷積核和池化核的大小為為幀畫面的寬度。3D?卷積核和池化核的大小為 d × k × k,,d 是核的時間深度,是核的時間深度,k 是核的空間大小。網絡的輸入為視頻的抽幀,預測出的是類別標簽。所有的視頻幀畫面都調整大小為是核的空間大小。網絡的輸入為視頻的抽幀,預測出的是類別標簽。所有的視頻幀畫面都調整大小為 128 × 171 $,幾乎將 UCF-101 數據集中的幀調整為一半大小。視頻被分為不重復的 16 幀畫面,這些畫面將作為模型網絡的輸入。最后對幀畫面的大小進行裁剪,輸入的數據為 $16 × 112 × 112 $

    3.C3D 模型訓練

    接下來,我們將對 C3D 模型進行訓練,訓練過程分為:數據預處理以及模型訓練。在此次訓練中,我們使用的數據集為 UCF-101,由于 C3D 模型的輸入是視頻的每幀圖片,因此我們需要對數據集的視頻進行抽幀,也就是將視頻轉換為圖片,然后將圖片數據傳入模型之中,進行訓練。

    在本案例中,我們隨機抽取了 UCF-101 數據集的一部分進行訓練的演示,感興趣的同學可以下載完整的 UCF-101 數據集進行訓練。

    UCF-101 下載

    數據集存儲在目錄 dataset_subset 下

    如下代碼是使用 cv2 庫進行視頻文件到圖片文件的轉換

    import cv2 import os # 視頻數據集存儲位置 video_path = './dataset_subset/' # 生成的圖像數據集存儲位置 save_path = './dataset/' # 如果文件路徑不存在則創建路徑 if not os.path.exists(save_path):os.mkdir(save_path) # 獲取動作列表 action_list = os.listdir(video_path) # 遍歷所有動作 for action in action_list:if action.startswith(".")==False:if not os.path.exists(save_path+action):os.mkdir(save_path+action)video_list = os.listdir(video_path+action)# 遍歷所有視頻for video in video_list:prefix = video.split('.')[0]if not os.path.exists(os.path.join(save_path, action, prefix)):os.mkdir(os.path.join(save_path, action, prefix))save_name = os.path.join(save_path, action, prefix) + '/'video_name = video_path+action+'/'+video# 讀取視頻文件# cap為視頻的幀cap = cv2.VideoCapture(video_name)# fps為幀率fps = int(cap.get(cv2.CAP_PROP_FRAME_COUNT))fps_count = 0for i in range(fps):ret, frame = cap.read()if ret:# 將幀畫面寫入圖片文件中cv2.imwrite(save_name+str(10000+fps_count)+'.jpg',frame)fps_count += 1

    此時,視頻逐幀轉換成的圖片數據已經存儲起來,為模型訓練做準備。

    4. 模型訓練

    首先,我們構建模型結構。

    C3D 模型結構我們之前已經介紹過,這里我們通過 keras 提供的 Conv3D,MaxPool3D,ZeroPadding3D 等函數進行模型的搭建。

    from keras.layers import Dense,Dropout,Conv3D,Input,MaxPool3D,Flatten,Activation, ZeroPadding3D from keras.regularizers import l2 from keras.models import Model, Sequential # 輸入數據為 112×112 的圖片,16幀, 3通道 input_shape = (112,112,16,3) # 權重衰減率 weight_decay = 0.005 # 類型數量,我們使用UCF-101 為數據集,所以為101 nb_classes = 101 # 構建模型結構 inputs = Input(input_shape) x = Conv3D(64,(3,3,3),strides=(1,1,1),padding='same',activation='relu',kernel_regularizer=l2(weight_decay))(inputs) x = MaxPool3D((2,2,1),strides=(2,2,1),padding='same')(x) x = Conv3D(128,(3,3,3),strides=(1,1,1),padding='same',activation='relu',kernel_regularizer=l2(weight_decay))(x) x = MaxPool3D((2,2,2),strides=(2,2,2),padding='same')(x) x = Conv3D(128,(3,3,3),strides=(1,1,1),padding='same',activation='relu',kernel_regularizer=l2(weight_decay))(x) x = MaxPool3D((2,2,2),strides=(2,2,2),padding='same')(x) x = Conv3D(256,(3,3,3),strides=(1,1,1),padding='same',activation='relu',kernel_regularizer=l2(weight_decay))(x) x = MaxPool3D((2,2,2),strides=(2,2,2),padding='same')(x) x = Conv3D(256, (3, 3, 3), strides=(1, 1, 1), padding='same',activation='relu',kernel_regularizer=l2(weight_decay))(x) x = MaxPool3D((2, 2, 2), strides=(2, 2, 2), padding='same')(x) x = Flatten()(x) x = Dense(2048,activation='relu',kernel_regularizer=l2(weight_decay))(x) x = Dropout(0.5)(x) x = Dense(2048,activation='relu',kernel_regularizer=l2(weight_decay))(x) x = Dropout(0.5)(x) x = Dense(nb_classes,kernel_regularizer=l2(weight_decay))(x) x = Activation('softmax')(x) model = Model(inputs, x) Using TensorFlow backend. /home/ma-user/anaconda3/envs/TensorFlow-1.13.1/lib/python3.6/site-packages/tensorflow/python/framework/dtypes.py:526: FutureWarning: Passing (type, 1) or '1type' as a synonym of type is deprecated; in a future version of numpy, it will be understood as (type, (1,)) / '(1,)type'._np_qint8 = np.dtype([("qint8", np.int8, 1)]) /home/ma-user/anaconda3/envs/TensorFlow-1.13.1/lib/python3.6/site-packages/tensorflow/python/framework/dtypes.py:527: FutureWarning: Passing (type, 1) or '1type' as a synonym of type is deprecated; in a future version of numpy, it will be understood as (type, (1,)) / '(1,)type'._np_quint8 = np.dtype([("quint8", np.uint8, 1)]) /home/ma-user/anaconda3/envs/TensorFlow-1.13.1/lib/python3.6/site-packages/tensorflow/python/framework/dtypes.py:528: FutureWarning: Passing (type, 1) or '1type' as a synonym of type is deprecated; in a future version of numpy, it will be understood as (type, (1,)) / '(1,)type'._np_qint16 = np.dtype([("qint16", np.int16, 1)]) /home/ma-user/anaconda3/envs/TensorFlow-1.13.1/lib/python3.6/site-packages/tensorflow/python/framework/dtypes.py:529: FutureWarning: Passing (type, 1) or '1type' as a synonym of type is deprecated; in a future version of numpy, it will be understood as (type, (1,)) / '(1,)type'._np_quint16 = np.dtype([("quint16", np.uint16, 1)]) /home/ma-user/anaconda3/envs/TensorFlow-1.13.1/lib/python3.6/site-packages/tensorflow/python/framework/dtypes.py:530: FutureWarning: Passing (type, 1) or '1type' as a synonym of type is deprecated; in a future version of numpy, it will be understood as (type, (1,)) / '(1,)type'._np_qint32 = np.dtype([("qint32", np.int32, 1)]) /home/ma-user/anaconda3/envs/TensorFlow-1.13.1/lib/python3.6/site-packages/tensorflow/python/framework/dtypes.py:535: FutureWarning: Passing (type, 1) or '1type' as a synonym of type is deprecated; in a future version of numpy, it will be understood as (type, (1,)) / '(1,)type'.np_resource = np.dtype([("resource", np.ubyte, 1)]) WARNING:tensorflow:From /home/ma-user/anaconda3/envs/TensorFlow-1.13.1/lib/python3.6/site-packages/tensorflow/python/framework/op_def_library.py:263: colocate_with (from tensorflow.python.framework.ops) is deprecated and will be removed in a future version. Instructions for updating: Colocations handled automatically by placer. WARNING:tensorflow:From /home/ma-user/anaconda3/envs/TensorFlow-1.13.1/lib/python3.6/site-packages/keras/backend/tensorflow_backend.py:3445: calling dropout (from tensorflow.python.ops.nn_ops) with keep_prob is deprecated and will be removed in a future version. Instructions for updating: Please use `rate` instead of `keep_prob`. Rate should be set to `rate = 1 - keep_prob`.

    通過 keras 提供的 summary () 方法,打印模型結構。可以看到模型的層構建以及各層的輸入輸出情況。

    model.summary()

    此處輸出較長,省略

    通過 keras 的 input 方法可以查看模型的輸入形狀,shape 分別為 (batch size, width, height, frames, channels) 。

    model.input <tf.Tensor 'input_1:0' shape=(?, 112, 112, 16, 3) dtype=float32>

    可以看到模型的數據處理的維度與圖像處理模型有一些差別,多了 frames 維度,體現出時序關系在視頻分析中的影響。

    接下來,我們開始將圖片文件轉為訓練需要的數據形式。

    # 引用必要的庫 from keras.optimizers import SGD,Adam from keras.utils import np_utils import numpy as np import random import cv2 import matplotlib.pyplot as plt # 自定義callbacks from schedules import onetenth_4_8_12 INFO:matplotlib.font_manager:font search path ['/home/ma-user/anaconda3/envs/TensorFlow-1.13.1/lib/python3.6/site-packages/matplotlib/mpl-data/fonts/ttf', '/home/ma-user/anaconda3/envs/TensorFlow-1.13.1/lib/python3.6/site-packages/matplotlib/mpl-data/fonts/afm', '/home/ma-user/anaconda3/envs/TensorFlow-1.13.1/lib/python3.6/site-packages/matplotlib/mpl-data/fonts/pdfcorefonts'] INFO:matplotlib.font_manager:generated new fontManager

    參數定義

    img_path = save_path # 圖片文件存儲位置 results_path = './results' # 訓練結果保存位置 if not os.path.exists(results_path):os.mkdir(results_path)

    數據集劃分,隨機抽取 4/5 作為訓練集,其余為驗證集。將文件信息分別存儲在 train_list 和 test_list 中,為訓練做準備。

    cates = os.listdir(img_path) train_list = [] test_list = [] # 遍歷所有的動作類型 for cate in cates:videos = os.listdir(os.path.join(img_path, cate))length = len(videos)//5# 訓練集大小,隨機取視頻文件加入訓練集train= random.sample(videos, length*4)train_list.extend(train)# 將余下的視頻加入測試集for video in videos:if video not in train:test_list.append(video) print("訓練集為:") print( train_list) print("共%d 個視頻\n"%(len(train_list))) print("驗證集為:") print(test_list) print("共%d 個視頻"%(len(test_list)))

    此處輸出較長,省略

    接下來開始進行模型的訓練。

    首先定義數據讀取方法。方法 process_data 中讀取一個 batch 的數據,包含 16 幀的圖片信息的數據,以及數據的標注信息。在讀取圖片數據時,對圖片進行隨機裁剪和翻轉操作以完成數據增廣。

    def process_data(img_path, file_list,batch_size=16,train=True):batch = np.zeros((batch_size,16,112,112,3),dtype='float32')labels = np.zeros(batch_size,dtype='int')cate_list = os.listdir(img_path)def read_classes():path = "./classInd.txt"with open(path, "r+") as f:lines = f.readlines()classes = {}for line in lines:c_id = line.split()[0]c_name = line.split()[1]classes[c_name] =c_id return classesclasses_dict = read_classes()for file in file_list:cate = file.split("_")[1]img_list = os.listdir(os.path.join(img_path, cate, file))img_list.sort()batch_img = []for i in range(batch_size):path = os.path.join(img_path, cate, file)label = int(classes_dict[cate])-1symbol = len(img_list)//16if train:# 隨機進行裁剪crop_x = random.randint(0, 15)crop_y = random.randint(0, 58)# 隨機進行翻轉is_flip = random.randint(0, 1)# 以16 幀為單位for j in range(16):img = img_list[symbol + j]image = cv2.imread( path + '/' + img)image = cv2.cvtColor(image, cv2.COLOR_BGR2RGB)image = cv2.resize(image, (171, 128))if is_flip == 1:image = cv2.flip(image, 1)batch[i][j][:][:][:] = image[crop_x:crop_x + 112, crop_y:crop_y + 112, :]symbol-=1if symbol<0:breaklabels[i] = labelelse:for j in range(16):img = img_list[symbol + j]image = cv2.imread( path + '/' + img)image = cv2.cvtColor(image, cv2.COLOR_BGR2RGB)image = cv2.resize(image, (171, 128))batch[i][j][:][:][:] = image[8:120, 30:142, :]symbol-=1if symbol<0:breaklabels[i] = labelreturn batch, labels batch, labels = process_data(img_path, train_list) print("每個batch的形狀為:%s"%(str(batch.shape))) print("每個label的形狀為:%s"%(str(labels.shape))) 每個batch的形狀為:(16, 16, 112, 112, 3) 每個label的形狀為:(16,)

    定義 data generator, 將數據批次傳入訓練函數中。

    def generator_train_batch(train_list, batch_size, num_classes, img_path):while True:# 讀取一個batch的數據x_train, x_labels = process_data(img_path, train_list, batch_size=16,train=True)x = preprocess(x_train)# 形成input要求的數據格式y = np_utils.to_categorical(np.array(x_labels), num_classes)x = np.transpose(x, (0,2,3,1,4))yield x, y def generator_val_batch(test_list, batch_size, num_classes, img_path):while True:# 讀取一個batch的數據y_test,y_labels = process_data(img_path, train_list, batch_size=16,train=False)x = preprocess(y_test)# 形成input要求的數據格式x = np.transpose(x,(0,2,3,1,4))y = np_utils.to_categorical(np.array(y_labels), num_classes)yield x, y

    定義方法 preprocess, 對函數的輸入數據進行圖像的標準化處理。

    def preprocess(inputs):inputs[..., 0] -= 99.9inputs[..., 1] -= 92.1inputs[..., 2] -= 82.6inputs[..., 0] /= 65.8inputs[..., 1] /= 62.3inputs[..., 2] /= 60.3return inputs # 訓練一個epoch大約需4分鐘 # 類別數量 num_classes = 101 # batch大小 batch_size = 4 # epoch數量 epochs = 1 # 學習率大小 lr = 0.005 # 優化器定義 sgd = SGD(lr=lr, momentum=0.9, nesterov=True) model.compile(loss='categorical_crossentropy', optimizer=sgd, metrics=['accuracy']) # 開始訓練 history = model.fit_generator(generator_train_batch(train_list, batch_size, num_classes,img_path),steps_per_epoch= len(train_list) // batch_size,epochs=epochs,callbacks=[onetenth_4_8_12(lr)],validation_data=generator_val_batch(test_list, batch_size,num_classes,img_path),validation_steps= len(test_list) // batch_size,verbose=1) # 對訓練結果進行保存 model.save_weights(os.path.join(results_path, 'weights_c3d.h5')) WARNING:tensorflow:From /home/ma-user/anaconda3/envs/TensorFlow-1.13.1/lib/python3.6/site-packages/tensorflow/python/ops/math_ops.py:3066: to_int32 (from tensorflow.python.ops.math_ops) is deprecated and will be removed in a future version. Instructions for updating: Use tf.cast instead. Epoch 1/1 20/20 [==============================] - 442s 22s/step - loss: 28.7099 - acc: 0.9344 - val_loss: 27.7600 - val_acc: 1.0000

    5. 模型測試

    接下來我們將訓練之后得到的模型進行測試。隨機在 UCF-101 中選擇一個視頻文件作為測試數據,然后對視頻進行取幀,每 16 幀畫面傳入模型進行一次動作預測,并且將動作預測以及預測百分比打印在畫面中并進行視頻播放。

    首先,引入相關的庫。

    from IPython.display import clear_output, Image, display, HTML import time import cv2 import base64 import numpy as np

    構建模型結構并且加載權重。

    from models import c3d_model model = c3d_model() model.load_weights(os.path.join(results_path, 'weights_c3d.h5'), by_name=True) # 加載剛訓練的模型

    定義函數 arrayshow,進行圖片變量的編碼格式轉換。

    def arrayShow(img):_,ret = cv2.imencode('.jpg', img) return Image(data=ret)

    進行視頻的預處理以及預測,將預測結果打印到畫面中,最后進行播放。

    # 加載所有的類別和編號 with open('./ucfTrainTestlist/classInd.txt', 'r') as f:class_names = f.readlines()f.close() # 讀取視頻文件 video = './videos/v_Punch_g03_c01.avi' cap = cv2.VideoCapture(video) clip = [] # 將視頻畫面傳入模型 while True:try:clear_output(wait=True)ret, frame = cap.read()if ret:tmp = cv2.cvtColor(frame, cv2.COLOR_BGR2RGB)clip.append(cv2.resize(tmp, (171, 128)))# 每16幀進行一次預測if len(clip) == 16:inputs = np.array(clip).astype(np.float32)inputs = np.expand_dims(inputs, axis=0)inputs[..., 0] -= 99.9inputs[..., 1] -= 92.1inputs[..., 2] -= 82.6inputs[..., 0] /= 65.8inputs[..., 1] /= 62.3inputs[..., 2] /= 60.3inputs = inputs[:,:,8:120,30:142,:]inputs = np.transpose(inputs, (0, 2, 3, 1, 4))# 獲得預測結果pred = model.predict(inputs)label = np.argmax(pred[0])# 將預測結果繪制到畫面中cv2.putText(frame, class_names[label].split(' ')[-1].strip(), (20, 20),cv2.FONT_HERSHEY_SIMPLEX, 0.6,(0, 0, 255), 1)cv2.putText(frame, "prob: %.4f" % pred[0][label], (20, 40),cv2.FONT_HERSHEY_SIMPLEX, 0.6,(0, 0, 255), 1)clip.pop(0)# 播放預測后的視頻 lines, columns, _ = frame.shapeframe = cv2.resize(frame, (int(columns), int(lines)))img = arrayShow(frame)display(img)time.sleep(0.02)else:breakexcept:print(0) cap.release()

    6.I3D 模型

    在之前我們簡單介紹了 I3D 模型,I3D 官方 github 庫提供了在 Kinetics 上預訓練的模型和預測代碼,接下來我們將體驗 I3D 模型如何對視頻進行預測。

    首先,引入相關的包

    import numpy as np import tensorflow as tf import i3d WARNING: The TensorFlow contrib module will not be included in TensorFlow 2.0. For more information, please see:* https://github.com/tensorflow/community/blob/master/rfcs/20180907-contrib-sunset.md* https://github.com/tensorflow/addons If you depend on functionality not listed there, please file an issue.

    進行參數的定義

    # 輸入圖片大小 _IMAGE_SIZE = 224 # 視頻的幀數 _SAMPLE_VIDEO_FRAMES = 79 # 輸入數據包括兩部分:RGB和光流 # RGB和光流數據已經經過提前計算 _SAMPLE_PATHS = {'rgb': 'data/v_CricketShot_g04_c01_rgb.npy','flow': 'data/v_CricketShot_g04_c01_flow.npy', } # 提供了多種可以選擇的預訓練權重 # 其中,imagenet系列模型從ImageNet的2D權重中拓展而來,其余為視頻數據下的預訓練權重 _CHECKPOINT_PATHS = {'rgb': 'data/checkpoints/rgb_scratch/model.ckpt','flow': 'data/checkpoints/flow_scratch/model.ckpt','rgb_imagenet': 'data/checkpoints/rgb_imagenet/model.ckpt','flow_imagenet': 'data/checkpoints/flow_imagenet/model.ckpt', } # 記錄類別文件 _LABEL_MAP_PATH = 'data/label_map.txt' # 類別數量為400 NUM_CLASSES = 400

    定義參數:

    • imagenet_pretrained :如果為 True,則調用預訓練權重,如果為 False,則調用 ImageNet 轉成的權重
    imagenet_pretrained = True # 加載動作類型 kinetics_classes = [x.strip() for x in open(_LABEL_MAP_PATH)] tf.logging.set_verbosity(tf.logging.INFO)

    構建 RGB 部分模型

    rgb_input = tf.placeholder(tf.float32, shape=(1, _SAMPLE_VIDEO_FRAMES, _IMAGE_SIZE, _IMAGE_SIZE, 3)) with tf.variable_scope('RGB', reuse=tf.AUTO_REUSE):rgb_model = i3d.InceptionI3d(NUM_CLASSES, spatial_squeeze=True, final_endpoint='Logits')rgb_logits, _ = rgb_model(rgb_input, is_training=False, dropout_keep_prob=1.0) rgb_variable_map = {} for variable in tf.global_variables():if variable.name.split('/')[0] == 'RGB':rgb_variable_map[variable.name.replace(':0', '')] = variable rgb_saver = tf.train.Saver(var_list=rgb_variable_map, reshape=True)

    構建光流部分模型

    flow_input = tf.placeholder(tf.float32,shape=(1, _SAMPLE_VIDEO_FRAMES, _IMAGE_SIZE, _IMAGE_SIZE, 2)) with tf.variable_scope('Flow', reuse=tf.AUTO_REUSE):flow_model = i3d.InceptionI3d(NUM_CLASSES, spatial_squeeze=True, final_endpoint='Logits')flow_logits, _ = flow_model(flow_input, is_training=False, dropout_keep_prob=1.0) flow_variable_map = {} for variable in tf.global_variables():if variable.name.split('/')[0] == 'Flow':flow_variable_map[variable.name.replace(':0', '')] = variable flow_saver = tf.train.Saver(var_list=flow_variable_map, reshape=True)

    將模型聯合,成為完整的 I3D 模型

    model_logits = rgb_logits + flow_logits model_predictions = tf.nn.softmax(model_logits)

    開始模型預測,獲得視頻動作預測結果。

    預測數據為開篇提供的 RGB 和光流數據:

    with tf.Session() as sess:feed_dict = {}if imagenet_pretrained:rgb_saver.restore(sess, _CHECKPOINT_PATHS['rgb_imagenet']) # 加載rgb流的模型else:rgb_saver.restore(sess, _CHECKPOINT_PATHS['rgb'])tf.logging.info('RGB checkpoint restored')if imagenet_pretrained:flow_saver.restore(sess, _CHECKPOINT_PATHS['flow_imagenet']) # 加載flow流的模型else:flow_saver.restore(sess, _CHECKPOINT_PATHS['flow'])tf.logging.info('Flow checkpoint restored') start_time = time.time()rgb_sample = np.load(_SAMPLE_PATHS['rgb']) # 加載rgb流的輸入數據tf.logging.info('RGB data loaded, shape=%s', str(rgb_sample.shape))feed_dict[rgb_input] = rgb_sampleflow_sample = np.load(_SAMPLE_PATHS['flow']) # 加載flow流的輸入數據tf.logging.info('Flow data loaded, shape=%s', str(flow_sample.shape))feed_dict[flow_input] = flow_sampleout_logits, out_predictions = sess.run([model_logits, model_predictions],feed_dict=feed_dict)out_logits = out_logits[0]out_predictions = out_predictions[0]sorted_indices = np.argsort(out_predictions)[::-1]print('Inference time in sec: %.3f' % float(time.time() - start_time))print('Norm of logits: %f' % np.linalg.norm(out_logits))print('\nTop classes and probabilities')for index in sorted_indices[:20]:print(out_predictions[index], out_logits[index], kinetics_classes[index]) WARNING:tensorflow:From /home/ma-user/anaconda3/envs/TensorFlow-1.13.1/lib/python3.6/site-packages/tensorflow/python/training/saver.py:1266: checkpoint_exists (from tensorflow.python.training.checkpoint_management) is deprecated and will be removed in a future version. Instructions for updating: Use standard file APIs to check for files with this prefix. INFO:tensorflow:Restoring parameters from data/checkpoints/rgb_imagenet/model.ckpt INFO:tensorflow:RGB checkpoint restored INFO:tensorflow:Restoring parameters from data/checkpoints/flow_imagenet/model.ckpt INFO:tensorflow:Flow checkpoint restored INFO:tensorflow:RGB data loaded, shape=(1, 79, 224, 224, 3) INFO:tensorflow:Flow data loaded, shape=(1, 79, 224, 224, 2) Inference time in sec: 1.511 Norm of logits: 138.468643 Top classes and probabilities 1.0 41.813675 playing cricket 1.497162e-09 21.49398 hurling (sport) 3.8431236e-10 20.13411 catching or throwing baseball 1.549242e-10 19.22559 catching or throwing softball 1.1360187e-10 18.915354 hitting baseball 8.801105e-11 18.660116 playing tennis 2.4415466e-11 17.37787 playing kickball 1.153184e-11 16.627766 playing squash or racquetball 6.1318893e-12 15.996157 shooting goal (soccer) 4.391727e-12 15.662376 hammer throw 2.2134352e-12 14.9772005 golf putting 1.6307096e-12 14.67167 throwing discus 1.5456218e-12 14.618079 javelin throw 7.6690325e-13 13.917259 pumping fist 5.1929587e-13 13.527372 shot put 4.2681337e-13 13.331245 celebrating 2.7205462e-13 12.880901 applauding 1.8357015e-13 12.487494 throwing ball 1.6134511e-13 12.358444 dodgeball 1.1388395e-13 12.010078 tap dancing

    點擊關注,第一時間了解華為云新鮮技術~

    總結

    以上是生活随笔為你收集整理的详解视频中动作识别模型与代码实践的全部內容,希望文章能夠幫你解決所遇到的問題。

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

    欧美成人性战久久 | 中文字幕一区二区三区在线观看 | 国产专区精品 | 美女网站免费福利视频 | 国色综合 | 久久蜜臀一区二区三区av | 香蕉影视app | 国产99一区二区 | 亚洲精品美女 | www.xxxx变态.com| 911精品美国片911久久久 | 91九色网站| 婷婷网站天天婷婷网站 | 成人综合婷婷国产精品久久免费 | 九色激情网 | 国产精品毛片网 | 日产乱码一二三区别在线 | 操操操日日日 | 九色91福利 | 久草综合在线观看 | 欧美一区二区三区在线视频观看 | 亚洲欧美视频在线播放 | 国产群p| 在线观看免费国产小视频 | 一区二区三区在线观看免费视频 | 国产精品久久久久久久久久妇女 | 最近字幕在线观看第一季 | 男女全黄一级一级高潮免费看 | 国产精品原创av片国产免费 | 日韩久久久久久久 | 伊人看片 | 麻豆综合网 | av免费看在线 | 青草视频在线免费 | 久青草视频| 一级黄色电影网站 | 亚洲欧美国产日韩在线观看 | 超碰在线9 | 黄色免费电影网站 | 国产97av | 国产麻豆精品久久 | 日韩大片在线看 | 97精品国产aⅴ | 中文字幕在线久一本久 | 国产999精品久久久久久绿帽 | 国产小视频免费在线网址 | 九月婷婷综合网 | 日日成人网 | 自拍超碰在线 | 在线播放亚洲激情 | 亚洲精品中文字幕视频 | 精品国产一区二区久久 | 天天操天天色天天 | 在线视频免费观看 | 久久成人麻豆午夜电影 | 国产色视频网站 | 亚洲视频www | 亚洲国产电影在线观看 | 99热最新地址 | 国产精品五月天 | 97视频播放| 黄色软件在线看 | 国产一区免费视频 | 99久久婷婷国产精品综合 | 在线亚洲小视频 | 国产精品久久久毛片 | 色a在线观看 | 精品二区视频 | www.夜夜骑.com| 91爱在线 | 性色av免费在线观看 | 国产精品久久久久免费 | 亚洲一区二区三区四区精品 | 中文字幕欧美日韩va免费视频 | 中文字幕在线视频一区二区三区 | 香蕉影视在线观看 | 久久午夜电影网 | 99久久精品无免国产免费 | 中文字幕在线视频一区二区 | 狠狠躁夜夜躁人人爽超碰97香蕉 | 亚洲国产精品日韩 | 欧美成人久久 | 男女免费av| 黄色三级免费片 | 91精品国产入口 | 日韩午夜一级片 | 狠狠狠狠狠狠干 | 在线观看黄色国产 | 亚洲经典视频在线观看 | a视频在线观看免费 | 99精品视频一区二区 | 91视频91色 | 久久久久国产成人精品亚洲午夜 | 国产精品久久久久久久久久久久午夜片 | 在线看成人片 | 欧美成人一区二区 | 国产日韩欧美自拍 | 有码中文字幕 | 福利片视频区 | 最近的中文字幕大全免费版 | 天天亚洲| 爱射综合| 91免费视频网站在线观看 | 欧美大片大全 | 国产精品夜夜夜一区二区三区尤 | 正在播放 国产精品 | 91在线视频在线观看 | 成人国产网站 | 亚洲成aⅴ人片久久青草影院 | 免费午夜在线视频 | 久久国产精品99久久久久久丝袜 | 国产女做a爱免费视频 | 欧美精品乱码99久久影院 | 99精品一区二区三区 | 九九99视频 | 国产一级在线看 | 国产午夜精品在线 | av丝袜制服| 免费看黄在线观看 | 国产不卡视频在线 | 天天摸天天操天天舔 | 久久久免费毛片 | 国内精品久久久久久久久久久久 | 国产色综合天天综合网 | 久久久首页 | 国产精品爽爽爽 | 美女免费视频观看网站 | 在线视频日韩 | 高清精品久久 | 国产精品一区二区在线免费观看 | 91视频91自拍 | 在线91视频 | 麻豆视频在线免费观看 | 欧美亚洲专区 | 亚洲影院一区 | 国产 字幕 制服 中文 在线 | 黄色成人在线观看 | 国产一区二区三区高清播放 | 碰超在线97人人 | 99综合久久 | www.com操 | 国产日韩视频在线播放 | 国产一区二区三区高清播放 | 久久综合天天 | 伊人国产在线观看 | 日韩免费高清 | 免费在线观看亚洲视频 | 久久国产成人午夜av影院潦草 | 国产传媒一区在线 | 天天操天天色天天射 | 黄色a在线| 一级淫片在线观看 | 91av视频免费在线观看 | 日韩一级电影在线 | 男女靠逼app | 亚洲综合视频在线播放 | 91福利小视频 | 国产精品手机视频 | 91av视频| 国产香蕉av| 亚洲精品免费观看视频 | 国产探花视频在线播放 | 国产精品不卡一区 | 久久久五月婷婷 | av综合网址 | 激情深爱| 国内精品久久久久影院男同志 | 久久久视频在线 | 日韩精品中文字幕av | 国产无遮挡又黄又爽在线观看 | 综合精品久久 | 伊人影院在线观看 | 日韩免费在线观看网站 | 亚洲国产一区二区精品专区 | av视屏在线播放 | 在线电影中文字幕 | 天堂av网址 | 久久国产精品系列 | 美女视频一区 | 国产精品久久久久久久久婷婷 | 怡红院久久 | 久久大片 | www.91国产| 99亚洲国产 | 国产在线观看一 | 丝袜少妇在线 | 91资源在线视频 | 97视频在线免费 | 一本一本久久a久久精品综合妖精 | 国产一级一片免费播放放 | 97超碰资源站 | 欧美日韩国产在线观看 | 久久9999久久 | 日本精品视频免费 | 五月天堂色| 五月激情电影 | 成人av中文字幕在线观看 | 最新av网址大全 | 精品久久五月天 | 成人黄视频 | 亚洲成成品网站 | 久久香蕉一区 | 国产成人久久av | 韩日av一区二区 | 97在线免费观看视频 | 亚洲a在线观看 | 亚洲dvd | 亚洲欧洲av在线 | 天天要夜夜操 | 日韩理论片在线观看 | 一区二区三区免费看 | 91精品亚洲影视在线观看 | 亚洲欧美日本一区二区三区 | 成人黄色短片 | 激情欧美丁香 | 日本最新中文字幕 | 激情网站网址 | 黄色国产在线观看 | 91片在线观看 | 日本久久中文 | 久久视精品 | 亚洲成人第一区 | 国产精品色婷婷视频 | 国产精品久久久久久久久软件 | 韩国精品福利一区二区三区 | 精品国产一区在线观看 | 最近中文字幕国语免费av | 视频在线在亚洲 | 国产精品破处视频 | avwww在线观看 | 国产精品一区二区三区视频免费 | 国产丝袜美腿在线 | 欧美少妇bbwhd| 日韩av专区 | 久草网在线 | 亚洲精品国 | 91成人在线免费观看 | av免费看av | 精品成人国产 | 欧美综合在线观看 | 日韩在线观看 | 黄色h在线观看 | 日韩成人在线一区二区 | 日本在线观看中文字幕 | 青草视频在线看 | 欧美另类巨大 | 日韩视频中文字幕在线观看 | 久久激情视频 久久 | 日韩簧片在线观看 | 午夜精品一区二区三区免费 | 四虎在线免费观看 | 午夜性盈盈| 国产玖玖精品视频 | 美女黄网久久 | 欧美激情一区不卡 | 亚洲在线精品视频 | 在线最新av | 黄色字幕网| 国产成人免费av电影 | 亚洲欧美日韩不卡 | 日韩免费一级a毛片在线播放一级 | 欧美激情视频一区二区三区 | 日韩有码欧美 | 911精品视频| 欧美日韩一区二区免费在线观看 | 91天堂素人约啪 | 成人久久久精品国产乱码一区二区 | 欧美a级在线免费观看 | 国产裸体视频网站 | 四虎永久国产精品 | 亚洲免费公开视频 | 五月婷婷丁香综合 | 91色在线观看 | 精品一区二区av | 亚洲第一色| 日韩欧美专区 | 97精品久久人人爽人人爽 | 日韩av影视在线观看 | 日本黄色免费播放 | 国内成人精品视频 | 日韩三级免费观看 | 一区精品在线 | 五月婷婷在线视频 | 啪啪免费观看网站 | 色综合网在线 | 一区二区理论片 | 成年人在线看片 | 日韩免费一区二区 | 伊人婷婷网 | 日韩av影视在线观看 | 视频一区在线免费观看 | 在线精品观看国产 | 天天色天天操综合 | 久艹视频在线观看 | 亚洲情婷婷 | 男女全黄一级一级高潮免费看 | 特级西西444www大精品视频免费看 | 久久久精品小视频 | 99性视频| 色网站免费在线观看 | 国产精品嫩草69影院 | 国产福利在线免费观看 | 日本精品久久久久中文字幕5 | 成人av网站在线观看 | 91久色蝌蚪| 国产 欧美 日本 | 久久一区二区三区国产精品 | 欧美日本中文字幕 | 国产精品video爽爽爽爽 | 九九热只有这里有精品 | avcom在线 | 97电影在线观看 | 亚洲综合国产精品 | 中文字幕高清免费日韩视频在线 | 国产国产人免费人成免费视频 | 久久亚洲欧美日韩精品专区 | 日日骑 | www色,com | 国产免费一区二区三区网站免费 | 国产精品入口麻豆 | 一区二区精品久久 | 国产精品亚洲成人 | 久久久人人爽 | 午夜精品久久久久久久99 | 中国黄色一级大片 | 久久久天天操 | 伊人婷婷激情 | 狠狠狠操| 天天夜夜亚洲 | 久久超级碰| www久| 丁香六月激情婷婷 | 九九九九色| 欧美精品一区二区三区四区在线 | 国产一区二区观看 | 精品99免费视频 | 一区二区三区高清在线 | 天天干天天拍天天操天天拍 | 爱情影院aqdy鲁丝片二区 | freejavvideo日本免费 | 日韩免费视频播放 | 超碰99在线 | 黄色一级动作片 | 天天操偷偷干 | 亚洲乱码久久久 | 日韩xxxx视频 | 成 人 黄 色 视频播放1 | 亚洲欧美国产日韩在线观看 | 日韩va亚洲va欧美va久久 | 中文字幕在线免费 | 欧美巨大荫蒂茸毛毛人妖 | 国产视频日韩 | 久久精品久久99精品久久 | 99国产在线视频 | 91天天操| 国产精品系列在线 | 玖草在线观看 | a色视频 | 国产在线精品一区 | 国产日韩欧美视频在线观看 | 欧美十八 | 九九久久电影 | 亚洲国产三级在线观看 | 成人欧美一区二区三区黑人麻豆 | 亚洲伦理中文字幕 | x99av成人免费 | 久久精品视频在线观看免费 | 黄色影院在线播放 | 黄色小说网站在线 | 久久精品欧美一 | 日韩精品一区二区三区在线视频 | 日本韩国精品一区二区在线观看 | av九九九| 日韩电影在线观看一区 | 国产麻豆果冻传媒在线观看 | 蜜臀av免费一区二区三区 | 欧美最爽乱淫视频播放 | 久久激情五月婷婷 | 亚洲高清在线精品 | 亚洲成人999 | 国产香蕉97碰碰碰视频在线观看 | www.69xx | 亚洲欧美日韩国产精品一区午夜 | 天天爽人人爽 | 天堂在线视频中文网 | 国产免费观看高清完整版 | 97国产超碰| 日韩毛片在线一区二区毛片 | 97视频在线 | 中文国产成人精品久久一 | 天堂网一区二区三区 | 精品国产伦一区二区三区观看说明 | 亚洲国产精品推荐 | 中文字幕91 | 国产成人精品av在线观 | 99在线高清视频在线播放 | 日韩欧美在线视频一区二区三区 | 色视频在线免费 | 西西大胆啪啪 | 久久久久免费视频 | 亚洲视频在线观看免费 | 免费不卡中文字幕视频 | 国产精品视频全国免费观看 | 91爱看片 | 国产日韩在线播放 | 久久免费大片 | 成人免费看片网址 | 深爱激情五月网 | 国产特级毛片aaaaaa毛片 | 亚洲精品视频免费 | 亚洲人成网站精品片在线观看 | 国模一二三区 | 国产精品 亚洲精品 | 欧美精品资源 | 国产一级一级国产 | 国产欧美高清 | 精品久久久成人 | 五月天狠狠操 | 在线免费观看黄网站 | 91日本在线播放 | 在线成人看片 | 色吊丝在线永久观看最新版本 | 中文字幕大全 | 国产在线观看你懂得 | 国产在线一区二区三区播放 | 黄色大片国产 | 欧美在线1 | 91av成人 | 中文字幕丝袜美腿 | 国内综合精品午夜久久资源 | 永久免费的啪啪网站免费观看浪潮 | 人人超碰97 | 顶级欧美色妇4khd | 婷婷在线视频 | 天天夜夜亚洲 | 久久五月婷婷丁香 | 亚洲精品影院在线观看 | 在线观看午夜 | 成人va视频 | 国产精品久久久久久久av电影 | 97电影院网 | 国产在线第三页 | 精品福利在线观看 | 久草免费在线 | 国产在线精品一区二区 | 99久热在线精品视频 | 午夜一级免费电影 | 国产精品麻豆欧美日韩ww | 天堂av在线免费观看 | 久久久久久久亚洲精品 | 国产特黄色片 | 久久这里有精品 | 99精品国产成人一区二区 | 国产精品一区二区麻豆 | 蜜臀av性久久久久蜜臀aⅴ流畅 | a国产精品 | 日韩免费一级a毛片在线播放一级 | 91中文字幕| 亚洲欧洲精品久久 | 婷婷综合五月天 | 丁香九月激情综合 | 青青草视频精品 | 视频在线观看一区 | 99精品国产在热久久 | 日韩欧美视频 | 91福利区一区二区三区 | 国产精品区免费视频 | 日韩综合视频在线观看 | 毛片网站在线看 | 国产精品一区二区精品视频免费看 | 欧美精品成人在线 | 国产中文在线字幕 | 久久国产精品色av免费看 | 日韩精品久久一区二区三区 | 黄色在线视频网址 | 91视频观看免费 | 欧美俄罗斯性视频 | 亚洲精选国产 | 在线精品视频在线观看高清 | 国产精品com | 97人人看 | 欧洲一区精品 | 7777精品伊人久久久大香线蕉 | 欧美一级裸体视频 | 国内一区二区视频 | 色综合天天色 | 97在线成人 | 黄色www在线观看 | 亚洲欧美视频在线观看 | 色欧美视频 | 国产美女搞久久 | 91爱看片 | 99爱精品视频 | 国产一区视频免费在线观看 | 中文字幕丝袜美腿 | 天天干天天拍 | 国产综合片 | 四虎www com| 午夜黄色 | 久久图 | 国产91国语对白在线 | 亚洲狠狠操 | 视频成人免费 | 亚洲无吗av | 久久高视频 | 天天夜夜狠狠操 | 久久亚洲精品国产亚洲老地址 | 久久国产精品99久久人人澡 | 久久久伊人网 | 久久国产精品久久久久 | www.玖玖玖 | av一区二区三区在线观看 | 亚洲一区二区观看 | 久久你懂得 | 极品中文字幕 | 在线观看91久久久久久 | 国产999精品久久久 免费a网站 | 国产一区二区午夜 | 久久精品国产美女 | 国产亚洲精品福利 | 婷婷精品视频 | 国产日产高清dvd碟片 | 日韩电影在线视频 | 日韩精品一区二区三区第95 | 日本一区二区高清不卡 | 欧美欧美| 成人免费视频观看 | 91麻豆精品国产91久久久更新时间 | 国产精品久久网 | 人人讲 | 欧美日韩国产一二 | 国产精品美女久久久久久久久 | 最新免费av在线 | 精品美女国产在线 | 丰满少妇在线观看网站 | 久久曰视频 | 久久精品99久久久久久2456 | 看片黄网站 | 亚洲激情综合 | 国内精品国产三级国产aⅴ久 | 九九欧美 | 免费av小说| av不卡中文字幕 | 毛片无卡免费无播放器 | 免费看国产黄色 | 亚洲欧美国产视频 | 国产精品涩涩屋www在线观看 | 2019中文最近的2019中文在线 | 精品国产视频一区 | 91精品国产亚洲 | 国产乱对白刺激视频在线观看女王 | 天天搞天天干天天色 | 国产精品永久免费在线 | 国产精品久久久久久影院 | av中文天堂 | 成人午夜黄色 | 免费看的黄色小视频 | 99久久精品免费看国产麻豆 | 丁香婷婷久久久综合精品国产 | 国产精品美女久久久久久网站 | 成全在线视频免费观看 | 精品在线小视频 | 91色一区二区三区 | 97视频在线免费 | 在线观看精品一区 | 天天人人 | 成人免费一区二区三区在线观看 | 亚洲黄色app | 免费观看www视频 | 碰超在线97人人 | 日韩欧美在线观看一区二区三区 | 久久精品99国产精品日本 | 免费国产在线精品 | 99热精品视 | 亚洲欧美日韩国产一区二区 | av直接看| 免费在线观看91 | 国产色婷婷 | 日本黄色免费播放 | 涩五月婷婷 | 亚洲人成影院在线 | 成人免费ⅴa| 成人午夜在线观看 | 亚洲毛片一区二区三区 | 亚洲精品免费观看 | 国产不卡在线视频 | 中文乱码视频在线观看 | 日韩特黄一级欧美毛片特黄 | 日韩欧美电影网 | 久久免费电影 | 1024在线看片 | 国产精品美女www爽爽爽视频 | 狠狠躁夜夜a产精品视频 | 女人高潮特级毛片 | 久久 亚洲视频 | 亚洲伊人色 | 992tv又爽又黄的免费视频 | 国产成人精品一区二区在线观看 | 久久精品在线 | 欧美少妇xxx | 精品美女在线视频 | 久久夜av | 99免费视频| 国产精品99久久久久久有的能看 | 国产一级a毛片视频爆浆 | 免费视频91蜜桃 | 久久久久亚洲精品中文字幕 | 久久精品99国产精品日本 | 不卡av电影在线 | 久久夜色网 | 在线免费色视频 | 日韩videos| 亚洲国产av精品毛片鲁大师 | 96久久精品| 国产精品欧美在线 | 成人免费av电影 | 亚洲精品美女免费 | 91最新视频在线观看 | 干亚洲少妇| 日本最新一区二区三区 | 免费av在线播放 | 96亚洲精品久久久蜜桃 | 99久久久国产精品 | 欧美在线aaa | 亚洲精品久久久久久久不卡四虎 | 天天射天天干天天操 | 国产精品网址在线观看 | 日韩在线观看第一页 | 日韩在线欧美在线 | 国产一区久久 | 免费av电影网站 | 夜色在线资源 | 久久激情五月婷婷 | 最近中文字幕免费大全 | 最近中文字幕第一页 | 四虎影视8848aamm | 亚洲精品国精品久久99热一 | 91色影院| 国产亚洲精品精品精品 | 特级毛片爽www免费版 | 亚洲精品视频在线免费播放 | 国产精品毛片一区二区在线 | 国产精品女同一区二区三区久久夜 | 免费av观看 | 欧美在线视频不卡 | 一区二区三区在线观看免费视频 | 中文电影网 | 93久久精品日日躁夜夜躁欧美 | www.人人干 | 91福利社区在线观看 | 国产一在线精品一区在线观看 | 日韩成人精品 | 中文字幕免费 | 亚洲欧美日韩精品一区二区 | 成人h视频在线播放 | 日韩欧美精品在线 | 99精品影视| 日韩欧美电影在线 | 成年人在线播放视频 | av免费网站在线观看 | 久草精品在线播放 | 国产精品久久久久久久av电影 | 黄色国产在线观看 | 日日爱影视 | 久久艹99| 久久久久久久久综合 | 天天操福利视频 | 色综合久久综合中文综合网 | 91麻豆免费视频 | 99热在线国产精品 | 一本色道久久综合亚洲二区三区 | 在线观看aaa | 免费a网址 | 亚洲丝袜一区 | 亚洲欧洲在线视频 | 日韩两性视频 | 日本高清中文字幕有码在线 | 麻豆观看 | 日本久久成人 | 丁香六月婷婷开心 | 国产成人av在线 | 91精品视频在线观看免费 | 丁香花在线观看视频在线 | 久久精品国产精品亚洲精品 | 97超碰人人网 | 久久免费资源 | 91香蕉视频黄 | 在线免费观看羞羞视频 | 亚洲资源 | 日本中文不卡 | 亚洲综合涩 | 99国产精品视频免费观看一公开 | 国产精品免费久久久 | 中文字幕资源网 | 国产黄色精品视频 | 亚洲精品国产精品久久99 | 91手机视频在线 | 91精品国产九九九久久久亚洲 | 国产国语在线 | 亚洲a在线观看 | 中文字幕麻豆 | 久草在线费播放视频 | 国产成人久久精品77777 | 日本少妇高清做爰视频 | 综合精品久久 | 免费色av| 中文字幕一区二区三区四区在线视频 | 亚洲最大免费成人网 | 日韩免费电影一区二区 | 久草在线手机观看 | 成年人黄色大片在线 | 国产成人久久久77777 | 日韩av免费一区 | 香蕉视频在线播放 | 久久久久女人精品毛片九一 | 一区二区三区在线免费观看 | 91插插插网站 | 精品国产自 | 成人在线观看免费视频 | 日韩高清二区 | 免费成视频 | 欧美一级免费在线 | 久久精品a | 五月天高清欧美mv | 99久久综合狠狠综合久久 | av福利免费 | 日韩草比 | 日韩精品久久久免费观看夜色 | 日韩欧美在线国产 | 热久久电影 | 极品国产91在线网站 | 精品91视频 | 婷婷丁香国产 | 黄色午夜网站 | 久久久www成人免费毛片 | 又湿又紧又大又爽a视频国产 | 日b黄色片 | 午夜的福利 | 很黄很色很污的网站 | 九九热国产视频 | 日韩视频www | 伊人影院av | 亚洲视频免费在线观看 | 一本到在线 | 国产三级香港三韩国三级 | 精品福利视频在线 | 91一区一区三区 | 成人在线观看免费 | 亚洲国产99 | 日韩免费视频观看 | 国产精品激情偷乱一区二区∴ | 成人久久综合 | 国产日产av | 成人性生交视频 | 少妇高潮流白浆在线观看 | 欧美尹人 | 久久不射电影院 | 国产99久久九九精品免费 | 免费在线91 | 免费观看成人网 | aaa毛片视频 | 一区二区三区久久精品 | 日本三级国产 | 操高跟美女 | 中文字幕亚洲欧美 | 在线日韩亚洲 | 久久精品一级片 | 亚洲黄色av网址 | 天天狠狠操 | www.五月婷婷 | 国产99久久九九精品免费 | 精品欧美小视频在线观看 | 欧美中文字幕久久 | 一本色道久久综合亚洲二区三区 | 免费在线国产精品 | 色吊丝在线永久观看最新版本 | 婷婷六月丁 | 久久国产精品视频观看 | 亚洲另类xxxx| 狠狠插天天干 | 成人黄色一级视频 | 亚洲天堂网在线播放 | 99久久婷婷国产精品综合 | 国产黄a三级三级三级三级三级 | 久久视频免费在线观看 | 国产精品自产拍在线观看 | 日韩在线免费高清视频 | 免费高清在线观看成人 | 久久久久久久99精品免费观看 | 在线播放国产一区二区三区 | 国产美女视频免费观看的网站 | 日日夜夜中文字幕 | h动漫中文字幕 | 99re中文字幕 | 欧美日韩在线视频一区 | 日本最新一区二区三区 | 久草电影免费在线观看 | 91福利影院在线观看 | 9在线观看免费高清完整 | 久久综合狠狠综合久久狠狠色综合 | 国产美女免费看 | 天堂在线一区二区 | 国产精品成人久久久久 | 欧美久久久一区二区三区 | 国产精品一区二区你懂的 | 国产精品一区在线观看你懂的 | 国产精品成人a免费观看 | 久久激情五月激情 | 97超碰人人网 | 国产在线精 | 色网站中文字幕 | 亚洲精品国产成人av在线 | 91香蕉久久 | 国产专区视频在线观看 | 2023年中文无字幕文字 | 在线视频手机国产 | 久久免费99精品久久久久久 | 午夜精品久久久久久久久久久久 | a黄色一级 | 久久综合影音 | 国产精品第 | 欧美精品在线一区 | 欧美 日韩 国产 成人 在线 | 最新精品国产 | 久久久精品欧美一区二区免费 | 亚洲高清色综合 | 一色av | 免费看成人a | 精品久久久久久亚洲综合网站 | 97成人在线免费视频 | 狠狠干天天 | 中文字幕成人在线观看 | 午夜婷婷综合 | 欧美一级激情 | 久草在线看片 | 成人免费av电影 | 久爱综合| 97在线观看免费观看 | 国产一级黄色电影 | 色综合色综合色综合 | 亚洲在线视频免费 | 国产精品一区二区果冻传媒 | 国产福利一区二区在线 | 免费在线观看一区 | 日韩精品久久久久久中文字幕8 | 久久96国产精品久久99软件 | 美女福利视频一区二区 | 亚洲精品色 | 亚洲成人黄色网址 | 色综合久久久久综合体 | 狠狠色伊人亚洲综合成人 | 九草视频在线观看 | 欧美高清视频不卡网 | 成人免费观看网站 | 国产亚洲人成网站在线观看 | 99精品视频免费 | 亚洲成av人片在线观看无 | 欧美日韩视频观看 | 黄色aaa级片 | 婷婷激情站 | 激情电影影院 | 亚洲成年人在线播放 | 亚洲一区二区观看 | 97超碰在线久草超碰在线观看 | 亚洲最新视频在线 | 天堂在线视频免费观看 | 五月婷视频 | 中文字幕在线视频免费播放 | 亚洲精品美女在线观看 | 国产精品久久久久久久免费观看 | japanesexxxhd奶水 国产一区二区在线免费观看 | 97国产小视频 | 中文字幕在线播放视频 | 欧美怡红院视频 | 欧美国产大片 | 欧美日韩视频免费 | 色狠狠婷婷 | 又色又爽又黄高潮的免费视频 | 久久人人97超碰com | 五月婷婷激情综合网 | 国产高清99 | 亚洲精品美女久久久久 | 欧美精品色 | 六月丁香婷 | 香蕉网在线观看 | av免费高清观看 | 超碰在线最新网址 | 国产精品资源在线观看 | 成人午夜性影院 | 久草在线免费资源 | 99久久久国产精品免费99 | 99热这里只有精品1 av中文字幕日韩 | 99精品国产视频 | 麻豆国产在线播放 | 在线观看黄网站 | 国产精品免费一区二区三区在线观看 | 国产精品一区二区 91 | 成人黄色在线播放 | 国产精品一区二区62 | 黄色在线网站噜噜噜 | 99久久超碰中文字幕伊人 | 精品亚洲男同gayvideo网站 | 国产五十路毛片 | 最近日本mv字幕免费观看 | 久久精品伊人 | 日黄网站 | 97精品久久人人爽人人爽 | 麻豆综合网 | 插婷婷| 精品免费一区二区三区 | 成年人在线观看网站 | 天天艹 | 黄色av电影在线观看 | 婷婷国产在线 | 欧美国产一区在线 | 久久精品视频在线观看 | 亚洲精品视频一 | 成人av片免费观看app下载 | 婷婷丁香视频 | 九九色在线| 日韩另类在线 | 成人久久免费 | 久草视频中文 | www.超碰 | 日本字幕网 | 色婷婷久久 | 欧美一级电影在线观看 | 免费av免费观看 | 97国产精品亚洲精品 | 色综合久久久久综合体 | 91成人免费看片 | aaa亚洲精品一二三区 | 日韩午夜电影网 | 日韩一区二区三区免费视频 | 国产精品美女999 | 日韩免费在线播放 | 91私密视频 | 日韩成人免费在线观看 | 成人作爱视频 | 国产麻豆精品传媒av国产下载 | 欧美日韩高清一区 | 一区二区精品在线视频 | 91大神电影 | 免费网站在线观看成人 | 激情av五月婷婷 | a一片一级 | 色网站中文字幕 | 日韩在观看线 | 免费av片在线 | 日韩欧美综合 | 免费国产ww| 亚洲资源在线观看 | 特级西西444www大胆高清无视频 | 四虎影视成人精品国库在线观看 | 黄色av一区二区 | 亚洲精品黄色片 | 91在线小视频 | 亚洲成人动漫在线观看 | 成人午夜在线观看 | 久久色在线观看 | 成人国产电影在线观看 | 欧美在线free | 美女国内精品自产拍在线播放 | 男女免费av | 最新国产在线观看 | 日韩精品免费一线在线观看 | 人人干狠狠干 | 在线看v片成人 | 国产精品久久久久久久久蜜臀 | 探花在线观看 | 五月天久久狠狠 | 久久久私人影院 | 性色xxxxhd| a黄色| 国产精品系列在线播放 | 国产91大片| 超碰免费久久 | 久久黄色免费观看 | 色婷婷视频在线观看 | 27xxoo无遮挡动态视频 | 麻豆免费在线播放 | 国产精品久久久久久一二三四五 | 99精品视频免费观看视频 | 五月天网站在线 | 91丨九色丨高潮 | 国产精品一区二区av麻豆 | 黄色片亚洲 | 美女视频是黄的免费观看 | 国产在线 一区二区三区 | 久久久久久蜜桃一区二区 | 天天色天天干天天色 | 亚洲精品一区中文字幕乱码 | 欧美成人一区二区 | 国产综合视频在线观看 | 国产精品久久久久9999 | 在线看的av网站 | 国语精品免费视频 | 97超碰人人澡人人 |