Imported Upstream version 1.7.0
[platform/core/ml/nnfw.git] / compiler / luci / lang / src / Nodes / CircleLocalResponseNormalization.test.cpp
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 #include "luci/IR/Nodes/CircleLocalResponseNormalization.h"
18
19 #include "luci/IR/CircleDialect.h"
20 #include "luci/IR/CircleNodeVisitor.h"
21
22 #include <gtest/gtest.h>
23
24 TEST(CircleLocalResponseNormalizationTest, constructor_P)
25 {
26   luci::CircleLocalResponseNormalization local_response_normalization_node;
27
28   ASSERT_EQ(luci::CircleDialect::get(), local_response_normalization_node.dialect());
29   ASSERT_EQ(luci::CircleOpcode::LOCAL_RESPONSE_NORMALIZATION,
30             local_response_normalization_node.opcode());
31
32   ASSERT_EQ(nullptr, local_response_normalization_node.input());
33   ASSERT_EQ(5, local_response_normalization_node.radius());
34   ASSERT_EQ(1.0f, local_response_normalization_node.bias());
35   ASSERT_EQ(1.0f, local_response_normalization_node.alpha());
36   ASSERT_EQ(0.5f, local_response_normalization_node.beta());
37 }
38
39 TEST(CircleLocalResponseNormalizationTest, input_NEG)
40 {
41   luci::CircleLocalResponseNormalization local_response_normalization_node;
42   luci::CircleLocalResponseNormalization node;
43
44   local_response_normalization_node.input(&node);
45   ASSERT_NE(nullptr, local_response_normalization_node.input());
46
47   local_response_normalization_node.input(nullptr);
48   ASSERT_EQ(nullptr, local_response_normalization_node.input());
49
50   local_response_normalization_node.radius(100);
51   local_response_normalization_node.bias(100.0f);
52   local_response_normalization_node.alpha(100.0f);
53   local_response_normalization_node.beta(100.0f);
54   ASSERT_NE(5, local_response_normalization_node.radius());
55   ASSERT_NE(1.0f, local_response_normalization_node.bias());
56   ASSERT_NE(1.0f, local_response_normalization_node.alpha());
57   ASSERT_NE(0.5f, local_response_normalization_node.beta());
58 }
59
60 TEST(CircleLocalResponseNormalizationTest, arity_NEG)
61 {
62   luci::CircleLocalResponseNormalization local_response_normalization_node;
63
64   ASSERT_NO_THROW(local_response_normalization_node.arg(0));
65   ASSERT_THROW(local_response_normalization_node.arg(1), std::out_of_range);
66 }
67
68 TEST(CircleLocalResponseNormalizationTest, visit_mutable_NEG)
69 {
70   struct TestVisitor final : public luci::CircleNodeMutableVisitor<void>
71   {
72   };
73
74   luci::CircleLocalResponseNormalization local_response_normalization_node;
75
76   TestVisitor tv;
77   ASSERT_THROW(local_response_normalization_node.accept(&tv), std::exception);
78 }
79
80 TEST(CircleLocalResponseNormalizationTest, visit_NEG)
81 {
82   struct TestVisitor final : public luci::CircleNodeVisitor<void>
83   {
84   };
85
86   luci::CircleLocalResponseNormalization local_response_normalization_node;
87
88   TestVisitor tv;
89   ASSERT_THROW(local_response_normalization_node.accept(&tv), std::exception);
90 }