blob: 4bd5a51a5239f370ecb1df47b7d9f55fa7a6c737 [file] [log] [blame]
josh minor4a3c6102020-01-06 16:40:46 -06001//
Matthew Sloyan2d213a72022-06-30 17:13:04 +01002// Copyright © 2022 Arm Ltd and Contributors. All rights reserved.
josh minor4a3c6102020-01-06 16:40:46 -06003// SPDX-License-Identifier: MIT
4//
5
6#include "RefElementwiseUnaryWorkload.hpp"
7
8#include "Decoders.hpp"
9#include "ElementwiseFunction.hpp"
10#include "Encoders.hpp"
11#include "RefWorkloadUtils.hpp"
12#include "Abs.hpp"
13#include "Exp.hpp"
Teresa Charlin50de4fa2021-05-31 18:47:33 +010014#include "Log.hpp"
josh minor4a3c6102020-01-06 16:40:46 -060015#include "Rsqrt.hpp"
Teresa Charlin50de4fa2021-05-31 18:47:33 +010016#include "Sin.hpp"
josh minor4a3c6102020-01-06 16:40:46 -060017#include "Sqrt.hpp"
18
19#include <Profiling.hpp>
20
21#include <armnn/TypesUtils.hpp>
22
23#include <functional>
24
25namespace armnn
26{
27
28RefElementwiseUnaryWorkload::RefElementwiseUnaryWorkload(const ElementwiseUnaryQueueDescriptor& desc,
29 const WorkloadInfo& info)
Finn Williams73c547d2022-02-15 20:47:34 +000030 : RefBaseWorkload<ElementwiseUnaryQueueDescriptor>(desc, info)
josh minor4a3c6102020-01-06 16:40:46 -060031{}
32
Finn Williamsb8181f72021-04-07 10:23:21 +010033void RefElementwiseUnaryWorkload::Execute() const
josh minor4a3c6102020-01-06 16:40:46 -060034{
Finn Williamsb8181f72021-04-07 10:23:21 +010035 Execute(m_Data.m_Inputs, m_Data.m_Outputs);
josh minor4a3c6102020-01-06 16:40:46 -060036}
37
Matthew Sloyan2d213a72022-06-30 17:13:04 +010038void RefElementwiseUnaryWorkload::ExecuteAsync(ExecutionData& executionData)
Finn Williamsb8181f72021-04-07 10:23:21 +010039{
40
Matthew Sloyan2d213a72022-06-30 17:13:04 +010041 WorkingMemDescriptor* workingMemDescriptor = static_cast<WorkingMemDescriptor*>(executionData.m_Data);
42 Execute(workingMemDescriptor->m_Inputs, workingMemDescriptor->m_Outputs);
Finn Williamsb8181f72021-04-07 10:23:21 +010043}
44
45void RefElementwiseUnaryWorkload::Execute(std::vector<ITensorHandle*> inputs, std::vector<ITensorHandle*> outputs) const
josh minor4a3c6102020-01-06 16:40:46 -060046{
47 ARMNN_SCOPED_PROFILING_EVENT(Compute::CpuRef, "RefElementwiseUnaryWorkload_Execute");
48
Finn Williamsb8181f72021-04-07 10:23:21 +010049 const TensorInfo& inputInfo = GetTensorInfo(inputs[0]);
50 const TensorInfo& outputInfo = GetTensorInfo(outputs[0]);
josh minor4a3c6102020-01-06 16:40:46 -060051
52 const TensorShape& inShape = inputInfo.GetShape();
53 const TensorShape& outShape = outputInfo.GetShape();
54
Finn Williamsb8181f72021-04-07 10:23:21 +010055 std::unique_ptr<Decoder<InType>> input = MakeDecoder<InType>(inputInfo, inputs[0]->Map());
56 std::unique_ptr<Encoder<OutType>> output= MakeEncoder<OutType>(outputInfo, outputs[0]->Map());
josh minor4a3c6102020-01-06 16:40:46 -060057
58 using AbsFunction = ElementwiseUnaryFunction<abs<InType>>;
59 using ExpFunction = ElementwiseUnaryFunction<exp<InType>>;
Teresa Charlin50de4fa2021-05-31 18:47:33 +010060 using LogFunction = ElementwiseUnaryFunction<log<InType>>;
josh minor4a3c6102020-01-06 16:40:46 -060061 using NegFunction = ElementwiseUnaryFunction<std::negate<InType>>;
62 using RsqrtFunction = ElementwiseUnaryFunction<rsqrt<InType>>;
Teresa Charlin50de4fa2021-05-31 18:47:33 +010063 using SinFunction = ElementwiseUnaryFunction<sin<InType>>;
josh minor4a3c6102020-01-06 16:40:46 -060064 using SqrtFunction = ElementwiseUnaryFunction<sqrt<InType>>;
65
66 switch (m_Data.m_Parameters.m_Operation)
67 {
68 case UnaryOperation::Abs:
69 {
Finn Williamsb8181f72021-04-07 10:23:21 +010070 AbsFunction(inShape, outShape, *input, *output);
josh minor4a3c6102020-01-06 16:40:46 -060071 break;
72 }
73 case UnaryOperation::Exp:
74 {
Finn Williamsb8181f72021-04-07 10:23:21 +010075 ExpFunction(inShape, outShape, *input, *output);
josh minor4a3c6102020-01-06 16:40:46 -060076 break;
77 }
Teresa Charlin50de4fa2021-05-31 18:47:33 +010078 case UnaryOperation::Log:
79 {
80 LogFunction(inShape, outShape, *input, *output);
81 break;
82 }
josh minor4a3c6102020-01-06 16:40:46 -060083 case UnaryOperation::Neg:
84 {
Finn Williamsb8181f72021-04-07 10:23:21 +010085 NegFunction(inShape, outShape, *input, *output);
josh minor4a3c6102020-01-06 16:40:46 -060086 break;
87 }
88 case UnaryOperation::Rsqrt:
89 {
Finn Williamsb8181f72021-04-07 10:23:21 +010090 RsqrtFunction(inShape, outShape, *input, *output);
josh minor4a3c6102020-01-06 16:40:46 -060091 break;
92 }
Teresa Charlin50de4fa2021-05-31 18:47:33 +010093 case UnaryOperation::Sin:
94 {
95 SinFunction(inShape, outShape, *input, *output);
96 break;
97 }
josh minor4a3c6102020-01-06 16:40:46 -060098 case UnaryOperation::Sqrt:
99 {
Finn Williamsb8181f72021-04-07 10:23:21 +0100100 SqrtFunction(inShape, outShape, *input, *output);
josh minor4a3c6102020-01-06 16:40:46 -0600101 break;
102 }
103 default:
104 {
105 throw InvalidArgumentException(std::string("Unsupported unary operation ") +
106 GetUnaryOperationAsCString(m_Data.m_Parameters.m_Operation), CHECK_LOCATION());
107 }
108 }
109}
110
111} // namespace armnn