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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

pp-human在rk3588上部署

發(fā)布時間:2023/12/20 编程问答 50 豆豆
生活随笔 收集整理的這篇文章主要介紹了 pp-human在rk3588上部署 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

手把手教你百度飛槳PP-YOLOE部署到瑞芯微RK3588_pp飛槳怎么安裝_布衣神棍的博客-CSDN博客手把手教你百度飛槳PP-YOLOE部署到瑞芯微RK3588https://blog.csdn.net/buyishengun/article/details/127653529開發(fā)板概況 — TB-RK3588x 0.1 文檔https://t.rock-chips.com/wiki/CN/tb-rk3588x/01%E5%BF%AB%E9%80%9F%E4%B8%8A%E6%89%8B.html瑞芯微RK3588等AI硬件NPU部署(paddle)_Vertira的博客-CSDN博客瑞芯微RK3588等AI硬件NPU部署https://blog.csdn.net/Vertira/article/details/127811686yolov5訓(xùn)練pt模型并轉(zhuǎn)換為rknn模型,部署在RK3588開發(fā)板上——從訓(xùn)練到部署全過程_rknn yolov5_Billy_zz的博客-CSDN博客本文實(shí)現(xiàn)了yolov5模型從訓(xùn)練pt模型,到轉(zhuǎn)換為rknn模型,最終部署在RK3588板子上使用NPU加速推理的過程。https://blog.csdn.net/m0_57315535/article/details/128250096?spm=1001.2101.3001.6650.5&utm_medium=distribute.pc_relevant.none-task-blog-2~default~CTRLIST~Rate-5-128250096-blog-126153227.pc_relevant_3mothn_strategy_and_data_recovery&depth_1-utm_source=distribute.pc_relevant.none-task-blog-2~default~CTRLIST~Rate-5-128250096-blog-126153227.pc_relevant_3mothn_strategy_and_data_recovery&utm_relevant_index=9rockchip-linux · GitCodeGitCode——開源代碼托管平臺,獨(dú)立第三方開源社區(qū),Git/Github/Gitlabhttps://gitcode.net/mirrors/rockchip-linuxFirefly | 讓科技更簡單,讓生活更智能Firefly是天啟科技旗下的品牌,我們專注于開源智能硬件,物聯(lián)網(wǎng),數(shù)字音頻產(chǎn)品的研發(fā)設(shè)計、生產(chǎn)和銷售,同時提供了智能硬件 產(chǎn)品的整體解決方案。Firefly產(chǎn)品包括行業(yè)主板,核心板,開源板等。全系列產(chǎn)品均是芯片原廠瑞芯微(Rockchip)推薦板卡,獲得原生SDK支持。核心板與行業(yè)主板廣泛應(yīng)用于人工智能,商業(yè)顯示,廣告一體機(jī),智能POS,人臉識別終端,物聯(lián)網(wǎng),智慧城市等領(lǐng)域。https://www.t-firefly.com/doc/download/106.html1. NPU使用 — Firefly WikiEC-R3588SPC采用 Rockchip RK3588S新一代旗艦級八核64位處理器,最大可配32GB大內(nèi)存;支持8K視頻編解碼;支持千兆網(wǎng)、;支持多種操作系統(tǒng);可適用于ARM PC、邊緣計算、云服務(wù)器、智能NVR等領(lǐng)域https://wiki.t-firefly.com/zh_CN/EC-R3588SPC/usage_npu.html【FastDeploy + 瑞芯微】RV1126、RK3588全量化部署詳解_嗶哩嗶哩_bilibili【FastDeploy + 瑞芯微】RV1126、RK3588全量化部署詳解, 視頻播放量 618、彈幕量 0、點(diǎn)贊數(shù) 9、投硬幣枚數(shù) 4、收藏人數(shù) 24、轉(zhuǎn)發(fā)人數(shù) 6, 視頻作者 飛槳PaddlePaddle, 作者簡介 后廠村第一煉丹師<( ̄︶ ̄)>,相關(guān)視頻:【瑞芯微NPU部署】官方Y(jié)OLOV5+Tengine推理引擎+RV1126嵌入式AI硬件,3588--新一代NPU的介紹及使用,瑞芯微RK3588 ARM PC解決方案,擺脫電腦,直接在RK3588平臺上推理,幫用戶部署 RKNN 模加速 AI 應(yīng)用的落地,瑞芯微RK3588高端平板解決方案,開箱首發(fā)!瑞芯微旗艦芯RK3588開發(fā)板,瑞芯微RK3588邊緣計算及AI應(yīng)用,瑞芯微RK3588智能車載360°全景環(huán)視,rv1126板子說明!,香蕉派開源社區(qū)完成瑞芯微RK3568/RK3588全國產(chǎn)化開發(fā)板硬件驗(yàn)證并運(yùn)行國產(chǎn)麒麟Linux系統(tǒng)https://www.bilibili.com/video/BV1Xg411x7MV/?spm_id_from=333.999.top_right_bar_window_history.content.click&vd_source=4aed82e35f26bb600bc5b46e65e25c22examples/vision/detection/paddledetection/rknpu2/README_CN.md · develop · mirrors / paddlepaddle / fastdeploy · GitCode??An Easy-to-use and Fast Deep Learning Model Deployment Toolkit for ??Cloud 📱Mobile andhttps://gitcode.net/mirrors/paddlepaddle/fastdeploy/-/blob/develop/examples/vision/detection/paddledetection/rknpu2/README_CN.mdyolov5訓(xùn)練并生成rknn模型以及3588平臺部署_rknn yolov5_新鑫信心的博客-CSDN博客瑞芯微RK3588上yolov5目標(biāo)檢測的部署。https://blog.csdn.net/m0_51714298/article/details/125916417

1.bfloat16的安裝

使用distutils構(gòu)建Python擴(kuò)展模塊(Building Python extension module with distutils)_電腦培訓(xùn)使用distutils構(gòu)建Python擴(kuò)展模塊(Building Python extension module with distutils),我正在使用distutils來構(gòu)建一個用C ++編寫的Python擴(kuò)展模塊。 我遇到的問題是,為了編譯https://www.656463.com/wenda/sydistutilsgjPythonkzmk_284https://www.cnblogs.com/goldsunshine/p/8872623.htmlhttps://www.cnblogs.com/goldsunshine/p/8872623.html用源碼編譯,直接sudo pip install 安裝有問題,源碼python setup.py install --user,有的時候sudo pip install 不好使,就使用--user這種方式,有的時候三方庫鏈接不到,python setup.py install不好使,可以試試python setup.py sdist,記住distutils只是一種打包方式。此外,升級的gcc5.4在源碼編譯時可能有問題,加上

module.extra_compile_args = ['--std=c++0x']

2.rknpu

?250幀,640x640

?訓(xùn)練框架自帶的一些量化操作可以被rknn讀取

rknpu即為上面的rknn runtime.

rk3588的cpu比較強(qiáng),其實(shí)在PC或者板子上編譯都可以。

dmesg | grep Galcore 查看版本

?wget/adb/ssh推送都是可以的

rk3588對輸入有優(yōu)化

3.paddledetection中的pp-human在rk3588上部署

rknn的部署其實(shí)有兩部分,第一部分是在linux系統(tǒng)上開發(fā)量化和rknn模型,用到的是rknn-toolkit2,在板子上python調(diào)用,pc端是必須要裝的,因?yàn)榻o的rknn-toolkit2是用來轉(zhuǎn)模型的,如果不用fastdeploy這樣的框架的話。可以使用rknn-toolkit2中rknn-lite來部署,可以調(diào)用npu接口,如果對速度有更高要求,則需要使用rknpu來進(jìn)行c++側(cè)的部署,c++優(yōu)化了預(yù)處理等操作,事實(shí)上,預(yù)處理是很耗時的。

3.1 paddle2rknn

paddle提供的權(quán)重已經(jīng)是export_model之后的模型了,因此在export_model.py之前通過exclude_nms=True不可行。

下面這個鏈接可行
examples/vision/detection/paddledetection/rknpu2/README_CN.md · develop · mirrors / paddlepaddle / fastdeploy · GitCode??An Easy-to-use and Fast Deep Learning Model Deployment Toolkit for ??Cloud 📱Mobile andhttps://gitcode.net/mirrors/paddlepaddle/fastdeploy/-/blob/develop/examples/vision/detection/paddledetection/rknpu2/README_CN.md

