xref: /aosp_15_r20/external/armnn/src/backends/reference/workloads/RefActivationWorkload.cpp (revision 89c4ff92f2867872bb9e2354d150bf0c8c502810)
1 //
2 // Copyright © 2022 Arm Ltd and Contributors. All rights reserved.
3 // SPDX-License-Identifier: MIT
4 //
5 
6 #include "RefActivationWorkload.hpp"
7 
8 #include "Activation.hpp"
9 #include "Decoders.hpp"
10 #include "Encoders.hpp"
11 #include "RefWorkloadUtils.hpp"
12 
13 #include "Profiling.hpp"
14 
15 namespace armnn
16 {
17 
Execute() const18 void RefActivationWorkload::Execute() const
19 {
20     Execute(m_Data.m_Inputs, m_Data.m_Outputs);
21 }
22 
ExecuteAsync(ExecutionData & executionData)23 void RefActivationWorkload::ExecuteAsync(ExecutionData& executionData)
24 {
25     WorkingMemDescriptor* workingMemDescriptor = static_cast<WorkingMemDescriptor*>(executionData.m_Data);
26     Execute(workingMemDescriptor->m_Inputs, workingMemDescriptor->m_Outputs);
27 }
28 
Execute(std::vector<ITensorHandle * > inputs,std::vector<ITensorHandle * > outputs) const29 void RefActivationWorkload::Execute(std::vector<ITensorHandle*> inputs, std::vector<ITensorHandle*> outputs) const
30 {
31     ARMNN_SCOPED_PROFILING_EVENT(Compute::CpuRef, "RefActivationWorkload_Execute");
32 
33     const TensorInfo& inputInfo = GetTensorInfo(inputs[0]);
34     const TensorInfo& outputInfo = GetTensorInfo(outputs[0]);
35 
36     Activation(*MakeDecoder<float>(inputInfo, inputs[0]->Map()),
37                *MakeEncoder<float>(outputInfo, outputs[0]->Map()),
38                inputInfo,
39                m_Data.m_Parameters.m_Function,
40                m_Data.m_Parameters.m_A,
41                m_Data.m_Parameters.m_B);
42 }
43 
44 
45 } //namespace armnn
46