Imported Upstream version 1.21.0
[platform/core/ml/nnfw.git] / compiler / luci-interpreter / src / loader / nodes / StridedSlice.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/StridedSlice.h"
20
21 namespace luci_interpreter
22 {
23
24 std::unique_ptr<Kernel> build_kernel_CircleStridedSlice(const luci::CircleNode *circle_node,
25                                                         KernelBuilderHelper &helper)
26 {
27   const auto *node = loco::must_cast<const luci::CircleStridedSlice *>(circle_node);
28   assert(node->arity() == 4);
29
30   const Tensor *input = helper.getInputTensor(node->input());
31   const Tensor *begin = helper.getInputTensor(node->begin());
32   const Tensor *end = helper.getInputTensor(node->end());
33   const Tensor *strides = helper.getInputTensor(node->strides());
34
35   Tensor *output = helper.getOutputTensor(node);
36
37   StridedSliceParams params{};
38   params.begin_mask = node->begin_mask();
39   params.ellipsis_mask = node->ellipsis_mask();
40   params.end_mask = node->end_mask();
41   params.new_axis_mask = node->new_axis_mask();
42   params.shrink_axis_mask = node->shrink_axis_mask();
43
44   return std::make_unique<kernels::StridedSlice>(input, begin, end, strides, output, params);
45 }
46
47 } // namespace luci_interpreter