| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859 |
- // 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/base.h"
- #ifdef ENABLE_CVCUDA
- #include <cvcuda/OpConvertTo.hpp>
- #include "ultra_infer/vision/common/processors/cvcuda_utils.h"
- #endif
- namespace ultra_infer {
- namespace vision {
- /*! @brief Processor for cast images with given type default is float.
- */
- class ULTRAINFER_DECL Cast : public Processor {
- public:
- explicit Cast(const std::string &dtype = "float") : dtype_(dtype) {}
- bool ImplByOpenCV(Mat *mat);
- #ifdef ENABLE_FLYCV
- bool ImplByFlyCV(Mat *mat);
- #endif
- #ifdef ENABLE_CVCUDA
- bool ImplByCvCuda(FDMat *mat);
- #endif
- std::string Name() { return "Cast"; }
- /** \brief Process the input images
- *
- * \param[in] mat The input image data
- * \param[in] dtype type of data will be casted to
- * \param[in] lib to define OpenCV or FlyCV or CVCUDA will be used.
- * \return true if the process succeeded, otherwise false
- */
- static bool Run(Mat *mat, const std::string &dtype,
- ProcLib lib = ProcLib::DEFAULT);
- std::string GetDtype() const { return dtype_; }
- private:
- std::string dtype_;
- #ifdef ENABLE_CVCUDA
- cvcuda::ConvertTo cvcuda_convert_op_;
- #endif
- };
- } // namespace vision
- } // namespace ultra_infer
|