xref: /aosp_15_r20/external/armnn/src/backends/neon/workloads/NeonActivationWorkload.cpp (revision 89c4ff92f2867872bb9e2354d150bf0c8c502810)
1 //
2 // Copyright © 2017 Arm Ltd and Contributors. All rights reserved.
3 // SPDX-License-Identifier: MIT
4 //
5 
6 #include "NeonActivationWorkload.hpp"
7 #include "NeonWorkloadUtils.hpp"
8 
9 #include <aclCommon/ArmComputeUtils.hpp>
10 #include <armnn/utility/PolymorphicDowncast.hpp>
11 
12 #include <arm_compute/runtime/NEON/functions/NEActivationLayer.h>
13 
14 namespace armnn
15 {
16 
NeonActivationWorkloadValidate(const TensorInfo & input,const TensorInfo & output,const ActivationDescriptor & descriptor)17 arm_compute::Status NeonActivationWorkloadValidate(const TensorInfo& input,
18                                                    const TensorInfo& output,
19                                                    const ActivationDescriptor& descriptor)
20 {
21     const arm_compute::TensorInfo aclInput = armcomputetensorutils::BuildArmComputeTensorInfo(input);
22     const arm_compute::TensorInfo aclOutput = armcomputetensorutils::BuildArmComputeTensorInfo(output);
23 
24     const arm_compute::ActivationLayerInfo activationLayerInfo =
25         ConvertActivationDescriptorToAclActivationLayerInfo(descriptor);
26 
27     return arm_compute::NEActivationLayer::validate(&aclInput,
28                                                     &aclOutput,
29                                                     activationLayerInfo);
30 }
31 
NeonActivationWorkload(const ActivationQueueDescriptor & descriptor,const WorkloadInfo & info)32 NeonActivationWorkload::NeonActivationWorkload(const ActivationQueueDescriptor& descriptor,
33                                                const WorkloadInfo& info)
34     : NeonBaseWorkload<ActivationQueueDescriptor>(descriptor, info)
35 {
36     // Report Profiling Details
37     ARMNN_REPORT_PROFILING_WORKLOAD_DESC("NeonActivationWorkload_Construct",
38                                          descriptor.m_Parameters,
39                                          info,
40                                          this->GetGuid());
41 
42     m_Data.ValidateInputsOutputs("NeonActivationWorkload", 1, 1);
43 
44     const arm_compute::ActivationLayerInfo activationLayerInfo =
45         ConvertActivationDescriptorToAclActivationLayerInfo(m_Data.m_Parameters);
46 
47     arm_compute::ITensor& input = PolymorphicDowncast<IAclTensorHandle*>(m_Data.m_Inputs[0])->GetTensor();
48     arm_compute::ITensor& output = PolymorphicDowncast<IAclTensorHandle*>(m_Data.m_Outputs[0])->GetTensor();
49 
50     auto layer = std::make_unique<arm_compute::NEActivationLayer>();
51     layer->configure(&input, &output, activationLayerInfo);
52 
53     m_ActivationLayer.reset(layer.release());
54 }
55 
Execute() const56 void NeonActivationWorkload::Execute() const
57 {
58     ARMNN_SCOPED_PROFILING_EVENT_NEON_GUID("NeonActivationWorkload_Execute", this->GetGuid());
59     m_ActivationLayer->run();
60 }
61 
62 } //namespace armnn
63