Imported Upstream version 1.7.0
[platform/core/ml/nnfw.git] / compiler / luci / lang / include / luci / IR / Nodes / CircleBCQGather.h
1 /*
2  * Copyright (c) 2020 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 __LUCI_IR_CIRCLEBCQGATHER_H__
18 #define __LUCI_IR_CIRCLEBCQGATHER_H__
19
20 #include "luci/IR/CircleNodeDecl.h"
21 #include "luci/IR/CircleOpcode.h"
22
23 #include "luci/IR/LuciNodeMixins.h"
24
25 namespace luci
26 {
27
28 /**
29  * @brief BCQ_GATHER in Circle
30  */
31 class CircleBCQGather final : public FixedArityNode<4, CircleNodeImpl<CircleOpcode::BCQ_GATHER>>
32 {
33 public:
34   loco::Node *input_scales(void) const { return at(0)->node(); }
35   void input_scales(loco::Node *node) { at(0)->node(node); }
36
37   loco::Node *input_binary(void) const { return at(1)->node(); }
38   void input_binary(loco::Node *node) { at(1)->node(node); }
39
40   loco::Node *indices(void) const { return at(2)->node(); }
41   void indices(loco::Node *node) { at(2)->node(node); }
42
43   loco::Node *input_clusters(void) const { return at(3)->node(); }
44   void input_clusters(loco::Node *node) { at(3)->node(node); }
45
46 public:
47   int32_t axis(void) const { return _axis; }
48   void axis(int32_t axis) { _axis = axis; }
49
50   int32_t input_hidden_size(void) const { return _input_hidden_size; }
51   void input_hidden_size(int32_t input_hidden_size) { _input_hidden_size = input_hidden_size; }
52
53 private:
54   int32_t _axis = 0;
55   int32_t _input_hidden_size = 0;
56 };
57
58 } // namespace luci
59
60 #endif // __LUCI_IR_CIRCLEBCQGATHER_H__