2 * Copyright (c) 2020 Samsung Electronics Co., Ltd. All Rights Reserved
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
8 * http://www.apache.org/licenses/LICENSE-2.0
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.
17 #ifndef __ONERT_BACKEND_CPU_KERNEL_REDUCESUMLAYER_H__
18 #define __ONERT_BACKEND_CPU_KERNEL_REDUCESUMLAYER_H__
20 #include "../operand/Tensor.h"
22 #include <exec/IFunction.h>
51 class ReduceLayer : public ::onert::exec::IFunction
58 void configure(const operand::Tensor *input, operand::Tensor *output, ReduceType reduceType,
59 const std::vector<int> &axes, bool keep_dims);
64 // this abstract method is used just for profiling and called for
65 // backend::acl_common::AclFunction
70 const operand::Tensor *_input;
71 operand::Tensor *_output;
72 ReduceType _reduceType;
73 std::vector<int> _axes;
76 std::unique_ptr<nnfw::cker::Reduce> _reduce_kernel;
81 } // namespace backend
84 #endif // __ONERT_BACKEND_CPU_KERNEL_REDUCESUMLAYER_H__