MNN/source/backend/cpu/CPUConvolutionDepthwise.hpp

71 lines
2.9 KiB
C++
Raw Normal View History

2019-04-17 10:49:11 +08:00
//
// CPUConvolutionDepthwise.hpp
// MNN
//
// Created by MNN on 2018/07/20.
// Copyright © 2018, Alibaba Group Holding Limited
//
#ifndef CPUConvolutionDepthwise_hpp
#define CPUConvolutionDepthwise_hpp
2019-12-27 22:16:57 +08:00
#include "core/AutoStorage.h"
#include "backend/cpu/CPUConvolution.hpp"
#include "backend/cpu/compute/ConvolutionIntFactory.hpp"
2019-04-17 10:49:11 +08:00
namespace MNN {
2021-01-06 16:29:37 +08:00
class CPUConvolutionDepthwise {
2019-04-17 10:49:11 +08:00
public:
class BasicFloatExecution : public CPUConvolution {
2019-04-17 10:49:11 +08:00
public:
BasicFloatExecution(const Convolution2DCommon *common, Backend *b) : CPUConvolution(common, b) {
}
virtual ~BasicFloatExecution() = default;
2019-04-17 10:49:11 +08:00
virtual ErrorCode onExecute(const std::vector<Tensor *> &inputs, const std::vector<Tensor *> &outputs) override;
virtual ErrorCode onResize(const std::vector<Tensor *> &inputs, const std::vector<Tensor *> &outputs) override;
private:
2021-04-08 15:34:23 +08:00
std::function<void(const uint8_t *, uint8_t *, int)> mExecutor;
2019-04-17 10:49:11 +08:00
int mNumber = 1;
};
class MultiInputFloatExecution : public BasicFloatExecution {
public:
MultiInputFloatExecution(const Convolution2DCommon *common, Backend *b) : BasicFloatExecution(common, b) {
}
virtual ~MultiInputFloatExecution() = default;
virtual ErrorCode onResize(const std::vector<Tensor *> &inputs, const std::vector<Tensor *> &outputs) override;
virtual ErrorCode onExecute(const std::vector<Tensor *> &inputs, const std::vector<Tensor *> &outputs) override;
private:
std::unique_ptr<Tensor> mWeight;
std::unique_ptr<Tensor> mBias;
std::vector<Tensor *> mTempInputs;
};
class FloatExecution : public CPUConvolution {
public:
FloatExecution(const Convolution2DCommon *common, Backend *b, const float *originWeight,
size_t originWeightSize, const float *bias, size_t biasSize);
virtual ~FloatExecution();
virtual ErrorCode onExecute(const std::vector<Tensor *> &inputs,
const std::vector<Tensor *> &outputs) override {
return mOrigin->onExecute(mTempInputs, outputs);
}
virtual ErrorCode onResize(const std::vector<Tensor *> &inputs, const std::vector<Tensor *> &outputs) override {
2021-01-06 16:29:37 +08:00
mTempInputs = {inputs[0], mResource->mWeight.get(), mResource->mBias.get()};
return mOrigin->onResize(mTempInputs, outputs);
}
2021-01-06 16:29:37 +08:00
virtual bool onClone(Backend* bn, const Op* op, Execution** dst) override;
private:
2021-01-06 16:29:37 +08:00
FloatExecution(std::shared_ptr<Resource> resource, const Convolution2DCommon* common, Backend* b) : CPUConvolution(common, b) {
mResource = resource;
mOrigin.reset(new BasicFloatExecution(common, b));
}
std::shared_ptr<CPUConvolution::Resource> mResource;
std::vector<Tensor *> mTempInputs;
std::unique_ptr<BasicFloatExecution> mOrigin;
};
2019-04-17 10:49:11 +08:00
};
} // namespace MNN
#endif /* CPUConvolutionDepthwise_hpp */