• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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_CONV2D_BUILDER_H
17 #define NEURAL_NETWORK_RUNTIME_CONV2D_BUILDER_H
18 
19 #include "frameworks/native/ops_builder.h"
20 #include "frameworks/native/ops_registry.h"
21 #include "mindir.h"
22 
23 namespace OHOS {
24 namespace NeuralNetworkRuntime {
25 namespace Ops {
26 class Conv2DBuilder : public OpsBuilder {
27 public:
28     Conv2DBuilder();
29     ~Conv2DBuilder() override;
30     OH_NN_ReturnCode Build(const std::vector<uint32_t>& paramsIndex,
31                            const std::vector<uint32_t>& inputsIndex,
32                            const std::vector<uint32_t>& outputsIndex,
33                            const std::vector<std::shared_ptr<NNTensor>>& allTensors) override;
34 
35     LiteGraphPrimitvePtr GetPrimitive() override;
36 
37 private:
38     OH_NN_ReturnCode SetInputAndOutput(const std::vector<uint32_t>& inputsIndex,
39                                        const std::vector<uint32_t>& outputsIndex,
40                                        const std::vector<std::shared_ptr<NNTensor>>& allTensors);
41     OH_NN_ReturnCode SetChannel(const std::vector<uint32_t>& inputsIndex,
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(std::shared_ptr<NNTensor> tensor);
46     OH_NN_ReturnCode SetDilation(std::shared_ptr<NNTensor> tensor);
47     OH_NN_ReturnCode SetPad(std::shared_ptr<NNTensor> tensor);
48     OH_NN_ReturnCode SetGroup(std::shared_ptr<NNTensor> tensor);
49     OH_NN_ReturnCode SetActavitation(std::shared_ptr<NNTensor> tensor);
50 
51 private:
52     int64_t m_group{1};
53     int64_t m_inChannel{0};
54     int64_t m_outChannel{0};
55     std::vector<int64_t> m_kernelSize;
56     std::vector<int64_t> m_strides;
57     std::vector<int64_t> m_pad;
58     std::vector<int64_t> m_dilation;
59     mindspore::lite::PadMode m_padMode{mindspore::lite::PAD_MODE_PAD};
60     mindspore::lite::ActivationType m_activationType{mindspore::lite::ACTIVATION_TYPE_NO_ACTIVATION};
61 };
62 } // namespace Ops
63 } // namespace NeuralNetworkRuntime
64 } // namespace OHOS
65 #endif // NEURAL_NETWORK_RUNTIME_CONV2D_BUILDER_H