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 __LUCI_IR_CIRCLEBCQGATHER_H__
18 #define __LUCI_IR_CIRCLEBCQGATHER_H__
20 #include "luci/IR/CircleNodeDecl.h"
21 #include "luci/IR/CircleOpcode.h"
23 #include "luci/IR/LuciNodeMixins.h"
29 * @brief BCQ_GATHER in Circle
31 class CircleBCQGather final : public FixedArityNode<4, CircleNodeImpl<CircleOpcode::BCQ_GATHER>>
34 loco::Node *input_scales(void) const { return at(0)->node(); }
35 void input_scales(loco::Node *node) { at(0)->node(node); }
37 loco::Node *input_binary(void) const { return at(1)->node(); }
38 void input_binary(loco::Node *node) { at(1)->node(node); }
40 loco::Node *indices(void) const { return at(2)->node(); }
41 void indices(loco::Node *node) { at(2)->node(node); }
43 loco::Node *input_clusters(void) const { return at(3)->node(); }
44 void input_clusters(loco::Node *node) { at(3)->node(node); }
47 int32_t axis(void) const { return _axis; }
48 void axis(int32_t axis) { _axis = axis; }
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; }
55 int32_t _input_hidden_size = 0;
60 #endif // __LUCI_IR_CIRCLEBCQGATHER_H__