mirror of
https://github.com/PaddlePaddle/FastDeploy.git
synced 2025-10-16 13:41:30 +08:00
[Model] add detection model : FastestDet (#842)
* model done, CLA fix * remove letter_box and ConvertAndPermute, use resize hwc2chw and convert in preprocess * remove useless values in preprocess * remove useless values in preprocess * fix reviewed problem * fix reviewed problem pybind * fix reviewed problem pybind * postprocess fix * add test_fastestdet.py, coco_val2017_500 fixed done, ready to review * fix reviewed problem * python/.../fastestdet.py * fix infer.cc, preprocess, python/fastestdet.py * fix examples/python/infer.py
This commit is contained in:
@@ -0,0 +1,57 @@
|
||||
// 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.
|
||||
|
||||
#pragma once
|
||||
#include "fastdeploy/vision/common/processors/transform.h"
|
||||
#include "fastdeploy/vision/common/result.h"
|
||||
|
||||
namespace fastdeploy {
|
||||
namespace vision {
|
||||
|
||||
namespace detection {
|
||||
/*! @brief Preprocessor object for FastestDet serials model.
|
||||
*/
|
||||
class FASTDEPLOY_DECL FastestDetPreprocessor {
|
||||
public:
|
||||
/** \brief Create a preprocessor instance for FastestDet serials model
|
||||
*/
|
||||
FastestDetPreprocessor();
|
||||
|
||||
/** \brief Process the input image and prepare input tensors for runtime
|
||||
*
|
||||
* \param[in] images The input image data list, all the elements are returned by cv::imread()
|
||||
* \param[in] outputs The output tensors which will feed in runtime
|
||||
* \param[in] ims_info The shape info list, record input_shape and output_shape
|
||||
* \return true if the preprocess successed, otherwise false
|
||||
*/
|
||||
bool Run(std::vector<FDMat>* images, std::vector<FDTensor>* outputs,
|
||||
std::vector<std::map<std::string, std::array<float, 2>>>* ims_info);
|
||||
|
||||
/// Set target size, tuple of (width, height), default size = {352, 352}
|
||||
void SetSize(const std::vector<int>& size) { size_ = size; }
|
||||
|
||||
/// Get target size, tuple of (width, height), default size = {352, 352}
|
||||
std::vector<int> GetSize() const { return size_; }
|
||||
|
||||
protected:
|
||||
bool Preprocess(FDMat* mat, FDTensor* output,
|
||||
std::map<std::string, std::array<float, 2>>* im_info);
|
||||
|
||||
// target size, tuple of (width, height), default size = {352, 352}
|
||||
std::vector<int> size_;
|
||||
};
|
||||
|
||||
} // namespace detection
|
||||
} // namespace vision
|
||||
} // namespace fastdeploy
|
Reference in New Issue
Block a user