1 /*
2  * Copyright (c) 2022 Huawei Device Co., Ltd.
3  * Licensed under the Apache License, Version 2.0 (the "License");
4  * you may not use this file except in compliance with the License.
5  * You may obtain a copy of the License at
6  *
7  *     http://www.apache.org/licenses/LICENSE-2.0
8  *
9  * Unless required by applicable law or agreed to in writing, software
10  * distributed under the License is distributed on an "AS IS" BASIS,
11  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12  * See the License for the specific language governing permissions and
13  * limitations under the License.
14  */
15 
16 #ifndef NEURAL_NETWORK_RUNTIME_CONV2DTRANSPOSE_BUILDER_H
17 #define NEURAL_NETWORK_RUNTIME_CONV2DTRANSPOSE_BUILDER_H
18 
19 #include "ops_builder.h"
20 #include "ops_registry.h"
21 #include "mindir.h"
22 
23 namespace OHOS {
24 namespace NeuralNetworkRuntime {
25 namespace Ops {
26 class Conv2DTransposeBuilder : public OpsBuilder {
27 public:
28     typedef OH_NN_ReturnCode (Conv2DTransposeBuilder::*FuncPtr)(const std::shared_ptr<NNTensor>&);
29 
30     Conv2DTransposeBuilder();
31     ~Conv2DTransposeBuilder() override;
32     OH_NN_ReturnCode Build(const std::vector<uint32_t>& paramsIndex,
33                            const std::vector<uint32_t>& inputsIndex,
34                            const std::vector<uint32_t>& outputsIndex,
35                            const std::vector<std::shared_ptr<NNTensor>>& allTensors) override;
36 
37     LiteGraphPrimitvePtr GetPrimitive() override;
38 
39 private:
40     OH_NN_ReturnCode SetInput(const std::vector<uint32_t>& inputsIndex,
41                               const std::vector<uint32_t>& outputsIndex,
42                               const std::vector<std::shared_ptr<NNTensor>>& allTensors);
43     void SetKernelSize(const std::vector<uint32_t>& inputsIndex,
44                        const std::vector<std::shared_ptr<NNTensor>>& allTensors);
45     OH_NN_ReturnCode SetStrides(const std::shared_ptr<NNTensor>& tensor);
46     OH_NN_ReturnCode SetDilation(const std::shared_ptr<NNTensor>& tensor);
47     OH_NN_ReturnCode SetPad(const std::shared_ptr<NNTensor>& tensor);
48     OH_NN_ReturnCode SetGroup(const std::shared_ptr<NNTensor>& tensor);
49     OH_NN_ReturnCode SetOutPadding(const std::shared_ptr<NNTensor>& tensor);
50     OH_NN_ReturnCode SetActivation(const std::shared_ptr<NNTensor>& tensor);
51 
52 private:
53     int64_t m_group {1};
54     int64_t m_inChannel {0};
55     int64_t m_outChannel {0};
56     std::vector<int64_t> m_kernelSize;
57     std::vector<int64_t> m_strides;
58     std::vector<int64_t> m_padList;
59     std::vector<int64_t> m_dilation;
60     std::vector<int64_t> m_outputPaddings;
61     mindspore::lite::PadMode m_padMode{mindspore::lite::PAD_MODE_PAD};
62     mindspore::lite::ActivationType m_activationType{mindspore::lite::ACTIVATION_TYPE_NO_ACTIVATION};
63     std::unordered_map<OH_NN_TensorType, FuncPtr> m_paramMap = {
64         {OH_NN_CONV2D_TRANSPOSE_STRIDES, &Conv2DTransposeBuilder::SetStrides},
65         {OH_NN_CONV2D_TRANSPOSE_PAD, &Conv2DTransposeBuilder::SetPad},
66         {OH_NN_CONV2D_TRANSPOSE_DILATION, &Conv2DTransposeBuilder::SetDilation},
67         {OH_NN_CONV2D_TRANSPOSE_OUTPUT_PADDINGS, &Conv2DTransposeBuilder::SetOutPadding},
68         {OH_NN_CONV2D_TRANSPOSE_PAD_MODE, &Conv2DTransposeBuilder::SetPad},
69         {OH_NN_CONV2D_TRANSPOSE_ACTIVATION_TYPE, &Conv2DTransposeBuilder::SetActivation},
70         {OH_NN_CONV2D_TRANSPOSE_GROUP, &Conv2DTransposeBuilder::SetGroup}
71     };
72 };
73 } // namespace Ops
74 } // namespace NeuralNetworkRuntime
75 } // namespace OHOS
76 
77 #endif // NEURAL_NETWORK_RUNTIME_CONV2DTRANSPOSE_BUILDER_H
78