代碼示例:

paddle2onnx --model_dir /home/sniss/local_disk/rknn-toolkit2-master/examples/onnx/ppyoloe/paddle_ori/mot_ppyoloe_l_36e_pipeline \ --model_filename /home/sniss/local_disk/rknn-toolkit2-master/examples/onnx/ppyoloe/paddle_ori/mot_ppyoloe_l_36e_pipeline/model.pdmodel \ --params_filename /home/sniss/local_disk/rknn-toolkit2-master/examples/onnx/ppyoloe/paddle_ori/mot_ppyoloe_l_36e_pipeline/model.pdiparams \ --save_file /home/sniss/local_disk/rknn-toolkit2-master/examples/onnx/ppyoloe/ppyoloeonnx/mot_ppyoloe_l_36e_pipeline.onnx \ --enable_dev_version True --opset_version 12 --enable_onnx_checker True python -m paddle2onnx.optimize --input_model /home/sniss/local_disk/rknn-toolkit2-master/examples/onnx/ppyoloe/ppyoloeonnx/mot_ppyoloe_l_36e_pipeline.onnx \ --output_model /home/sniss/local_disk/rknn-toolkit2-master/examples/onnx/ppyoloe/ppyoloeonnx/mot_ppyoloe_l_36e_pipeline_opt.onnx \ --input_shape_dict "{'image':[1,3,640,640], 'scale_factor':[1,2]}" python export_rknn.py --config_path /home/sniss/local_disk/rknn-toolkit2-master/examples/onnx/ppyoloe/ppyoloeonnx/mot_ppyoloe_opt.yaml --target_platform rk3588

上面這種方式是通過rknn來進(jìn)行onnx靜態(tài)圖的裁剪,避免了在onnx和paddle上面進(jìn)行裁剪。

3.2 paddleinference->rknn推理

剪裁完節(jié)點(diǎn)之后輸出是[(8400,4),8400]的array,第一維是兩個點(diǎn)坐標(biāo)有8400,后面是對應(yīng)的置信度有8400個,此時解耦頭輸出的結(jié)果。

pphuman部署的是ppyoloe模型,其實(shí)是跟蹤的模型,但是第一部分還是ppyoloe,后面加上卡爾曼濾波和匈牙利算法,所以核心還是ppyoloe在rk3588的部署。

此處寫了兩個版本的nms去做后處理,發(fā)現(xiàn)都輸出的框都有問題,即便是沒有量化,輸出的框還是有問題。

