2 * Copyright (c) 2021 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 #include "luci/ConnectNode.h"
19 #include "ConnectNode.test.h"
21 #include <luci/Service/CircleNodeClone.h>
23 #include <gtest/gtest.h>
28 using namespace luci::test;
30 class NodeGraphlet : public NodeGraphletT<luci::CircleFullyConnected>
33 NodeGraphlet() = default;
36 void init(loco::Graph *g) override
38 NodeGraphletT<luci::CircleFullyConnected>::init(g);
40 _node->fusedActivationFunction(luci::FusedActFunc::RELU);
41 _node->weights_format(luci::CircleFullyConnected::WeightsFormat::DEFAULT);
45 class TestNodeGraph : public TestIsOGraph<3>, public NodeGraphlet
48 TestNodeGraph() = default;
51 void init(const ShapeU32 shape)
53 TestIsOGraph<3>::init({shape, shape, shape}, shape);
54 NodeGraphlet::init(g());
56 node()->input(input(0));
57 node()->weights(input(1));
58 node()->bias(input(2));
60 output()->from(node());
66 TEST(ConnectNodeTest, connect_FullyConnected)
71 ConnectionTestHelper cth;
72 cth.prepare_inputs(&tng);
74 auto *node = tng.node();
75 ASSERT_NO_THROW(loco::must_cast<luci::CircleFullyConnected *>(node));
77 auto *clone = luci::clone_node(node, cth.graph_clone());
78 ASSERT_NO_THROW(loco::must_cast<luci::CircleFullyConnected *>(clone));
80 cth.clone_connect(node, clone);
82 ASSERT_EQ(3, clone->arity());
83 ASSERT_EQ(cth.inputs(0), clone->arg(0));
84 ASSERT_EQ(cth.inputs(1), clone->arg(1));
85 ASSERT_EQ(cth.inputs(2), clone->arg(2));
88 TEST(ConnectNodeTest, connect_FullyConnected_NEG)
93 ConnectionTestHelper cth;
94 cth.prepare_inputs_miss(&tng);
96 auto *node = tng.node();
97 ASSERT_NO_THROW(loco::must_cast<luci::CircleFullyConnected *>(node));
99 auto *clone = luci::clone_node(node, cth.graph_clone());
100 ASSERT_NO_THROW(loco::must_cast<luci::CircleFullyConnected *>(clone));
102 EXPECT_ANY_THROW(cth.clone_connect(node, clone));