Imported Upstream version 1.25.0
[platform/core/ml/nnfw.git] / compiler / luci-interpreter / src / kernels / Log.cpp
1 /*
2  * Copyright (c) 2023 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 "kernels/Log.h"
18 #include "kernels/Utils.h"
19
20 #include <cmath>
21
22 namespace luci_interpreter
23 {
24
25 namespace kernels
26 {
27
28 Log::Log(const Tensor *input, Tensor *output) : Kernel({input}, {output}) {}
29
30 void Log::configure() { output()->resize(input()->shape()); }
31
32 void Log::execute() const
33 {
34   switch (input()->element_type())
35   {
36     case DataType::FLOAT32:
37       evalFloat();
38       break;
39     default:
40       throw std::runtime_error("Unsupported type.");
41   }
42 }
43
44 void Log::evalFloat() const
45 {
46   const auto input_data = getTensorData<float>(input());
47   const auto input_shape = input()->shape();
48   auto output_data = getTensorData<float>(output());
49   for (int64_t i = 0; i < input_shape.num_elements(); ++i)
50   {
51     output_data[i] = std::log(input_data[i]);
52   }
53 }
54
55 } // namespace kernels
56 } // namespace luci_interpreter