forked from alibaba/MNN
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathVulkanConvolution.hpp
More file actions
71 lines (58 loc) · 2.42 KB
/
Copy pathVulkanConvolution.hpp
File metadata and controls
71 lines (58 loc) · 2.42 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
//
// VulkanConvolution.hpp
// MNN
//
// Created by MNN on 2019/01/31.
// Copyright © 2018, Alibaba Group Holding Limited
//
#ifndef VulkanConvolution_hpp
#define VulkanConvolution_hpp
#include "VulkanBasicExecution.hpp"
namespace MNN {
class VulkanConvolutionCommon : public VulkanBasicExecution {
public:
VulkanConvolutionCommon(const Op* op, Backend* bn);
virtual ~VulkanConvolutionCommon();
virtual ErrorCode onEncode(const std::vector<Tensor*>& inputs, const std::vector<Tensor*>& outputs,
const VulkanCommandPool::Buffer* cmdBuffer) override;
struct ConvolutionParameter {
ivec2 pad;
ivec2 kernelSize;
ivec2 stride;
ivec2 dilate;
ivec4 inputSize;
ivec4 outputSize;
int batch;
int group;
};
static void writeParameter(ConvolutionParameter* dest, const Convolution2DCommon* common, const Tensor* input,
const Tensor* output);
static std::string getPostTreatMacro(const Convolution2DCommon* common);
protected:
virtual ErrorCode onEncodeConvolution(const Convolution2DCommon* common, const std::vector<Tensor*>& inputs,
const std::vector<Tensor*>& outputs,
const VulkanCommandPool::Buffer* cmdBuffer,
const VulkanBuffer* constConvBuffer, const VulkanImage* biasBuffer) = 0;
private:
std::shared_ptr<VulkanImage> mBias;
const Convolution2DCommon* mCommon;
std::shared_ptr<VulkanBuffer> mConvCons;
};
class VulkanConvolutionDepthwise : public VulkanConvolutionCommon {
public:
VulkanConvolutionDepthwise(const Op* op, Backend* bn);
virtual ~VulkanConvolutionDepthwise();
virtual ErrorCode onEncodeConvolution(const Convolution2DCommon* common, const std::vector<Tensor*>& inputs,
const std::vector<Tensor*>& outputs,
const VulkanCommandPool::Buffer* cmdBuffer,
const VulkanBuffer* constConvBuffer, const VulkanImage* biasBuffer) override;
private:
std::shared_ptr<VulkanImage> mKernel;
const VulkanPipeline* mConvPipeline;
std::shared_ptr<VulkanPipeline::DescriptorSet> mConvSet;
const VulkanSampler* mSampler;
int mLocalX = 0;
int mLocalY = 0;
};
} // namespace MNN
#endif /* VulkanConvolution_hpp */