mmdeploy/csrc/preprocess/cpu/load_impl.cpp

53 lines
1.6 KiB
C++

// Copyright (c) OpenMMLab. All rights reserved.
#include "opencv_utils.h"
#include "preprocess/transform/load.h"
using namespace std;
namespace mmdeploy {
namespace cpu {
class PrepareImageImpl : public ::mmdeploy::PrepareImageImpl {
public:
explicit PrepareImageImpl(const Value& args) : ::mmdeploy::PrepareImageImpl(args){};
~PrepareImageImpl() override = default;
protected:
Result<Tensor> ConvertToBGR(const Mat& img) override {
auto src_mat = Mat2CVMat(img);
auto dst_mat = ColorTransfer(src_mat, img.pixel_format(), PixelFormat::kBGR);
if (arg_.to_float32) {
cv::Mat _dst_mat;
dst_mat.convertTo(_dst_mat, CV_32FC3);
dst_mat = _dst_mat;
}
return ::mmdeploy::cpu::CVMat2Tensor(dst_mat);
}
Result<Tensor> ConvertToGray(const Mat& img) override {
auto src_mat = Mat2CVMat(img);
auto dst_mat = ColorTransfer(src_mat, img.pixel_format(), PixelFormat::kGRAYSCALE);
if (arg_.to_float32) {
cv::Mat _dst_mat;
dst_mat.convertTo(_dst_mat, CV_32FC1);
dst_mat = _dst_mat;
}
return ::mmdeploy::cpu::CVMat2Tensor(dst_mat);
}
};
class PrepareImageImplCreator : public Creator<::mmdeploy::PrepareImageImpl> {
public:
const char* GetName() const override { return "cpu"; }
int GetVersion() const override { return 1; }
ReturnType Create(const Value& args) override { return make_unique<PrepareImageImpl>(args); }
};
} // namespace cpu
} // namespace mmdeploy
using mmdeploy::PrepareImageImpl;
using mmdeploy::cpu::PrepareImageImplCreator;
REGISTER_MODULE(PrepareImageImpl, PrepareImageImplCreator);