Imported Upstream version 1.9.0
[platform/core/ml/nnfw.git] / runtime / onert / core / src / ir / operation / ElementwiseActivation.cc
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 "ir/operation/ElementwiseActivation.h"
18
19 #include <cassert>
20 #include <unordered_map>
21
22 #include "ir/OperationVisitor.h"
23
24 namespace onert
25 {
26 namespace ir
27 {
28 namespace operation
29 {
30
31 void ElementwiseActivation::accept(OperationVisitor &v) const { v.visit(*this); }
32
33 ElementwiseActivation::ElementwiseActivation(const OperandIndexSequence &inputs,
34                                              const OperandIndexSequence &outputs,
35                                              const Param &param)
36     : Operation{OperandConstraint::createExact(1u), inputs, outputs}, _param{param}
37 {
38   if (param.op_type == Type::LOGISTIC)
39   {
40     assert(param.alpha == 0.0f && param.beta == 0.0f && "Logistic will be supported only as "
41                                                         "sigmoid function(L=1, k=1, x0=0). So, do "
42                                                         "not use alpha and beta");
43   }
44   else if (param.op_type == Type::RELU)
45   {
46     assert(param.alpha >= param.beta && "ReLU's alpha must be equal or greater than beta");
47   }
48   else if (param.op_type == Type::TANH)
49   {
50     assert(param.alpha == 1.0f && param.beta == 1.0f && "f(x) = alpha * tanh(beta * x), Tanh is "
51                                                         "supported only the values of alpha and "
52                                                         "beta are 1.f");
53   }
54 }
55
56 std::string ElementwiseActivation::name() const
57 {
58   using ElementwiseActivationType = onert::ir::operation::ElementwiseActivation::Type;
59   static const std::unordered_map<Type, std::string> name_map{
60       {ElementwiseActivationType::ELU, "ELU"},
61       {ElementwiseActivationType::LOGISTIC, "Logistic"},
62       {ElementwiseActivationType::RELU, "ReLU"},
63       {ElementwiseActivationType::TANH, "Tanh"},
64       {ElementwiseActivationType::LEAKY_RELU, "LeakyRelu"}};
65   return name_map.at(_param.op_type);
66 }
67
68 float ElementwiseActivation::infinity = std::numeric_limits<float>::infinity();
69
70 } // namespace operation
71 } // namespace ir
72 } // namespace onert