xref: /aosp_15_r20/external/armnn/src/backends/cl/workloads/ClComparisonWorkload.cpp (revision 89c4ff92f2867872bb9e2354d150bf0c8c502810)
1 //
2 // Copyright © 2020 Arm Ltd and Contributors. All rights reserved.
3 // SPDX-License-Identifier: MIT
4 //
5 
6 #include "ClComparisonWorkload.hpp"
7 
8 #include "ClWorkloadUtils.hpp"
9 
10 #include <aclCommon/ArmComputeUtils.hpp>
11 #include <aclCommon/ArmComputeTensorUtils.hpp>
12 
13 #include <armnn/backends/TensorHandle.hpp>
14 
15 #include <cl/ClLayerSupport.hpp>
16 #include <cl/ClTensorHandle.hpp>
17 #include <cl/ClLayerSupport.hpp>
18 
19 namespace armnn
20 {
21 
22 using namespace armcomputetensorutils;
23 
ClComparisonWorkloadValidate(const TensorInfo & input0,const TensorInfo & input1,const TensorInfo & output,const ComparisonDescriptor & descriptor)24 arm_compute::Status ClComparisonWorkloadValidate(const TensorInfo& input0,
25                                                  const TensorInfo& input1,
26                                                  const TensorInfo& output,
27                                                  const ComparisonDescriptor& descriptor)
28 {
29     const arm_compute::TensorInfo aclInput0Info = BuildArmComputeTensorInfo(input0);
30     const arm_compute::TensorInfo aclInput1Info = BuildArmComputeTensorInfo(input1);
31     const arm_compute::TensorInfo aclOutputInfo = BuildArmComputeTensorInfo(output);
32 
33     const arm_compute::ComparisonOperation comparisonOperation = ConvertComparisonOperationToAcl(descriptor);
34 
35     const arm_compute::Status aclStatus = arm_compute::CLComparison::validate(&aclInput0Info,
36                                                                               &aclInput1Info,
37                                                                               &aclOutputInfo,
38                                                                               comparisonOperation);
39     return aclStatus;
40 }
41 
ClComparisonWorkload(const ComparisonQueueDescriptor & descriptor,const WorkloadInfo & info,const arm_compute::CLCompileContext & clCompileContext)42 ClComparisonWorkload::ClComparisonWorkload(const ComparisonQueueDescriptor& descriptor,
43                                            const WorkloadInfo& info,
44                                            const arm_compute::CLCompileContext& clCompileContext)
45     : ClBaseWorkload<ComparisonQueueDescriptor>(descriptor, info)
46 {
47     // Report Profiling Details
48     ARMNN_REPORT_PROFILING_WORKLOAD_DESC("NeonComparisonWorkload_Construct",
49                                          descriptor.m_Parameters,
50                                          info,
51                                          this->GetGuid());
52 
53     m_Data.ValidateInputsOutputs("ClComparisonWorkload", 2, 1);
54 
55     arm_compute::ICLTensor& input0 = static_cast<IClTensorHandle*>(m_Data.m_Inputs[0])->GetTensor();
56     arm_compute::ICLTensor& input1 = static_cast<IClTensorHandle*>(m_Data.m_Inputs[1])->GetTensor();
57     arm_compute::ICLTensor& output = static_cast<IClTensorHandle*>(m_Data.m_Outputs[0])->GetTensor();
58 
59     const arm_compute::ComparisonOperation comparisonOperation = ConvertComparisonOperationToAcl(m_Data.m_Parameters);
60 
61     {
62         ARMNN_SCOPED_PROFILING_EVENT(Compute::Undefined, "ClComparisonWorkload_configure");
63         m_ComparisonLayer.configure(clCompileContext, &input0, &input1, &output, comparisonOperation);
64     }
65 }
66 
Execute() const67 void ClComparisonWorkload::Execute() const
68 {
69     ARMNN_SCOPED_PROFILING_EVENT_CL_GUID("ClComparisonWorkload_Execute", this->GetGuid());
70     RunClFunction(m_ComparisonLayer, CHECK_LOCATION());
71 }
72 
73 } //namespace armnn
74