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 #include "luci/IR/Nodes/CircleLocalResponseNormalization.h"
19 #include "luci/IR/CircleDialect.h"
20 #include "luci/IR/CircleNodeVisitor.h"
22 #include <gtest/gtest.h>
24 TEST(CircleLocalResponseNormalizationTest, constructor_P)
26 luci::CircleLocalResponseNormalization local_response_normalization_node;
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());
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());
39 TEST(CircleLocalResponseNormalizationTest, input_NEG)
41 luci::CircleLocalResponseNormalization local_response_normalization_node;
42 luci::CircleLocalResponseNormalization node;
44 local_response_normalization_node.input(&node);
45 ASSERT_NE(nullptr, local_response_normalization_node.input());
47 local_response_normalization_node.input(nullptr);
48 ASSERT_EQ(nullptr, local_response_normalization_node.input());
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());
60 TEST(CircleLocalResponseNormalizationTest, arity_NEG)
62 luci::CircleLocalResponseNormalization local_response_normalization_node;
64 ASSERT_NO_THROW(local_response_normalization_node.arg(0));
65 ASSERT_THROW(local_response_normalization_node.arg(1), std::out_of_range);
68 TEST(CircleLocalResponseNormalizationTest, visit_mutable_NEG)
70 struct TestVisitor final : public luci::CircleNodeMutableVisitor<void>
74 luci::CircleLocalResponseNormalization local_response_normalization_node;
77 ASSERT_THROW(local_response_normalization_node.accept(&tv), std::exception);
80 TEST(CircleLocalResponseNormalizationTest, visit_NEG)
82 struct TestVisitor final : public luci::CircleNodeVisitor<void>
86 luci::CircleLocalResponseNormalization local_response_normalization_node;
89 ASSERT_THROW(local_response_normalization_node.accept(&tv), std::exception);