import os import urllib import traceback import time import sys import yaml import numpy as np import cv2 from rknn.api import RKNNONNX_MODEL = 'yolov5s.onnx' RKNN_MODEL = '/home/sniss/local_disk/rknn-toolkit2-master/examples/onnx/ppyoloe/ppyoloeonnx/mot_ppyoloe_l_36e_pipeline_opt_rk3588_quantized.rknn' IMG_PATH = './test.png' DATASET = './dataset.txt'QUANTIZE_ON = TrueOBJ_THRESH = 0.25 NMS_THRESH = 0.45 IMG_SIZE = 640CLASSES = ["player"]def draw_results(result, image, draw_thresh=0.5): # plt.figure(figsize=(10, 10)) # im = imread(filename) # plt.imshow(im) # currentAxis=plt.gca() # colors = ['r', 'g', 'b', 'k', 'y', 'pink', 'purple']for item in result:top, left, right, bottom= item[2:6]label = int(item[0])score = item[1]name = CLASSES[label]if item[1] > draw_thresh:top = int(top)left = int(left)right = int(right)bottom = int(bottom)cv2.rectangle(image, (top, left), (right, bottom), (255, 0, 0), 2)cv2.putText(image, '{0} {1:.2f}'.format(name, score),(top, left - 6),cv2.FONT_HERSHEY_SIMPLEX,0.6, (0, 0, 255), 2) # draw_rectangle(currentAxis, box, edgecolor = colors[label]) # plt.text(box[0], box[1], name, fontsize=12, color=colors[label]) # plt.savefig('/home/aistudio/external-libraries/PaddleDection/outout_img/output_pic.png')# plt.show()def draw(image, boxes, scores, classes):"""Draw the boxes on the image.# Argument:image: original image.boxes: ndarray, boxes of objects.classes: ndarray, classes of objects.scores: ndarray, scores of objects.all_classes: all classes name."""for box, score, cl in zip(boxes, scores, classes):top, left, right, bottom = boxprint('class: {}, score: {}'.format(CLASSES[cl], score))print('box coordinate left,top,right,down: [{}, {}, {}, {}]'.format(top, left, right, bottom))top = int(top)left = int(left)right = int(right)bottom = int(bottom)cv2.rectangle(image, (top, left), (right, bottom), (255, 0, 0), 2)cv2.putText(image, '{0} {1:.2f}'.format(CLASSES[cl], score),(top, left - 6),cv2.FONT_HERSHEY_SIMPLEX,0.6, (0, 0, 255), 2)# 計算IoU,矩形框的坐標(biāo)形式為xyxy,這個函數(shù)會被保存在box_utils.py文件中 def box_iou_xyxy(box1, box2):# 獲取box1左上角和右下角的坐標(biāo)x1min, y1min, x1max, y1max = box1[0], box1[1], box1[2], box1[3]# 計算box1的面積s1 = (y1max - y1min + 1.) * (x1max - x1min + 1.)# 獲取box2左上角和右下角的坐標(biāo)x2min, y2min, x2max, y2max = box2[0], box2[1], box2[2], box2[3]# 計算box2的面積s2 = (y2max - y2min + 1.) * (x2max - x2min + 1.)# 計算相交矩形框的坐標(biāo)xmin = np.maximum(x1min, x2min)ymin = np.maximum(y1min, y2min)xmax = np.minimum(x1max, x2max)ymax = np.minimum(y1max, y2max)# 計算相交矩形行的高度、寬度、面積inter_h = np.maximum(ymax - ymin + 1., 0.)inter_w = np.maximum(xmax - xmin + 1., 0.)intersection = inter_h * inter_w# 計算相并面積union = s1 + s2 - intersection# 計算交并比iou = intersection / unionreturn ioudef nms(bboxes, scores, score_thresh, nms_thresh, pre_nms_topk):"""nms"""inds = np.argsort(scores)inds = inds[::-1]inds = inds[:pre_nms_topk]keep_inds = []while(len(inds) > 0):cur_ind = inds[0]cur_score = scores[cur_ind]# if score of the box is less than score_thresh, just drop itif cur_score < score_thresh:breakkeep = Truefor ind in keep_inds:current_box = bboxes[cur_ind]remain_box = bboxes[ind]# import pdb;pdb.set_trace()iou = box_iou_xyxy(current_box, remain_box)if iou > nms_thresh:keep = Falsebreakif keep:keep_inds.append(cur_ind)inds = inds[1:]return np.array(keep_inds)def multiclass_nms(bboxes, scores, score_thresh=0.05, nms_thresh=0.5, pre_nms_topk=1000, pos_nms_topk=100):"""This is for multiclass_nms"""batch_size = bboxes.shape[0]class_num = scores.shape[1]rets = []for i in range(batch_size):bboxes_i = bboxes[i]scores_i = scores[i]ret = []for c in range(class_num):scores_i_c = scores_i[c]keep_inds = nms(bboxes_i, scores_i_c, score_thresh, nms_thresh, pre_nms_topk)if len(keep_inds) < 1:continuekeep_bboxes = bboxes_i[keep_inds]keep_scores = scores_i_c[keep_inds]keep_results = np.zeros([keep_scores.shape[0], 6])keep_results[:, 0] = ckeep_results[:, 1] = keep_scores[:]keep_results[:, 2:6] = keep_bboxes[:, :]ret.append(keep_results)if len(ret) < 1:rets.append(ret)continueret_i = np.concatenate(ret, axis=0)scores_i = ret_i[:, 1]if len(scores_i) > pos_nms_topk:inds = np.argsort(scores_i)[::-1]inds = inds[:pos_nms_topk]ret_i = ret_i[inds]rets.append(ret_i)return retsdef nms_boxes(boxes, scores):"""Suppress non-maximal boxes.# Argumentsboxes: ndarray, boxes of objects.scores: ndarray, scores of objects.# Returnskeep: ndarray, index of effective boxes."""x = boxes[:, 0]y = boxes[:, 1]w = boxes[:, 2] - boxes[:, 0]h = boxes[:, 3] - boxes[:, 1]areas = w * horder = scores.argsort()[::-1]keep = []while order.size > 0:i = order[0]keep.append(i)xx1 = np.maximum(x[i], x[order[1:]])yy1 = np.maximum(y[i], y[order[1:]])xx2 = np.minimum(x[i] + w[i], x[order[1:]] + w[order[1:]])yy2 = np.minimum(y[i] + h[i], y[order[1:]] + h[order[1:]])w1 = np.maximum(0.0, xx2 - xx1 + 0.00001)h1 = np.maximum(0.0, yy2 - yy1 + 0.00001)inter = w1 * h1ovr = inter / (areas[i] + areas[order[1:]] - inter)inds = np.where(ovr <= NMS_THRESH)[0]order = order[inds + 1]keep = np.array(keep)return keepdef ppyolo_nms(pred_bboxes, pred_scores): # pred_bboxes:(1,8400,1) pred_scores:(1,1,8400) boxes = pred_bboxes.reshape(-1,4)box_class_probs = pred_scores.reshape(pred_scores.shape[-1]*pred_scores.shape[0],-1)box_confidences = np.ones(boxes.shape[0]).reshape(-1,)_box_pos = np.where(box_confidences >= OBJ_THRESH)boxes = boxes[_box_pos]box_confidences = box_confidences[_box_pos]box_class_probs = box_class_probs[_box_pos]class_max_score = np.max(box_class_probs, axis=-1)classes = np.argmax(box_class_probs, axis=-1)_class_pos = np.where(class_max_score >= OBJ_THRESH)boxes = boxes[_class_pos]classes = classes[_class_pos]scores = (class_max_score* box_confidences)[_class_pos] # boxes = np.concatenate(boxes) # classes = np.concatenate(classes) # scores = np.concatenate(scores)nboxes, nclasses, nscores = [], [], []for c in set(classes):inds = np.where(classes == c)b = boxes[inds]c = classes[inds]s = scores[inds]keep = nms_boxes(b, s)nboxes.append(b[keep])nclasses.append(c[keep])nscores.append(s[keep])if not nclasses and not nscores:return None, None, Noneboxes = np.concatenate(nboxes)classes = np.concatenate(nclasses)scores = np.concatenate(nscores)return boxes, classes, scoresdef letterbox(im, new_shape=(640, 640), color=(0, 0, 0)):# Resize and pad image while meeting stride-multiple constraintsshape = im.shape[:2] # current shape [height, width]if isinstance(new_shape, int):new_shape = (new_shape, new_shape)# Scale ratio (new / old)r = min(new_shape[0] / shape[0], new_shape[1] / shape[1])# Compute paddingratio = r, r # width, height ratiosnew_unpad = int(round(shape[1] * r)), int(round(shape[0] * r))dw, dh = new_shape[1] - new_unpad[0], new_shape[0] - new_unpad[1] # wh paddingdw /= 2 # divide padding into 2 sidesdh /= 2if shape[::-1] != new_unpad: # resizeim = cv2.resize(im, new_unpad, interpolation=cv2.INTER_LINEAR)top, bottom = int(round(dh - 0.1)), int(round(dh + 0.1))left, right = int(round(dw - 0.1)), int(round(dw + 0.1))im = cv2.copyMakeBorder(im, top, bottom, left, right, cv2.BORDER_CONSTANT, value=color) # add borderreturn im, ratio, (dw, dh)if __name__ == '__main__': with open("/home/sniss/local_disk/rknn-toolkit2-master/examples/onnx/ppyoloe/ppyoloeonnx/mot_ppyoloe_opt.yaml") as file:file_data = file.read()yaml_config = yaml.safe_load(file_data)print(yaml_config)model = RKNN(True)# Configmean_values = yaml_config["mean"]std_values = yaml_config["std"]model.config(mean_values=mean_values,std_values=std_values,target_platform="rk3588")# Load ONNX modelif yaml_config["outputs_nodes"] is None:ret = model.load_onnx(model=yaml_config["model_path"])else:ret = model.load_onnx(model=yaml_config["model_path"],outputs=yaml_config["outputs_nodes"])assert ret == 0, "Load model failed!"# Build modelret = model.build(do_quantization=yaml_config["do_quantization"],dataset=yaml_config["dataset"])assert ret == 0, "Build model failed!"# Init Runtimeret = model.init_runtime()assert ret == 0, "Init runtime environment failed!"# Exportif not os.path.exists(yaml_config["output_folder"]):os.mkdir(yaml_config["output_folder"])model_base_name = os.path.basename(yaml_config["model_path"]).split(".")[0] # model_device_name = config.target_platform.lower()model_device_name = 'rk3588'if yaml_config["do_quantization"]:model_save_name = model_base_name + "_" + model_device_name + "_quantized" + ".rknn"else:model_save_name = model_base_name + "_" + model_device_name + "_unquantized" + ".rknn"ret = model.export_rknn(os.path.join(yaml_config["output_folder"], model_save_name))assert ret == 0, "Export rknn model failed!"print("Export OK!")# Set inputsimg = cv2.imread(IMG_PATH)img, ratio, (dw, dh) = letterbox(img, new_shape=(IMG_SIZE, IMG_SIZE))img = cv2.cvtColor(img, cv2.COLOR_BGR2RGB)img = cv2.resize(img, (IMG_SIZE, IMG_SIZE))# Inferenceprint('--> Running model')outputs = model.inference(inputs=[img])print('done') # import pdb;pdb.set_trace() # pred_bboxes = outputs[0] # pred_scores = outputs[1] # bbox_pred = multiclass_nms(pred_bboxes,pred_scores) # bbox_pred = bbox_pred[0]# import pdb;pdb.set_trace() # img_1 = cv2.cvtColor(img, cv2.COLOR_RGB2BGR) # if bbox_pred is not None: # draw_results(bbox_pred, img_1, draw_thresh=0.1) # cv2.imwrite("1.png",img_1) # draw_results(result, image, draw_thresh=0.5):import pdb;pdb.set_trace()pred_bboxes = outputs[0]pred_scores = outputs[1] # pred_bboxes = pred_bboxes.numpy() # pred_scores = pred_scores.numpy()boxes, classes, scores = ppyolo_nms(pred_bboxes,pred_scores)img_1 = cv2.cvtColor(img, cv2.COLOR_RGB2BGR)if boxes is not None:draw(img_1, boxes, scores, classes)cv2.imwrite("1.png",img_1)rknn.release()

4.fastdeploy部署

fastdeploy可以部署在rk3588上,比較友好的其還有python的接口,可以做快速的嘗試,還是用ppyoloe跑檢測,后面在加上跟蹤的代碼,fastdeploy的python接口在rk3588上默認(rèn)是onnxruntime的推理后端,python似乎是不支持rknpu2,沒跑通。

