// 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 "ultra_infer/vision/common/processors/manager.h" #include "ultra_infer/vision/common/processors/transform.h" #include "ultra_infer/vision/common/result.h" namespace ultra_infer { namespace vision { namespace classification { /*! @brief Preprocessor object for PaddleClas serials model. */ class ULTRAINFER_DECL PaddleClasPreprocessor : public ProcessorManager { public: /** \brief Create a preprocessor instance for PaddleClas serials model * * \param[in] config_file Path of configuration file for deployment, e.g * resnet/infer_cfg.yml */ explicit PaddleClasPreprocessor(const std::string &config_file); /** \brief Implement the virtual function of ProcessorManager, Apply() is the * body of Run(). Apply() contains the main logic of preprocessing, Run() is * called by users to execute preprocessing * * \param[in] image_batch The input image batch * \param[in] outputs The output tensors which will feed in runtime * \return true if the preprocess succeeded, otherwise false */ virtual bool Apply(FDMatBatch *image_batch, std::vector *outputs); /// This function will disable normalize in preprocessing step. void DisableNormalize(); /// This function will disable hwc2chw in preprocessing step. void DisablePermute(); /** \brief When the initial operator is Resize, and input image size is large, * maybe it's better to run resize on CPU, because the HostToDevice memcpy * is time consuming. Set this true to run the initial resize on CPU. * * \param[in] v true or false */ void InitialResizeOnCpu(bool v) { initial_resize_on_cpu_ = v; } private: bool BuildPreprocessPipelineFromConfig(); bool initialized_ = false; std::vector> processors_; // for recording the switch of hwc2chw bool disable_permute_ = false; // for recording the switch of normalize bool disable_normalize_ = false; // read config file std::string config_file_; bool initial_resize_on_cpu_ = false; }; } // namespace classification } // namespace vision } // namespace ultra_infer