Imported Upstream version 1.8.0
[platform/core/ml/nnfw.git] / runtime / onert / backend / cpu / ops / PadLayer.h
1 /*
2  * Copyright (c) 2019 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 #ifndef __ONERT_BACKEND_CPU_OPS_PADLAYER_H__
18 #define __ONERT_BACKEND_CPU_OPS_PADLAYER_H__
19
20 #include <backend/IPortableTensor.h>
21 #include "OperationUtils.h"
22
23 #include <exec/IFunction.h>
24
25 namespace onert
26 {
27 namespace backend
28 {
29 namespace cpu
30 {
31 namespace ops
32 {
33
34 // Note, this is pad with mode=`CONSTANT`: it doesn't support `REFLECT` and
35 // `SYMMETRIC`
36 class PadLayer : public ::onert::exec::IFunction
37 {
38 public:
39   PadLayer();
40
41 public:
42   template <typename T> void padImpl(const T *constant_value_data);
43
44   void configure(const IPortableTensor *input, IPortableTensor *output, const int32_t *padData,
45                  int32_t padRank, const void *constantValueData = nullptr);
46
47   void run() override;
48
49 private:
50   const IPortableTensor *_input;
51   IPortableTensor *_output;
52
53   int32_t _padData[8];
54   int32_t _padRank;
55   ConstDataPtr _constantValueData;
56 };
57
58 } // namespace ops
59 } // namespace cpu
60 } // namespace backend
61 } // namespace onert
62
63 #endif // __ONERT_BACKEND_CPU_OPS_PADLAYER_H__