Imported Upstream version 1.18.0
[platform/core/ml/nnfw.git] / compiler / luci-interpreter / src / loader / nodes / AveragePool2D.cpp
1 /*
2  * Copyright (c) 2021 Samsung Electronics Co., Ltd. All Rights Reserved
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *    http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16
17 #include "Builders.h"
18
19 #include "kernels/AveragePool2D.h"
20
21 namespace luci_interpreter
22 {
23
24 std::unique_ptr<Kernel> build_kernel_CircleAveragePool2D(const luci::CircleNode *circle_node,
25                                                          KernelBuilderHelper &helper)
26 {
27   const auto *node = dynamic_cast<const luci::CircleAveragePool2D *>(circle_node);
28   if (node == nullptr)
29     throw std::runtime_error("wrong builder for operation");
30   assert(node->arity() == 1);
31
32   const Tensor *input = helper.getInputTensor(node->value());
33   Tensor *output = helper.getOutputTensor(node);
34
35   Pool2DParams params{};
36   params.padding = node->padding();
37   params.filter_height = node->filter()->h();
38   params.filter_width = node->filter()->w();
39   params.stride_height = node->stride()->h();
40   params.stride_width = node->stride()->w();
41   params.activation = node->fusedActivationFunction();
42
43   return std::make_unique<kernels::AveragePool2D>(input, output, params);
44 }
45
46 } // namespace luci_interpreter