Files
FastDeploy/fastdeploy/vision/common/processors/base.cc
2022-09-14 15:44:13 +08:00

62 lines
1.6 KiB
C++

// 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.
#include "fastdeploy/vision/common/processors/base.h"
#include "fastdeploy/utils/utils.h"
namespace fastdeploy {
namespace vision {
ProcLib Processor::default_lib = ProcLib::DEFAULT;
bool Processor::CpuRun(Mat* mat) {
FDERROR << "Unimplemented CpuRun." << std::endl;
return false;
}
#ifdef ENABLE_OPENCV_CUDA
bool Processor::GpuRun(Mat* mat) {
FDERROR << "Unimplemented GpuRun." << std::endl;
return false;
}
#endif
bool Processor::operator()(Mat* mat, ProcLib lib) {
// if default_lib is set
// then use default_lib
ProcLib target = lib;
if (default_lib != ProcLib::DEFAULT) {
target = default_lib;
}
if (target == ProcLib::OPENCV_CUDA) {
#ifdef ENABLE_OPENCV_CUDA
bool ret = GpuRun(mat);
mat->device = Device::GPU;
return ret;
#else
FDERROR
<< "OpenCV is not compiled with CUDA, cannot process image with CUDA."
<< std::endl;
return false;
#endif
}
bool ret = CpuRun(mat);
mat->device = Device::CPU;
return ret;
}
} // namespace vision
} // namespace fastdeploy