''' @Time : 2023/2/27 14:37 @Author : leeguandon@gmail.com ''' import os import fastdeploy as fd import cv2 import numpy as np from ocsort_tracker import OCSORTTracker from collections import defaultdict from pathlib import Path import copyOBJ_THRESH = 0.25 NMS_THRESH = 0.45 CLASSES = ["player"] visual = Truedef draw(image, boxes, scores, classes):"""Draw the boxes on the image.# Argument:image: original image.boxes: ndarray, boxes of objects.classes: ndarray, classes of objects.scores: ndarray, scores of objects.all_classes: all classes name."""for box, score, cl in zip(boxes, scores, classes):top, left, right, bottom = boxprint('class: {}, score: {}'.format(CLASSES[cl], score))print('box coordinate left,top,right,down: [{}, {}, {}, {}]'.format(top, left, right, bottom))top = int(top)left = int(left)right = int(right)bottom = int(bottom)cv2.rectangle(image, (top, left), (right, bottom), (255, 0, 0), 2)cv2.putText(image, '{0} {1:.2f}'.format(CLASSES[cl], score),(top, left - 6),cv2.FONT_HERSHEY_SIMPLEX,0.6, (0, 0, 255), 2)def nms_boxes(boxes, scores):"""Suppress non-maximal boxes.# Argumentsboxes: ndarray, boxes of objects.scores: ndarray, scores of objects.# Returnskeep: ndarray, index of effective boxes."""x = boxes[:, 0]y = boxes[:, 1]w = boxes[:, 2] - boxes[:, 0]h = boxes[:, 3] - boxes[:, 1]areas = w * horder = scores.argsort()[::-1]keep = []while order.size > 0:i = order[0]keep.append(i)xx1 = np.maximum(x[i], x[order[1:]])yy1 = np.maximum(y[i], y[order[1:]])xx2 = np.minimum(x[i] + w[i], x[order[1:]] + w[order[1:]])yy2 = np.minimum(y[i] + h[i], y[order[1:]] + h[order[1:]])w1 = np.maximum(0.0, xx2 - xx1 + 0.00001)h1 = np.maximum(0.0, yy2 - yy1 + 0.00001)inter = w1 * h1ovr = inter / (areas[i] + areas[order[1:]] - inter)inds = np.where(ovr <= NMS_THRESH)[0]order = order[inds + 1]keep = np.array(keep)return keepdef ppyolo_nms(pred_bboxes, pred_scores):boxes = pred_bboxes.reshape(-1, 4)box_confidences = np.ones(pred_bboxes.shape[0]).reshape(-1, )box_class_probs = pred_scores.reshape(pred_scores.shape[-1], -1)_box_pos = np.where(box_confidences >= OBJ_THRESH)boxes = boxes[_box_pos]box_confidences = box_confidences[_box_pos]box_class_probs = box_class_probs[_box_pos]class_max_score = np.max(box_class_probs, axis=-1)classes = np.argmax(box_class_probs, axis=-1)_class_pos = np.where(class_max_score >= OBJ_THRESH)boxes = boxes[_class_pos]classes = classes[_class_pos]scores = (class_max_score * box_confidences)[_class_pos]nboxes, nclasses, nscores = [], [], []for c in set(classes):inds = np.where(classes == c)b = boxes[inds]c = classes[inds]s = scores[inds]keep = nms_boxes(b, s)nboxes.append(b[keep])nclasses.append(c[keep])nscores.append(s[keep])if not nclasses and not nscores:return None, None, Noneboxes = np.concatenate(nboxes)classes = np.concatenate(nclasses)scores = np.concatenate(nscores)return boxes, classes, scoresdef postprocess(boxes, classes, scores):nboxes = []if len(boxes) > 0:for i, box in enumerate(boxes):classes_scores = np.append(classes[i], scores[i])boxes_ = np.append(classes_scores, box)nboxes.append(boxes_.tolist())result = {"boxes": np.array([boxes_]), 'boxes_num': np.array([len(boxes)])}return resultclass SDE_Detector(object):def __init__(self):use_byte = Falsedet_thresh = 0.4max_age = 30min_hits = 3iou_threshold = 0.3delta_t = 3inertia = 0.2min_box_area = 0vertical_ratio = 0self.tracker = OCSORTTracker(det_thresh=det_thresh,max_age=max_age,min_hits=min_hits,iou_threshold=iou_threshold,delta_t=delta_t,inertia=inertia,min_box_area=min_box_area,vertical_ratio=vertical_ratio,use_byte=use_byte)def tracking(self, det_results):pred_dets = det_results['boxes']pred_embs = det_results.get('embeddings', None)online_targets = self.tracker.update(pred_dets, pred_embs)online_tlwhs = defaultdict(list)online_scores = defaultdict(list)online_ids = defaultdict(list)for t in online_targets:tlwh = [t[0], t[1], t[2] - t[0], t[3] - t[1]] # top,left,w,htscore = float(t[4])tid = int(t[5])if tlwh[2] * tlwh[3] <= self.tracker.min_box_area: continueif self.tracker.vertical_ratio > 0 and tlwh[2] / tlwh[3] > self.tracker.vertical_ratio:continueif tlwh[2] * tlwh[3] > 0:online_tlwhs[0].append(tlwh)online_ids[0].append(tid)online_scores[0].append(tscore)tracking_outs = {'online_tlwhs': online_tlwhs, # 坐標(biāo)'online_scores': online_scores, # >0.4'online_ids': online_ids, # [10,9,8,7,6,5,4,3,2,1]}return tracking_outsdef get_color(idx):idx = idx * 3color = ((37 * idx) % 255, (17 * idx) % 255, (29 * idx) % 255)return colordef plot_tracking_dict(image,num_classes,tlwhs_dict,obj_ids_dict,scores_dict,frame_id=0,fps=0.,ids2names=[]):im = np.ascontiguousarray(np.copy(image)) # shape:480,854,3im_h, im_w = im.shape[:2]text_scale = max(0.5, image.shape[1] / 3000.)text_thickness = 2line_thickness = max(1, int(image.shape[1] / 500.))for cls_id in range(num_classes):tlwhs = tlwhs_dict[cls_id]obj_ids = obj_ids_dict[cls_id]scores = scores_dict[cls_id]cv2.putText(im,'frame: %d fps: %.2f num: %d' % (frame_id, fps, len(tlwhs)),(0, int(15 * text_scale) + 5),cv2.FONT_ITALIC,text_scale, (0, 0, 255),thickness=text_thickness)record_id = set()for i, tlwh in enumerate(tlwhs):x1, y1, w, h = tlwhintbox = tuple(map(int, (x1, y1, x1 + w, y1 + h)))center = tuple(map(int, (x1 + w / 2., y1 + h / 2.)))obj_id = int(obj_ids[i])id_text = '{}'.format(int(obj_id))if ids2names != []:id_text = '{}_{}'.format(ids2names[cls_id], id_text)else:id_text = 'class{}_{}'.format(cls_id, id_text)_line_thickness = 1 if obj_id <= 0 else line_thicknessin_region = Falsecolor = get_color(abs(obj_id)) if in_region == False else (0, 0,255)cv2.rectangle(im,intbox[0:2],intbox[2:4],color=color,thickness=line_thickness)cv2.putText(im,id_text, (intbox[0], intbox[1] - 25),cv2.FONT_ITALIC,text_scale,color,thickness=text_thickness)return imoption = fd.RuntimeOption() # option.use_cpu() # option.use_openvino_backend() # 一行命令切換使用 OpenVINO部署model = fd.vision.detection.PPYOLOE("/home/sniss/local_disk/rknn-toolkit2-master/examples/onnx/ppyoloe/paddle_ori/mot_ppyoloe_l_36e_pipeline/model.pdmodel","/home/sniss/local_disk/rknn-toolkit2-master/examples/onnx/ppyoloe/paddle_ori/mot_ppyoloe_l_36e_pipeline/model.pdiparams" , "/home/sniss/local_disk/rknn-toolkit2-master/examples/onnx/ppyoloe/paddle_ori/mot_ppyoloe_l_36e_pipeline/infer_cfg.yml")tracker = SDE_Detector() mot_results = []video_file = "kitch.mp4" output_dir = "results" capture = cv2.VideoCapture(video_file)# Get Video info : resolution, fps, frame count width = int(capture.get(cv2.CAP_PROP_FRAME_WIDTH)) height = int(capture.get(cv2.CAP_PROP_FRAME_HEIGHT)) fps = int(capture.get(cv2.CAP_PROP_FPS)) frame_count = int(capture.get(cv2.CAP_PROP_FRAME_COUNT)) print("video fps: %d, frame_count: %d" % (fps, frame_count))video_out_name = Path(video_file).stem if not os.path.exists(output_dir):os.makedirs(output_dir) out_path = os.path.join(output_dir, video_out_name + ".mp4") fourcc = cv2.VideoWriter_fourcc(*'mp4v') writer = cv2.VideoWriter(out_path, fourcc, fps, (width, height))frame_id = 0while (1):# frame_id = 0if frame_id % 10 == 0:print('frame id: {}'.format(frame_id))ret, frame = capture.read()if not ret:break# img = cv2.imread("test.png")img = frameresult = model.predict(copy.deepcopy(img))pred_bboxes = np.array(result.boxes)pred_scores = np.array(result.scores)boxes, classes, scores = ppyolo_nms(pred_bboxes, pred_scores)# boxes# array([[ 618.63458252, 172.54750061, 1023.77459717, 781.89233398]])# classes# array([0])# scores# array([0.95259225])det_result = postprocess(boxes, classes, scores)tracking_outs = tracker.tracking(det_result)online_tlwhs = tracking_outs['online_tlwhs']online_scores = tracking_outs['online_scores']online_ids = tracking_outs['online_ids']mot_results.append([online_tlwhs, online_scores, online_ids])if visual:im = plot_tracking_dict(frame,1,online_tlwhs,online_ids,online_scores,frame_id=frame_id,ids2names=CLASSES)cv2.imwrite(os.path.join(output_dir, '{:05d}.jpg'.format(frame_id)), im)frame_id += 1writer.write(im)# img_1 = cv2.cvtColor(img, cv2.COLOR_RGB2BGR)# if boxes is not None:# draw(img_1, boxes, scores, classes)## img_2 = cv2.cvtColor(img_1, cv2.COLOR_BGR2RGB)# cv2.imwrite("fastdeploy_1.png", img_2)writer.release()

