blob: c2ae8773c6305881d15d4c09df064a1bbff5303c [file] [log] [blame]
Sang-Hoon Park63001ac2021-01-18 14:20:27 +00001/*
2 * Copyright (c) 2021 Arm Limited.
3 *
4 * SPDX-License-Identifier: MIT
5 *
6 * Permission is hereby granted, free of charge, to any person obtaining a copy
7 * of this software and associated documentation files (the "Software"), to
8 * deal in the Software without restriction, including without limitation the
9 * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
10 * sell copies of the Software, and to permit persons to whom the Software is
11 * furnished to do so, subject to the following conditions:
12 *
13 * The above copyright notice and this permission notice shall be included in all
14 * copies or substantial portions of the Software.
15 *
16 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
19 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
21 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
22 * SOFTWARE.
23 */
Georgios Pinitas7891a732021-08-20 21:39:25 +010024#include "src/cpu/operators/CpuElementwise.h"
Felix Thomasmathibalanafd38f02023-09-27 17:46:17 +010025
ramelg013ae3d882021-09-12 23:07:47 +010026#include "src/common/utils/Log.h"
Sang-Hoon Park668ccdc2021-02-03 10:32:59 +000027#include "src/core/helpers/WindowHelpers.h"
Georgios Pinitas7891a732021-08-20 21:39:25 +010028#include "src/cpu/kernels/CpuElementwiseKernel.h"
Sang-Hoon Park63001ac2021-01-18 14:20:27 +000029
30namespace arm_compute
31{
32namespace cpu
33{
Sang-Hoon Park668ccdc2021-02-03 10:32:59 +000034void CpuElementwiseBase::run(ITensorPack &tensors)
35{
36 // If the kernel has been configured, use the window from the kernel.
Felix Thomasmathibalanafd38f02023-09-27 17:46:17 +010037 if (_kernel->is_window_configured())
Sang-Hoon Park668ccdc2021-02-03 10:32:59 +000038 {
39 ICpuOperator::run(tensors);
40 return;
41 }
42
43 auto src0_info = tensors.get_const_tensor(TensorType::ACL_SRC_0)->info();
44 auto src1_info = tensors.get_const_tensor(TensorType::ACL_SRC_1)->info();
Sang-Hoon Parkd0b7b4b2021-03-09 10:47:30 +000045 auto shape_and_window = compute_output_shape_and_window(src0_info->tensor_shape(), src1_info->tensor_shape());
Sang-Hoon Park668ccdc2021-02-03 10:32:59 +000046 ICpuOperator::run(tensors, shape_and_window.second);
47}
48
Sang-Hoon Park6b0bf992021-02-17 13:12:53 +000049template <ArithmeticOperation op>
50void CpuElementwiseArithmetic<op>::configure(const ITensorInfo *src0, const ITensorInfo *src1, ITensorInfo *dst)
Sang-Hoon Park63001ac2021-01-18 14:20:27 +000051{
ramelg013ae3d882021-09-12 23:07:47 +010052 ARM_COMPUTE_LOG_PARAMS(src0, src1, dst);
Sang-Hoon Park63001ac2021-01-18 14:20:27 +000053 auto k = std::make_unique<kernels::CpuArithmeticKernel>();
Sang-Hoon Park6b0bf992021-02-17 13:12:53 +000054 k->configure(op, src0, src1, dst);
Sang-Hoon Park63001ac2021-01-18 14:20:27 +000055 _kernel = std::move(k);
56}
57
Sang-Hoon Park6b0bf992021-02-17 13:12:53 +000058template <ArithmeticOperation op>
59Status CpuElementwiseArithmetic<op>::validate(const ITensorInfo *src0, const ITensorInfo *src1, const ITensorInfo *dst)
Sang-Hoon Park63001ac2021-01-18 14:20:27 +000060{
Sang-Hoon Park6b0bf992021-02-17 13:12:53 +000061 return kernels::CpuArithmeticKernel::validate(op, src0, src1, dst);
Sang-Hoon Park63001ac2021-01-18 14:20:27 +000062}
63
Sang-Hoon Park6b0bf992021-02-17 13:12:53 +000064template class CpuElementwiseArithmetic<ArithmeticOperation::MAX>;
65template class CpuElementwiseArithmetic<ArithmeticOperation::MIN>;
66template class CpuElementwiseArithmetic<ArithmeticOperation::SQUARED_DIFF>;
67template class CpuElementwiseArithmetic<ArithmeticOperation::PRELU>;
Sang-Hoon Park63001ac2021-01-18 14:20:27 +000068
Sang-Hoon Park668ccdc2021-02-03 10:32:59 +000069void CpuElementwiseDivision::configure(const ITensorInfo *src0, const ITensorInfo *src1, ITensorInfo *dst)
Sang-Hoon Park63001ac2021-01-18 14:20:27 +000070{
ramelg013ae3d882021-09-12 23:07:47 +010071 ARM_COMPUTE_LOG_PARAMS(src0, src1, dst);
Sang-Hoon Park63001ac2021-01-18 14:20:27 +000072 auto k = std::make_unique<kernels::CpuDivisionKernel>();
Sang-Hoon Park668ccdc2021-02-03 10:32:59 +000073 k->configure(src0, src1, dst);
Sang-Hoon Park63001ac2021-01-18 14:20:27 +000074 _kernel = std::move(k);
75}
76
Sang-Hoon Park668ccdc2021-02-03 10:32:59 +000077Status CpuElementwiseDivision::validate(const ITensorInfo *src0, const ITensorInfo *src1, const ITensorInfo *dst)
Sang-Hoon Park63001ac2021-01-18 14:20:27 +000078{
Sang-Hoon Park668ccdc2021-02-03 10:32:59 +000079 return kernels::CpuDivisionKernel::validate(src0, src1, dst);
Sang-Hoon Park63001ac2021-01-18 14:20:27 +000080}
81
Sang-Hoon Park668ccdc2021-02-03 10:32:59 +000082void CpuElementwisePower::configure(const ITensorInfo *src0, const ITensorInfo *src1, ITensorInfo *dst)
Sang-Hoon Park63001ac2021-01-18 14:20:27 +000083{
ramelg013ae3d882021-09-12 23:07:47 +010084 ARM_COMPUTE_LOG_PARAMS(src0, src1, dst);
Sang-Hoon Park63001ac2021-01-18 14:20:27 +000085 auto k = std::make_unique<kernels::CpuPowerKernel>();
Sang-Hoon Park668ccdc2021-02-03 10:32:59 +000086 k->configure(src0, src1, dst);
Sang-Hoon Park63001ac2021-01-18 14:20:27 +000087 _kernel = std::move(k);
88}
89
Sang-Hoon Park668ccdc2021-02-03 10:32:59 +000090Status CpuElementwisePower::validate(const ITensorInfo *src0, const ITensorInfo *src1, const ITensorInfo *dst)
Sang-Hoon Park63001ac2021-01-18 14:20:27 +000091{
Sang-Hoon Park668ccdc2021-02-03 10:32:59 +000092 return kernels::CpuPowerKernel::validate(src0, src1, dst);
Sang-Hoon Park63001ac2021-01-18 14:20:27 +000093}
94
95template <ComparisonOperation COP>
Sang-Hoon Park668ccdc2021-02-03 10:32:59 +000096void CpuElementwiseComparisonStatic<COP>::configure(const ITensorInfo *src0, const ITensorInfo *src1, ITensorInfo *dst)
Sang-Hoon Park63001ac2021-01-18 14:20:27 +000097{
ramelg013ae3d882021-09-12 23:07:47 +010098 ARM_COMPUTE_LOG_PARAMS(src0, src1, dst);
Sang-Hoon Park63001ac2021-01-18 14:20:27 +000099 auto k = std::make_unique<kernels::CpuComparisonKernel>();
Sang-Hoon Park668ccdc2021-02-03 10:32:59 +0000100 k->configure(COP, src0, src1, dst);
Sang-Hoon Park63001ac2021-01-18 14:20:27 +0000101 _kernel = std::move(k);
102}
103
104template <ComparisonOperation COP>
Felix Thomasmathibalanafd38f02023-09-27 17:46:17 +0100105Status
106CpuElementwiseComparisonStatic<COP>::validate(const ITensorInfo *src0, const ITensorInfo *src1, const ITensorInfo *dst)
Sang-Hoon Park63001ac2021-01-18 14:20:27 +0000107{
Sang-Hoon Park668ccdc2021-02-03 10:32:59 +0000108 return kernels::CpuComparisonKernel::validate(COP, src0, src1, dst);
Sang-Hoon Park63001ac2021-01-18 14:20:27 +0000109}
110
Felix Thomasmathibalanafd38f02023-09-27 17:46:17 +0100111void CpuElementwiseComparison::configure(const ITensorInfo *src0,
112 const ITensorInfo *src1,
113 ITensorInfo *dst,
114 ComparisonOperation op)
Sang-Hoon Park63001ac2021-01-18 14:20:27 +0000115{
ramelg013ae3d882021-09-12 23:07:47 +0100116 ARM_COMPUTE_LOG_PARAMS(src0, src1, dst);
Sang-Hoon Park63001ac2021-01-18 14:20:27 +0000117 auto k = std::make_unique<kernels::CpuComparisonKernel>();
Sang-Hoon Park668ccdc2021-02-03 10:32:59 +0000118 k->configure(op, src0, src1, dst);
Sang-Hoon Park63001ac2021-01-18 14:20:27 +0000119 _kernel = std::move(k);
120}
121
Felix Thomasmathibalanafd38f02023-09-27 17:46:17 +0100122Status CpuElementwiseComparison::validate(const ITensorInfo *src0,
123 const ITensorInfo *src1,
124 const ITensorInfo *dst,
125 ComparisonOperation op)
Sang-Hoon Park63001ac2021-01-18 14:20:27 +0000126{
Sang-Hoon Park668ccdc2021-02-03 10:32:59 +0000127 return kernels::CpuComparisonKernel::validate(op, src0, src1, dst);
Sang-Hoon Park63001ac2021-01-18 14:20:27 +0000128}
129
130// Supported Specializations
131template class CpuElementwiseComparisonStatic<ComparisonOperation::Equal>;
132template class CpuElementwiseComparisonStatic<ComparisonOperation::NotEqual>;
133template class CpuElementwiseComparisonStatic<ComparisonOperation::Greater>;
134template class CpuElementwiseComparisonStatic<ComparisonOperation::GreaterEqual>;
135template class CpuElementwiseComparisonStatic<ComparisonOperation::Less>;
136template class CpuElementwiseComparisonStatic<ComparisonOperation::LessEqual>;
137} // namespace cpu
Felix Thomasmathibalanafd38f02023-09-27 17:46:17 +0100138} // namespace arm_compute