MNN/source/backend/metal/MetalConvolutionWinograd.hpp

45 lines
1.3 KiB
C++
Raw Normal View History

2019-04-17 10:49:11 +08:00
//
// MetalConvolutionWinograd.hpp
// MNN
//
// Created by MNN on 2019/01/31.
// Copyright © 2018, Alibaba Group Holding Limited
//
#ifndef MetalConvolutionWinograd_hpp
#define MetalConvolutionWinograd_hpp
#import "MetalConvolutionCommon.hpp"
#if MNN_METAL_ENABLED
namespace MNN {
class MetalConvolutionWinograd : public MetalConvolutionCommon {
public:
2022-06-10 10:39:50 +08:00
static bool isValid(const Convolution2D *conv, const Tensor *input, const Tensor* output);
2019-04-17 10:49:11 +08:00
MetalConvolutionWinograd(Backend *backend, const Tensor *input, const MNN::Op *op);
virtual ~MetalConvolutionWinograd() = default;
virtual ErrorCode onResize(const std::vector<Tensor *> &inputs, const std::vector<Tensor *> &outputs) override;
protected:
2023-12-27 17:26:44 +08:00
virtual void onFloat(const Tensor *input, const Tensor *output, id<MTLComputeCommandEncoder> encoder) override;
2019-04-17 10:49:11 +08:00
virtual id<MTLBuffer> weightForFloat(int group, int oc, int ic, int kh, int kw, const float *src) override;
private:
id<MTLBuffer> mShapeBuffer = nil;
int mSrcUnit;
int mDstUnit;
std::shared_ptr<Tensor> mTempSrc;
std::shared_ptr<Tensor> mTempDst;
MTLSize mInputTransformThreads;
MTLSize mMatMulThreads;
MTLSize mOutputTransformThreads;
};
} // namespace MNN
#endif /* MNN_METAL_ENABLED */
#endif /* MetalConvolutionWinograd_hpp */