fastdeploy的c++版本嘗試、

5.rknn-lite2 npu的python接口

用rknn-lite2可以調(diào)用rk3588的npu,速度相當(dāng)不錯。

總結(jié):整體來說,在pc端可以使用rknn-toolkit2做rknn模型的轉(zhuǎn)換,這一步最關(guān)鍵的就是.rknn模型的獲取,rknpu中雖然也有onnx2rknn,但是想在pc端用python做測試,還是走這個路子,有了rknn模型之后,可以用rknn-lite2在rk3588上推理,或者使用rknpu的c++接口,rknpu的c++接口高效處理了數(shù)據(jù)預(yù)處理,這一步其實(shí)很耗時間的,速度會更快點(diǎn)。

總結(jié)

以上是生活随笔為你收集整理的pp-human在rk3588上部署的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

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

91精品999| 国产日韩欧美在线一区 | 96国产精品视频 | 国产99久久精品一区二区永久免费 | 成人国产精品一区 | 天天综合入口 | 黄色最新网址 | 四虎影视成人精品国库在线观看 | 国产日韩一区在线 | 亚洲欧洲精品一区二区精品久久久 | 国产精品手机视频 | 色就色,综合激情 | 日本公妇在线观看高清 | av在线最新 | 友田真希x88av | 在线观看国产日韩 | 免费亚洲黄色 | 久久少妇免费视频 | 精品国产不卡 | 人人网av | 国产不卡在线观看 | 永久av免费在线观看 | 99免在线观看免费视频高清 | 成人97人人超碰人人99 | 色人久久 | 国产在线资源 | 黄色免费网战 | 日本不卡一区二区 | 欧美大jb| 亚洲精品视频网址 | 97超碰人人澡人人爱学生 | 成人影视免费 | 激情网色 | 蜜桃视频在线观看一区 | 大荫蒂欧美视频另类xxxx | 亚洲成人黄色av | 人人爽人人爽人人爽学生一级 | 92国产精品久久久久首页 | 亚洲精品在线视频 | 国产精品美女久久久久久久 | 久久国产精品99久久久久久老狼 | 亚洲欧洲视频 | 激情五月在线观看 | 深爱激情av | 伊人精品在线 | 国产精品扒开做爽爽的视频 | 91九色视频国产 | 日韩网 | 亚洲国产中文在线 | 国产视频在线播放 | 中文字幕视频免费观看 | 国产片免费在线观看视频 | 午夜视频黄 | www.五月天婷婷 | 亚洲伊人网在线观看 | 激情视频综合网 | 在线观看精品一区 | 六月丁香六月婷婷 | 曰韩精品 | 国产主播大尺度精品福利免费 | 成人av免费在线播放 | 欧美午夜a | 国产精品一区二区白浆 | 日韩免费在线看 | 日韩字幕 | 六月激情网| 字幕网av| 婷婷六月激情 | 国精产品永久999 | 91在线最新| 久久久蜜桃一区二区 | 亚洲最新av在线 | 国产美女精品人人做人人爽 | 日韩精品最新在线观看 | 久久精品9 | 免费黄色a网站 | 99视频一区 | 天天操天天射天天 | 亚洲狠狠婷婷综合久久久 | 97在线看片 | 一区二区三区精品在线视频 | 亚洲国产欧美在线人成大黄瓜 | 麻豆视频网址 | 精品国产电影一区二区 | 久草在线视频在线观看 | 久久99国产精品免费网站 | 成人久久电影 | 免费在线观看91 | 色天堂在线视频 | 精品一区精品二区 | 中文字幕在线观看一区二区 | 一区二区视频在线播放 | 五月婷婷开心中文字幕 | 91精品久久香蕉国产线看观看 | av大全在线免费观看 | 韩国一区二区av | 亚洲一区网站 | 99国产视频在线 | 天堂在线免费视频 | 欧美精品二 | 草久久久 | 中文字幕成人一区 | 亚洲精品日韩在线观看 | 日韩av高清在线观看 | 日韩av图片| 免费视频久久 | 天天爱天天操 | 特级西西444www高清大视频 | www毛片com| 成人app在线免费观看 | 色综合a| 天天操天天操天天操天天操 | 亚洲精品乱码久久 | 久久久久国产视频 | 国产一二三区av | 国产黄色免费 | 亚洲精品1234区 | 91精品一区二区三区蜜桃 | 久艹在线免费观看 | 四虎精品成人免费网站 | 99视频这里只有 | 免费久久久久久久 | 一本色道久久精品 | 国内精品视频免费 | 久久久久久久久网站 | 久久久久成人精品免费播放动漫 | 国产一级片久久 | 国产精品麻豆视频 | 国产黄色在线观看 | 免费精品国产va自在自线 | 欧美一级小视频 | 国产精品不卡在线 | 91丨九色丨蝌蚪丰满 | 在线电影 你懂得 | 国产成人在线免费观看 | 国产精品不卡视频 | 91探花国产综合在线精品 | 久久久亚洲国产精品麻豆综合天堂 | 国产二区视频在线观看 | 在线成人一区二区 | 黄色成人91 | 国产日韩在线播放 | 午夜视频在线观看网站 | 98久9在线 | 免费 | 又污又黄的网站 | 国产精品 日韩 | 在线亚洲人成电影网站色www | 免费观看一级特黄欧美大片 | av福利在线免费观看 | 日本在线观看一区 | 91精品国产九九九久久久亚洲 | 日本黄色免费网站 | 超黄视频网站 | av直接看 | 91av视频免费观看 | 日韩久久久久久久 | 日本成人中文字幕在线观看 | 91在线亚洲 | 久久久久亚洲精品中文字幕 | 尤物97国产精品久久精品国产 | 在线视频91 | 国产尤物在线 | 最近中文字幕高清字幕免费mv | 亚州精品天堂中文字幕 | 午夜精品av在线 | 日韩免费在线观看网站 | 成人黄色在线播放 | 在线观看视频一区二区三区 | 国产精品白丝av | 在线观看资源 | 91在线欧美| 久久精品男人的天堂 | 日韩av免费大片 | 色天天 | 日韩欧美国产免费播放 | 色婷婷丁香| 香蕉视频在线免费看 | 欧美va天堂va视频va在线 | 欧美精品生活片 | 欧美日韩二三区 | 在线观看免费视频 | 日本一区二区三区视频在线播放 | 久久国际影院 | 亚洲欧美精品一区二区 | 四虎国产 | 国产二级视频 | 在线国产中文字幕 | 超碰在线色| 久久av网| 国产一区二区播放 | 精品视频在线看 | 五月天久久婷 | 午夜a区 | 欧美久久精品 | 亚洲乱码中文字幕综合 | 国产免费区 | 亚洲免费a | 午夜丁香视频在线观看 | 日日激情 | 亚洲人毛片 | a天堂一码二码专区 | 96av在线视频 | 日韩剧情 | 久久精品超碰 | 中文字幕一区二 | 免费国产亚洲视频 | 亚洲二区精品 | 国产手机在线观看视频 | 亚洲九九 | 国产女教师精品久久av | 91在线成人 | 91在线观看视频网站 | 成人免费观看网站 | 国产亚洲va综合人人澡精品 | 91福利视频一区 | 超碰人人射 | 97夜夜澡人人双人人人喊 | 国产精品99久久久久人中文网介绍 | 国产精品一区二区白浆 | 黄色成人在线观看 | 欧美国产日韩一区二区三区 | 91视频啊啊啊 | 精品久久久久国产 | 精品久久久久久久久中文字幕 | 亚洲精品黄色片 | 天天操操操操操操 | av线上免费观看 | 久久久久久久99精品免费观看 | 久青草电影 | 国产流白浆高潮在线观看 | 日本精品视频在线播放 | 最近中文字幕国语免费av | 九九九九热精品免费视频点播观看 | 玖玖在线免费视频 | 免费在线观看亚洲视频 | 99免费观看视频 | 美女黄色网在线播放 | 91色国产在线 | 91成人免费看 | 13日本xxxxxⅹxxx20 | 91成人免费观看视频 | 911久久香蕉国产线看观看 | 伊人婷婷久久 | 欧美男同网站 | 香蕉久久久久 | 中文字幕第 | 亚洲国产三级在线观看 | 国语久久 | 五月婷婷综合激情 | 免费观看av网站 | 国产精品美女久久久久久久网站 | 国产一区欧美二区 | 国产精品99久久久久久武松影视 | 美女视频黄免费网站 | 亚洲精品色视频 | 在线播放日韩av | 97成人在线免费视频 | 日韩在线视频免费观看 | 中文字幕有码在线 | 超碰在线成人 | 亚洲一区二区精品 | 国产视频精品在线 | 免费看十八岁美女 | 黄污污网站| 91九色porn在线资源 | 国产精品毛片久久久久久久久久99999999 | 91插插影库| 午夜影院先| 天天操天天吃 | 国产手机视频在线播放 | 日韩免费在线网站 | 久草在线综合 | 欧美a√在线 | 美女网站免费福利视频 | 国产99亚洲 | av资源中文字幕 | 婷婷亚洲综合五月天小说 | 国产精品美女久久久久久久 | 麻豆影视在线免费观看 | 日韩国产精品毛片 | 久久精品综合 | 中文av影院 | 国产精品久久久久久影院 | 99久久精品国产欧美主题曲 | 国产手机视频在线 | www.亚洲黄色 | 亚洲综合精品在线 | 天天干 夜夜操 | 欧美一进一出抽搐大尺度视频 | 国产免费不卡 | 亚洲伊人成综合网 | 伊人春色电影网 | 国产黑丝一区二区 | 国产一区二区三区四区在线 | 91 中文字幕 | www.com.黄| 日韩中文字幕在线 | 国产中文视 | 亚洲精品色视频 | 久久久综合香蕉尹人综合网 | 在线久草视频 | 日韩影视在线 | 久久的色 | 国产精品久久久久久一区二区三区 | 午夜精品一区二区三区在线观看 | 中文字幕中文字幕在线中文字幕三区 | 欧美日韩在线播放一区 | 日日夜夜综合网 | 国产97色在线 | 久久99深爱久久99精品 | 精品久久一二三区 | 精品国产一区二区三区不卡 | 国产一区二区高清视频 | 99久久精品免费看国产一区二区三区 | 狠狠色狠狠综合久久 | 六月久久婷婷 | 精品国产区 | 欧美精品一级视频 | 精品美女久久久久久免费 | 在线观看精品视频 | 91激情视频在线 | 激情 亚洲| 最近在线中文字幕 | 在线日韩精品视频 | 另类五月激情 | 91视频a | 亚洲伊人成综合网 | 不卡日韩av| 黄色网址国产 | 激情久久网 | 亚洲欧美婷婷六月色综合 | ,午夜性刺激免费看视频 | 一二三区av| 国产精品女人久久久久久 | 爱色av.com| 欧美另类v | 婷色| 国产精品九九九九九九 | 人人超碰在线 | 午夜精品成人一区二区三区 | 日本爱爱免费 | 99se视频在线观看 | www日韩精品 | 亚洲精品中文在线资源 | 国产成人61精品免费看片 | 91自拍91| 国产99久久精品一区二区永久免费 | 免费在线激情视频 | 午夜 在线 | 二区三区在线观看 | 久久精品国产一区二区三 | 久久久久久福利 | 国产精品亚州 | 波多野结衣精品在线 | 国产色视频网站2 | 五月婷婷在线播放 | 日韩高清不卡在线 | 人人干人人干人人干 | 日韩电影在线看 | 午夜视频播放 | 欧美激情视频三区 | 欧美日性视频 | 亚洲国产丝袜在线观看 | 久久试看 | 五月天高清欧美mv | 日韩和的一区二在线 | 精品久久久久久久久久 | 天天射天天爽 | 久草精品视频在线看网站免费 | 黄色精品一区二区 | 极品中文字幕 | 欧美中文字幕久久 | 久久伊99综合婷婷久久伊 | 深夜免费小视频 | 精品国产成人在线 | 欧美贵妇性狂欢 | 亚洲天堂网在线视频观看 | 午夜精品福利一区二区 | 青草视频在线看 | 国产一区二区三区久久久 | 91中文视频 | av大片网址 | 亚洲国产成人在线 | 精产嫩模国品一二三区 | 人人爱人人舔 | 久久九九网站 | 色黄久久久久久 | 国产黄色大片免费看 | 成人wwwxxx视频 | 国产h在线播放 | 中文字幕精品在线 | 在线看av网址| 麻豆91在线看 | 亚洲成人黄色在线观看 | 国产精品视频免费观看 | 精品亚洲男同gayvideo网站 | 欧美精品一区二区在线播放 | www.com久久| 毛片网在线 | 国产精品v欧美精品v日韩 | 五月天久久久久 | 免费在线观看日韩视频 | 国产成人一二三 | 欧美成年网站 | 欧美精品一区二区免费 | 香蕉视频导航 | 在线国产一区二区三区 | www视频在线免费观看 | www.99av| 国产高清视频在线免费观看 | 午夜免费久久看 | 怡红院av | 黄色亚洲片 | 久久99精品热在线观看 | 四虎影视成人永久免费观看亚洲欧美 | 激情 亚洲 | 免费91麻豆精品国产自产在线观看 | 久久亚洲欧美日韩精品专区 | 日本中文字幕电影在线免费观看 | 九九视频在线播放 | 五月天网站在线 | 久久精品人人做人人综合老师 | 超碰av免费| 天堂黄色片 | 特级毛片网 | 福利视频导航网址 | 久久精品老司机 | 久草免费在线视频观看 | 在线亚洲激情 | 精品久久久久久久久久岛国gif | 国产无限资源在线观看 | 一区二区三区国产欧美 | 欧美日韩国产高清视频 | 欧美日韩二区三区 | 国产亚洲视频中文字幕视频 | 欧美日韩精品二区第二页 | 国产在线免费 | 欧美国产大片 | 五月婷婷视频在线观看 | 久久久私人影院 | 欧美一区二区日韩一区二区 | 日韩欧美视频在线观看免费 | 91桃色在线播放 | 98福利在线 | 69国产精品视频免费观看 | 欧美日韩另类在线 | 精品国产一区二区三区久久影院 | 国产成人1区 | 免费激情网 | 91在线小视频 | 国产综合福利在线 | www操操操| 亚洲欧美视频在线 | 99精品国产免费久久 | 午夜久久福利视频 | 欧美性粗大hdvideo | 中文字幕一区二区三区精华液 | 婷婷成人在线 | 欧美一区中文字幕 | 成人影音av | 97国产视频 | 色网免费观看 | 久久精彩| 一二三区av | 99久久精品无码一区二区毛片 | 玖玖精品在线 | 久久人人爽人人爽人人片av软件 | 日韩视频专区 | 国产高清在线视频 | 97免费中文视频在线观看 | 中文免费在线观看 | 在线观看国产一区 | 麻豆免费精品视频 | 五月天婷婷综合 | 欧美亚洲另类在线视频 | 玖玖国产精品视频 | 欧美性受极品xxxx喷水 | 国产小视频在线播放 | 国产一在线精品一区在线观看 | 一区二区三区在线看 | 国产区在线 | 日本爽妇网 | 999久久 | 97色婷婷成人综合在线观看 | av在线免费网 | 婷婷丁香色 | 久久96| 久久99这里只有精品 | 91在线影院| 亚洲欧洲中文日韩久久av乱码 | av黄色免费网站 | 国产护士av | av观看久久久 | 日韩av一区二区三区在线观看 | 亚洲不卡在线 | 免费视频91蜜桃 | 亚洲精品乱码久久久久久 | 欧洲精品码一区二区三区免费看 | 日日草夜夜操 | 久99久精品| 一级黄色片在线观看 | 500部大龄熟乱视频 欧美日本三级 | 久久久久久久久久久国产精品 | 国产一区二区三区免费在线 | 天天曰视频 | 国产91国语对白在线 | 在线看黄网站 | 免费高清国产 | 人人插人人做 | 欧美国产日韩一区二区三区 | 亚洲精品在线观看视频 | 国产精品精品久久久久久 | 亚洲精品日韩一区二区电影 | 在线观看黄网站 | 婷婷深爱网 | 五月婷婷在线视频观看 | 久久成视频 | 亚洲春色成人 | 黄色成品视频 | 国产欧美最新羞羞视频在线观看 | 国产精品av久久久久久无 | 久久国产91| 久久这里有 | 五月天激情视频在线观看 | 激情av一区二区 | 麻豆视频在线免费 | 最近中文字幕大全中文字幕免费 | 黄色一级大片在线免费看产 | 日韩中文字幕免费视频 | 91大神精品视频在线观看 | 久久一区国产 | 久久久久久毛片 | 在线国产视频观看 | 天天色影院 | 国产精品久久久久999 | 国产丝袜在线 | 在线免费观看国产 | 91av短视频 | 久久玖| 欧美成亚洲 | 久久99久久99久久 | 免费看的av片 | 精品专区 | 97视频在线看| 国产一区免费在线 | 成人毛片在线视频 | 国语自产偷拍精品视频偷 | 国产成本人视频在线观看 | 9992tv成人免费看片 | 性色av免费看 | 国产香蕉视频在线播放 | 91黄色成人 | 午夜视频二区 | 日本中文一区二区 | 国产999精品久久久久久 | 一本一道久久a久久综合蜜桃 | 中文字幕黄色网址 | 97国产电影 | 激情网第四色 | 波多野结衣视频一区二区三区 | 在线看岛国av | 国产精品美女久久久久久2018 | 97网| 国产手机免费视频 | 国产高清视频在线免费观看 | 国产91综合一区在线观看 | 国内精品久久久精品电影院 | 色偷偷88888欧美精品久久 | 日韩在线网 | 手机av在线网站 | 99在线热播精品免费99热 | 91视频com | 激情av一区二区 | 欧美一级裸体视频 | 久久精品网站免费观看 | 日韩三级中文字幕 | www.com在线观看 | 天天舔天天射天天操 | 91在线网址 | 波多野结衣理论片 | 91精品啪啪 | 国产一区二区三区高清播放 | 久久综合色8888| 99r在线精品 | 狠狠操狠狠干天天操 | 久久99网站 | 中文区中文字幕免费看 | 日日噜噜噜噜夜夜爽亚洲精品 | www.五月天婷婷 | 亚洲高清精品在线 | 免费成人在线电影 | 久久女同性恋中文字幕 | 97精产国品一二三产区在线 | 国产精品专区h在线观看 | 黄色av网站在线观看 | av免费福利 | 91高清免费 | 很黄很污的视频网站 | 九九九热精品免费视频观看 | 天天干天天插伊人网 | 国产精品成人国产乱 | 国产精品18久久久久久久 | 国产一区视频导航 | 麻豆视频免费入口 | 欧美三级免费 | 天天射综合网视频 | 成年人国产精品 | 天天av资源 | 精品一区电影国产 | 国产一区免费在线观看 | 综合网婷婷 | 在线观看免费日韩 | 18久久久| 国产一区免费观看 | 婷婷日日 | 欧美在线观看视频免费 | 日韩精品视频在线观看网址 | 中文字幕在线视频一区二区 | 久久精品国产一区二区三 | 91视频在线自拍 | 激情丁香综合五月 | 欧美高清视频不卡网 | av在线电影播放 | 日韩视频免费观看高清完整版在线 | 手机av电影在线 | 国产97视频在线 | 国产成人精品一区二三区 | 国际精品久久久久 | 国产91九色视频 | 久久久av免费 | 东方av在线免费观看 | 国产精品久一 | 波多野结衣精品在线 | 久久精品中文字幕免费mv | 日韩免费三区 | 精品99视频 | 亚洲国产影院av久久久久 | 九九视频在线播放 | 91精品国产综合久久福利 | 国产伦精品一区二区三区四区视频 | 色婷婷一区| 美女国产在线 | 久久草在线视频国产 | 777xxx欧美| 天天要夜夜操 | 91最新视频在线观看 | jizzjizzjizz亚洲 | 久久久久久国产精品久久 | 久久久影片 | 国产精品女人久久久 | 久久久国产日韩 | 日韩视频一 | 国产黄影院色大全免费 | 久久久免费精品国产一区二区 | 911精品美国片911久久久 | 97人人射| 国产91免费在线 | 国产精品成人一区二区三区吃奶 | 亚洲综合激情小说 | 91亚洲欧美激情 | 青草视频在线 | 一区二区三区av在线 | 久草在线视频免赞 | 在线国产能看的 | 国产精品嫩草影视久久久 | 亚洲国产激情 | 在线看国产视频 | 天天爽夜夜爽人人爽曰av | 国产视频一 | 在线草| 97在线精品国自产拍中文 | 亚洲欧美视频在线 | 色婷婷狠狠五月综合天色拍 | 久久视频这里有久久精品视频11 | 国产专区在线播放 | 亚洲黄色免费在线看 | 丁香六月激情婷婷 | 中文字幕网站视频在线 | 一级片免费观看 | 色综合天天综合 | 欧美成人黄| 天天插天天操天天干 | 中文字幕av专区 | 欧美高清成人 | 99久久一区 | 日韩激情在线 | 午夜精品久久久久久久99 | 精品福利片 | 波多野结衣一区三区 | 国产在线一线 | 欧美一级片在线观看视频 | 中文字幕一区二区三区乱码在线 | 国产不卡高清 | 国产一级一片免费播放放a 一区二区三区国产欧美 | 又黄又爽又色无遮挡免费 | 中文字幕在线播放一区二区 | 在线电影a | 国产精品一区二区久久精品爱微奶 | 久久久久久久久免费视频 | 999电影免费在线观看2020 | 午夜久久美女 | 探花视频在线观看+在线播放 | 婷婷久久五月天 | 又污又黄的网站 | 午夜视频二区 | 国产精品永久 | 欧美 激情在线 | 91九色在线 | 亚洲精品高清视频在线观看 | 综合久久精品 | 在线 国产一区 | 一本一本久久a久久精品综合小说 | 国产一区网址 | 欧美日韩裸体免费视频 | 欧美精品免费在线 | 亚洲欧美激情精品一区二区 | 亚洲综合国产精品 | 九九久久久久99精品 | 韩国av免费在线观看 | 亚洲高清视频在线观看免费 | 久久99国产精品自在自在app | 天天操天天干天天插 | 久久精品在线 | 久久亚洲私人国产精品va | 操夜夜操| 国产精品一区二区av日韩在线 | 欧美日韩中文字幕视频 | 亚洲天堂在线观看完整版 | 成人免费看电影 | 91成人精品一区在线播放 | 国产黄色av网站 | 国产剧情av在线播放 | 国产精品不卡av | 97香蕉超级碰碰久久免费软件 | 色综合 久久精品 | 国产极品尤物在线 | 亚洲成av人片 | 中文在线免费看视频 | 国产午夜三级 | 天天操网站 | 国产精品久久久久久久久久ktv | 在线观看黄 | 天天操操操操操操 | 国产精品久久久久久久久免费看 | 久久成年人网站 | 久久99精品久久久久久 | 国产999精品久久久影片官网 | 国产视频 久久久 | 99精品在线免费 | 欧美在线视频第一页 | 日韩一区二区三区免费视频 | 久久久久久久久久毛片 | 中国老女人日b | 国产91粉嫩白浆在线观看 | 国产91国语对白在线 | 国产精品成人一区二区三区 | 在线观看日韩中文字幕 | 日本精品一区二区在线观看 | 精品在线观看国产 | 国产美女被啪进深处喷白浆视频 | 日本久草电影 | 久久狠狠亚洲综合 | 日韩精品免费 | 免费看一级 | 爱情影院aqdy鲁丝片二区 | 久久精品9 | av免费网站 | 国产一区二三区好的 | 欧美日韩一区二区免费在线观看 | 国模吧一区 | 日本久久91 | 日韩高清免费电影 | 91在线影视 | 在线观看黄av| 这里有精品在线视频 | 尤物97国产精品久久精品国产 | 国产资源 | 不卡的av在线播放 | 黄色三级久久 | 久久成人18免费网站 | 日本中文字幕在线免费观看 | 欧美另类xxxxx | 久久婷婷五月综合色丁香 | 网站你懂的 | 国产精品久久久免费看 | 激情久久五月 | 久久综合丁香 | 婷婷六月天在线 | 狠狠干在线 | 久久精品99视频 | 成人免费看视频 | 日韩免费福利 | 国产一级电影免费观看 | 2021国产在线视频 | 在线精品一区二区 | av黄色影院 | 超碰在线成人 | 国产日产精品一区二区三区四区 | 欧美午夜精品久久久久 | 国产一区在线视频观看 | 国产婷婷在线观看 | 亚洲国产精品va在线看黑人 | 成年人电影免费在线观看 | 国产精品久久久久一区二区三区 | 五月婷婷丁香色 | 精品在线观看一区二区 | 91丨九色丨国产丨porny精品 | 麻豆av电影 | 亚洲欧美日韩在线一区二区 | 久久久久久久久久久影院 | 日韩免费大片 | 欧美久久久久久久久中文字幕 | 亚洲天天在线日亚洲洲精 | 91久久国产自产拍夜夜嗨 | 丁香五婷| 91免费网站在线观看 | 综合铜03 | 久久久免费精品国产一区二区 | 超碰av在线免费观看 | 日韩在线三区 | 西西444www| 天天干天天弄 | 国产精品资源在线观看 | 国产成人一二片 | 日本在线视频一区二区三区 | 国产在线不卡一区 | 亚洲国产精品一区二区尤物区 | 亚洲传媒在线 | 成人欧美一区二区三区黑人麻豆 | 久草热久草视频 | 人人操日日干 | 人人dvd | 在线国产日本 | 国产一区免费在线 | 色婷婷视频 | 香蕉视频在线看 | 欧美成天堂网地址 | 欧洲一区二区三区精品 | 国产精品一区在线观看你懂的 | 2017狠狠干 | 波多野结衣在线视频一区 | 91av手机在线观看 | 欧美一级免费黄色片 | 国产乱码精品一区二区蜜臀 | 射九九 | 国产黄免费 | 亚洲无在线 | x99av成人免费| 国产精品99久久久精品免费观看 | 亚洲一区二区天堂 | 国产精品美女久久久网av | 国产在线97 | 日韩av成人在线 | 日本精油按摩3 | 日韩v欧美v日本v亚洲v国产v | 中文字幕视频 | 亚洲精品久久久蜜桃直播 | 激情欧美xxxx| 天天插伊人 | 在线观看中文字幕2021 | 国产黄色片一级 | 国产一级久久 | 国产成人a亚洲精品v | 日韩成人看片 | 激情五月激情综合网 | 亚洲在线视频观看 | 99这里有精品 | 久久伊人精品一区二区三区 | 在线蜜桃视频 | 国产中文字幕视频在线 | 色射爱 | 91亚洲精品在线观看 | 热久久国产精品 | 在线 影视 一区 | 久久免费久久 | 亚洲免费国产 | 四虎永久免费网站 | 毛片区 | 成人精品一区二区三区中文字幕 | 色综合久久五月天 | 日韩高清精品一区二区 | 久久久久久欧美二区电影网 | 人人爱人人爽 | 欧美贵妇性狂欢 | 欧美日韩视频精品 | 一级黄色av | 免费 在线 中文 日本 | 亚洲国产精品成人女人久久 | 99在线播放 | a在线观看免费视频 | www.夜夜夜 | 久久99最新地址 | 99中文字幕在线观看 | 狠狠躁夜夜躁人人爽超碰97香蕉 | 丁香婷婷综合激情五月色 | av一区在线 | 精品伦理一区二区三区 | 欧美日韩久久一区 | 亚洲午夜精品久久久久久久久久久久 | 天天色天天爱天天射综合 | 日本在线观看黄色 | 国产精品视频地址 | 中文字幕av免费在线观看 | 手机av电影在线 | av爱干| 亚洲国产97在线精品一区 | 九九综合九九综合 | 亚洲精品视频一 | 在线观看国产日韩欧美 | 亚洲区另类春色综合小说校园片 | 黄色小说网站在线 | 日韩精品一区二区三区三炮视频 | 国产精品久久久av | 97视频在线免费 | 国产日韩欧美在线影视 | 久久成人一区二区 | 深夜免费福利视频 | 日日躁天天躁 | 国产精品一区二区免费 | 最新日韩精品 | 精品国产伦一区二区三区观看方式 | 人人爽人人澡人人添人人人人 | 久久电影色 | 色视频 在线 | 日韩精品一区二区三区外面 | 天天操天天舔天天干 | 91精品久久久久久综合乱菊 | 久久久午夜精品理论片中文字幕 | 国产美女视频免费 | 欧美一级乱黄 | 国产精品999久久久 久产久精国产品 | 综合网在线视频 | 国产日韩精品一区二区 | 五月天丁香 | 亚洲 欧美 日韩 综合 | 国产精品久久久久久久久久白浆 | 最新av免费在线观看 | 综合网在线视频 | 午夜黄色一级片 | 天天操夜夜曰 | 免费在线观看污 | 日韩专区一区二区 | 欧美电影黄色 | 夜夜躁日日躁狠狠久久88av | 激情影音先锋 | 久久av电影 | 很污的网站 | 亚洲国产精品视频 | 在线黄色免费 | 91九色蝌蚪视频 | 中文永久字幕 | 欧美一级片在线观看视频 | 一区在线免费观看 | 国产a视频免费观看 | 九色视频网 | 又色又爽又激情的59视频 | 日韩精品高清视频 | 国产精品普通话 | 一区二区中文字幕在线播放 | 欧美孕交vivoestv另类 | 亚洲无线视频 | 日韩性久久 | 国产成人久久精品亚洲 | 国产欧美最新羞羞视频在线观看 | 亚洲区另类春色综合小说校园片 | 成人黄色毛片 | 日韩精品欧美一区 | 男女全黄一级一级高潮免费看 | 91在线视频导航 | 国产亚洲精品久久久久秋 | 五月婷婷伊人网 | 婷婷夜夜| 狠狠躁日日躁狂躁夜夜躁av | 久久综合色播五月 | 日韩电影一区二区三区在线观看 | 激情综合五月 | 97人人模人人爽人人少妇 | 中文字幕在线色 | 久99久在线 | 天堂麻豆 | 国产成人黄色在线 | 亚洲精品国偷拍自产在线观看蜜桃 | 在线观看国产www | 四川妇女搡bbbb搡bbbb搡 | 蜜臀久久99精品久久久酒店新书 | 在线中文字幕网站 | 97成人在线观看 | 国产手机视频 | 国产午夜精品福利视频 | 亚洲无吗av | 成人黄色在线电影 | 99久久精品免费视频 | 美女在线国产 | 99久久99热这里只有精品 | 国产美女无遮挡永久免费 | 久久不卡视频 | 中文字幕在线观看一区二区三区 | 免费激情网 |