MNN/source/backend/cpu/compute/Convolution1x1Strassen.hpp

46 lines
1.6 KiB
C++
Raw Normal View History

2019-04-17 10:49:11 +08:00
//
// Convolution1x1Strassen.hpp
// MNN
//
// Created by MNN on 2019/02/12.
// Copyright © 2018, Alibaba Group Holding Limited
//
#ifndef Convolution1x1Strassen_hpp
#define Convolution1x1Strassen_hpp
#include <functional>
2019-12-27 22:16:57 +08:00
#include "backend/cpu/CPUConvolution.hpp"
#include "backend/cpu/compute/StrassenMatmulComputor.hpp"
2019-04-17 10:49:11 +08:00
namespace MNN {
class Convolution1x1Strassen : public CPUConvolution {
public:
Convolution1x1Strassen(const Convolution2DCommon *common, Backend *b, const float *originWeight,
size_t originWeightSize, const float *bias, size_t biasSize);
2021-01-06 16:29:37 +08:00
Convolution1x1Strassen(std::shared_ptr<CPUConvolution::Resource> resource, const Convolution2DCommon *common, Backend* b);
2019-04-17 10:49:11 +08:00
virtual ~Convolution1x1Strassen();
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;
2021-01-06 16:29:37 +08:00
virtual bool onClone(Backend* bn, const Op* op, Execution** dst) override;
2019-04-17 10:49:11 +08:00
private:
2021-01-06 16:29:37 +08:00
std::shared_ptr<CPUConvolution::Resource> mResource;
2020-07-04 01:21:30 +08:00
struct Unit {
bool mValid = true;
std::vector<Tensor *> mTempInputVector;
std::vector<Tensor *> mTempOutputVector;
std::shared_ptr<StrassenMatrixComputor> mStracssenComputor;
};
std::vector<Unit> mUnits;
std::shared_ptr<Tensor> mTempInputBatch;
std::shared_ptr<Tensor> mTempOutputBatch;
bool mNeedPretreat = false;
2021-04-08 15:34:23 +08:00
std::function<void(const uint8_t* srcBatch, uint8_t* dstBatch)> mPretreatFunction;
2019-04-17 10:49:11 +08:00
};
} // namespace MNN
#endif /* Convolution1x1Strassen_hpp */