mirror of
https://github.com/PaddlePaddle/FastDeploy.git
synced 2025-10-05 16:48:03 +08:00

* add paddle_trt in benchmark * update benchmark in device * update benchmark * update result doc * fixed for CI * update python api_docs * update index.rst * add runtime cpp examples * deal with comments * Update infer_paddle_tensorrt.py * Add runtime quick start * deal with comments * fixed reused_input_tensors&&reused_output_tensors * fixed docs * fixed headpose typo * fixed typo * refactor yolov5 * update model infer * refactor pybind for yolov5 * rm origin yolov5 * fixed bugs * rm cuda preprocess * fixed bugs * fixed bugs * fixed bug * fixed bug * fix pybind * rm useless code * add convert_and_permute * fixed bugs * fixed im_info for bs_predict * fixed bug * add bs_predict for yolov5 * Add runtime test and batch eval * deal with comments * fixed bug * update testcase * fixed batch eval bug * fixed preprocess bug * refactor yolov7 * add yolov7 testcase * rm resize_after_load and add is_scale_up * fixed bug * set multi_label true Co-authored-by: Jason <928090362@qq.com>
166 lines
6.2 KiB
Python
Executable File
166 lines
6.2 KiB
Python
Executable File
# Copyright (c) 2022 PaddlePaddle Authors. All Rights Reserved.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
# you may not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
# See the License for the specific language governing permissions and
|
|
# limitations under the License.
|
|
|
|
from fastdeploy import ModelFormat
|
|
import fastdeploy as fd
|
|
import cv2
|
|
import os
|
|
import pickle
|
|
import numpy as np
|
|
import runtime_config as rc
|
|
|
|
|
|
def test_detection_yolov7():
|
|
model_url = "https://bj.bcebos.com/paddlehub/fastdeploy/yolov7.onnx"
|
|
input_url1 = "https://gitee.com/paddlepaddle/PaddleDetection/raw/release/2.4/demo/000000014439.jpg"
|
|
input_url2 = "https://gitee.com/paddlepaddle/PaddleDetection/raw/release/2.4/demo/000000570688.jpg"
|
|
result_url1 = "https://bj.bcebos.com/paddlehub/fastdeploy/yolov7_result1.pkl"
|
|
result_url2 = "https://bj.bcebos.com/paddlehub/fastdeploy/yolov7_result2.pkl"
|
|
fd.download(model_url, "resources")
|
|
fd.download(input_url1, "resources")
|
|
fd.download(input_url2, "resources")
|
|
fd.download(result_url1, "resources")
|
|
fd.download(result_url2, "resources")
|
|
|
|
model_file = "resources/yolov7.onnx"
|
|
model = fd.vision.detection.YOLOv7(
|
|
model_file, runtime_option=rc.test_option)
|
|
|
|
with open("resources/yolov7_result1.pkl", "rb") as f:
|
|
expect1 = pickle.load(f)
|
|
|
|
with open("resources/yolov7_result2.pkl", "rb") as f:
|
|
expect2 = pickle.load(f)
|
|
|
|
# compare diff
|
|
im1 = cv2.imread("./resources/000000014439.jpg")
|
|
im2 = cv2.imread("./resources/000000570688.jpg")
|
|
|
|
for i in range(3):
|
|
# test single predict
|
|
result1 = model.predict(im1)
|
|
result2 = model.predict(im2)
|
|
|
|
diff_boxes_1 = np.fabs(
|
|
np.array(result1.boxes) - np.array(expect1["boxes"]))
|
|
diff_boxes_2 = np.fabs(
|
|
np.array(result2.boxes) - np.array(expect2["boxes"]))
|
|
|
|
diff_label_1 = np.fabs(
|
|
np.array(result1.label_ids) - np.array(expect1["label_ids"]))
|
|
diff_label_2 = np.fabs(
|
|
np.array(result2.label_ids) - np.array(expect2["label_ids"]))
|
|
|
|
diff_scores_1 = np.fabs(
|
|
np.array(result1.scores) - np.array(expect1["scores"]))
|
|
diff_scores_2 = np.fabs(
|
|
np.array(result2.scores) - np.array(expect2["scores"]))
|
|
|
|
assert diff_boxes_1.max(
|
|
) < 1e-06, "There's difference in detection boxes 1."
|
|
assert diff_label_1.max(
|
|
) < 1e-06, "There's difference in detection label 1."
|
|
assert diff_scores_1.max(
|
|
) < 1e-05, "There's difference in detection score 1."
|
|
|
|
assert diff_boxes_2.max(
|
|
) < 1e-06, "There's difference in detection boxes 2."
|
|
assert diff_label_2.max(
|
|
) < 1e-06, "There's difference in detection label 2."
|
|
assert diff_scores_2.max(
|
|
) < 1e-05, "There's difference in detection score 2."
|
|
|
|
# test batch predict
|
|
results = model.batch_predict([im1, im2])
|
|
result1 = results[0]
|
|
result2 = results[1]
|
|
|
|
diff_boxes_1 = np.fabs(
|
|
np.array(result1.boxes) - np.array(expect1["boxes"]))
|
|
diff_boxes_2 = np.fabs(
|
|
np.array(result2.boxes) - np.array(expect2["boxes"]))
|
|
|
|
diff_label_1 = np.fabs(
|
|
np.array(result1.label_ids) - np.array(expect1["label_ids"]))
|
|
diff_label_2 = np.fabs(
|
|
np.array(result2.label_ids) - np.array(expect2["label_ids"]))
|
|
|
|
diff_scores_1 = np.fabs(
|
|
np.array(result1.scores) - np.array(expect1["scores"]))
|
|
diff_scores_2 = np.fabs(
|
|
np.array(result2.scores) - np.array(expect2["scores"]))
|
|
assert diff_boxes_1.max(
|
|
) < 1e-06, "There's difference in detection boxes 1."
|
|
assert diff_label_1.max(
|
|
) < 1e-06, "There's difference in detection label 1."
|
|
assert diff_scores_1.max(
|
|
) < 1e-05, "There's difference in detection score 1."
|
|
|
|
assert diff_boxes_2.max(
|
|
) < 1e-06, "There's difference in detection boxes 2."
|
|
assert diff_label_2.max(
|
|
) < 1e-06, "There's difference in detection label 2."
|
|
assert diff_scores_2.max(
|
|
) < 1e-05, "There's difference in detection score 2."
|
|
|
|
|
|
def test_detection_yolov7_runtime():
|
|
model_url = "https://bj.bcebos.com/paddlehub/fastdeploy/yolov7.onnx"
|
|
input_url1 = "https://gitee.com/paddlepaddle/PaddleDetection/raw/release/2.4/demo/000000014439.jpg"
|
|
result_url1 = "https://bj.bcebos.com/paddlehub/fastdeploy/yolov7_result1.pkl"
|
|
fd.download(model_url, "resources")
|
|
fd.download(input_url1, "resources")
|
|
fd.download(result_url1, "resources")
|
|
|
|
model_file = "resources/yolov7.onnx"
|
|
|
|
preprocessor = fd.vision.detection.YOLOv7Preprocessor()
|
|
postprocessor = fd.vision.detection.YOLOv7Postprocessor()
|
|
|
|
rc.test_option.set_model_path(model_file, model_format=ModelFormat.ONNX)
|
|
rc.test_option.use_openvino_backend()
|
|
runtime = fd.Runtime(rc.test_option)
|
|
|
|
with open("resources/yolov7_result1.pkl", "rb") as f:
|
|
expect1 = pickle.load(f)
|
|
|
|
# compare diff
|
|
im1 = cv2.imread("./resources/000000014439.jpg")
|
|
|
|
for i in range(3):
|
|
# test runtime
|
|
input_tensors, ims_info = preprocessor.run([im1.copy()])
|
|
output_tensors = runtime.infer({"images": input_tensors[0]})
|
|
results = postprocessor.run(output_tensors, ims_info)
|
|
result1 = results[0]
|
|
|
|
diff_boxes_1 = np.fabs(
|
|
np.array(result1.boxes) - np.array(expect1["boxes"]))
|
|
diff_label_1 = np.fabs(
|
|
np.array(result1.label_ids) - np.array(expect1["label_ids"]))
|
|
diff_scores_1 = np.fabs(
|
|
np.array(result1.scores) - np.array(expect1["scores"]))
|
|
|
|
assert diff_boxes_1.max(
|
|
) < 1e-04, "There's difference in detection boxes 1."
|
|
assert diff_label_1.max(
|
|
) < 1e-06, "There's difference in detection label 1."
|
|
assert diff_scores_1.max(
|
|
) < 1e-05, "There's difference in detection score 1."
|
|
|
|
|
|
if __name__ == "__main__":
|
|
test_detection_yolov7()
|
|
test_detection_yolov7_runtime()
|