mirror of
https://github.com/PaddlePaddle/FastDeploy.git
synced 2026-04-23 00:17:25 +08:00
9164796645
* 添加paddleclas模型 * 更新README_CN * 更新README_CN * 更新README * update get_model.sh * update get_models.sh * update paddleseg models * update paddle_seg models * update paddle_seg models * modified test resources * update benchmark_gpu_trt.sh * add paddle detection * add paddledetection to benchmark * modified benchmark cmakelists * update benchmark scripts * modified benchmark function calling * modified paddledetection documents * add PaddleDetectonModel * reset examples/paddledetection * resolve conflict * update pybind * resolve conflict * fix bug * delete debug mode * update checkarch log * update trt inputs example * Update README.md --------- Co-authored-by: DefTruth <31974251+DefTruth@users.noreply.github.com>
105 lines
3.2 KiB
C++
Executable File
105 lines
3.2 KiB
C++
Executable File
#include "fastdeploy/vision/detection/ppdet/base.h"
|
|
|
|
#include "fastdeploy/utils/unique_ptr.h"
|
|
#include "fastdeploy/vision/utils/utils.h"
|
|
#include "yaml-cpp/yaml.h"
|
|
|
|
namespace fastdeploy {
|
|
namespace vision {
|
|
namespace detection {
|
|
|
|
PPDetBase::PPDetBase(const std::string& model_file,
|
|
const std::string& params_file,
|
|
const std::string& config_file,
|
|
const RuntimeOption& custom_option,
|
|
const ModelFormat& model_format)
|
|
: preprocessor_(config_file), postprocessor_(preprocessor_.GetArch()) {
|
|
runtime_option = custom_option;
|
|
runtime_option.model_format = model_format;
|
|
runtime_option.model_file = model_file;
|
|
runtime_option.params_file = params_file;
|
|
|
|
}
|
|
|
|
std::unique_ptr<PPDetBase> PPDetBase::Clone() const {
|
|
std::unique_ptr<PPDetBase> clone_model =
|
|
fastdeploy::utils::make_unique<PPDetBase>(PPDetBase(*this));
|
|
clone_model->SetRuntime(clone_model->CloneRuntime());
|
|
return clone_model;
|
|
}
|
|
|
|
bool PPDetBase::Initialize() {
|
|
if (!InitRuntime()) {
|
|
FDERROR << "Failed to initialize fastdeploy backend." << std::endl;
|
|
return false;
|
|
}
|
|
return true;
|
|
}
|
|
|
|
bool PPDetBase::Predict(cv::Mat* im, DetectionResult* result) {
|
|
return Predict(*im, result);
|
|
}
|
|
|
|
bool PPDetBase::Predict(const cv::Mat& im, DetectionResult* result) {
|
|
std::vector<DetectionResult> results;
|
|
if (!BatchPredict({im}, &results)) {
|
|
return false;
|
|
}
|
|
*result = std::move(results[0]);
|
|
return true;
|
|
}
|
|
|
|
bool PPDetBase::BatchPredict(const std::vector<cv::Mat>& imgs,
|
|
std::vector<DetectionResult>* results) {
|
|
std::vector<FDMat> fd_images = WrapMat(imgs);
|
|
if (!preprocessor_.Run(&fd_images, &reused_input_tensors_)) {
|
|
FDERROR << "Failed to preprocess the input image." << std::endl;
|
|
return false;
|
|
}
|
|
reused_input_tensors_[0].name = "image";
|
|
reused_input_tensors_[1].name = "scale_factor";
|
|
reused_input_tensors_[2].name = "im_shape";
|
|
|
|
if (NumInputsOfRuntime() == 1) {
|
|
auto scale_factor = static_cast<float*>(reused_input_tensors_[1].Data());
|
|
postprocessor_.SetScaleFactor({scale_factor[0], scale_factor[1]});
|
|
}
|
|
|
|
// Some models don't need scale_factor and im_shape as input
|
|
while (reused_input_tensors_.size() != NumInputsOfRuntime()) {
|
|
reused_input_tensors_.pop_back();
|
|
}
|
|
|
|
if (!Infer(reused_input_tensors_, &reused_output_tensors_)) {
|
|
FDERROR << "Failed to inference by runtime." << std::endl;
|
|
return false;
|
|
}
|
|
|
|
if (!postprocessor_.Run(reused_output_tensors_, results)) {
|
|
FDERROR << "Failed to postprocess the inference results by runtime."
|
|
<< std::endl;
|
|
return false;
|
|
}
|
|
return true;
|
|
}
|
|
|
|
bool PPDetBase::CheckArch(){
|
|
std::vector<std::string> archs = {"SOLOv2","YOLO","SSD","RetinaNet","RCNN","Face","GFL","YOLOX","YOLOv5","YOLOv6","YOLOv7","RTMDet","FCOS","TTFNet","TOOD","DETR"};
|
|
auto arch_ = preprocessor_.GetArch();
|
|
for (auto item : archs) {
|
|
if (arch_ == item) {
|
|
return true;
|
|
}
|
|
}
|
|
FDWARNING << "Please set model arch,"
|
|
<< "support value : SOLOv2, YOLO, SSD, RetinaNet, RCNN, Face , GFL , RTMDet ,"\
|
|
<<"FCOS , TTFNet , TOOD , DETR." << std::endl;
|
|
return false;
|
|
|
|
|
|
}
|
|
|
|
} // namespace detection
|
|
} // namespace vision
|
|
} // namespace fastdeploy
|