blob: 4305b255c0f9e223df504c883f82e09e5cd2e5cb [file] [log] [blame]
James Conroy2dc05722019-09-19 17:00:31 +01001//
Teresa Charlin588cbdf2022-01-19 15:55:37 +00002// Copyright © 2019 Arm Ltd and Contributors. All rights reserved.
James Conroy2dc05722019-09-19 17:00:31 +01003// SPDX-License-Identifier: MIT
4//
5
6#include "ClArgMinMaxWorkload.hpp"
7#include "ClWorkloadUtils.hpp"
8
9#include <aclCommon/ArmComputeTensorUtils.hpp>
10
Colm Donelan0c479742021-12-10 12:43:54 +000011#include <armnn/backends/TensorHandle.hpp>
James Conroy2dc05722019-09-19 17:00:31 +010012
Matteo Martincighe011d202019-11-28 11:35:47 +000013#include <armnnUtils/TensorUtils.hpp>
Matthew Sloyan171214c2020-09-09 09:07:37 +010014#include <armnn/utility/NumericCast.hpp>
James Conroy2dc05722019-09-19 17:00:31 +010015
16#include <cl/ClTensorHandle.hpp>
17#include <cl/ClLayerSupport.hpp>
18
19namespace
20{
21unsigned int CalcAclAxis(unsigned int numDimensions, unsigned int axisIndex)
22{
23 return (numDimensions - axisIndex) - 1;
24}
25
26} //namespace
27
28namespace armnn
29{
30
31arm_compute::Status ClArgMinMaxWorkloadValidate(const TensorInfo& input,
32 const TensorInfo& output,
33 const ArgMinMaxDescriptor& descriptor)
34{
35 const arm_compute::TensorInfo aclInput = armcomputetensorutils::BuildArmComputeTensorInfo(input);
36 const arm_compute::TensorInfo aclOutput = armcomputetensorutils::BuildArmComputeTensorInfo(output);
37
38 auto numDims = input.GetNumDimensions();
39 auto unsignedAxis = armnnUtils::GetUnsignedAxis(numDims, descriptor.m_Axis);
Matthew Sloyan171214c2020-09-09 09:07:37 +010040 int aclAxis = armnn::numeric_cast<int>(CalcAclAxis(numDims, unsignedAxis));
James Conroy2dc05722019-09-19 17:00:31 +010041
42 if (descriptor.m_Function == ArgMinMaxFunction::Max)
43 {
44 return arm_compute::CLArgMinMaxLayer::validate(&aclInput, aclAxis, &aclOutput,
45 arm_compute::ReductionOperation::ARG_IDX_MAX);
46 }
47 else
48 {
49 return arm_compute::CLArgMinMaxLayer::validate(&aclInput, aclAxis, &aclOutput,
50 arm_compute::ReductionOperation::ARG_IDX_MIN);
51 }
52}
53
54
55ClArgMinMaxWorkload::ClArgMinMaxWorkload(const ArgMinMaxQueueDescriptor& descriptor,
Sadik Armagane9444752020-12-02 11:28:58 +000056 const WorkloadInfo& info,
57 const arm_compute::CLCompileContext& clCompileContext)
Teresa Charlin588cbdf2022-01-19 15:55:37 +000058 : ClBaseWorkload<ArgMinMaxQueueDescriptor>(descriptor, info)
James Conroy2dc05722019-09-19 17:00:31 +010059{
Keith Davisbcd860a2021-08-05 14:20:33 +010060 // Report Profiling Details
61 ARMNN_REPORT_PROFILING_WORKLOAD_DESC("ClArgMinMaxWorkload_Construct",
62 descriptor.m_Parameters,
63 info,
64 this->GetGuid());
65
James Conroy2dc05722019-09-19 17:00:31 +010066 arm_compute::ICLTensor& input = static_cast<IClTensorHandle*>(this->m_Data.m_Inputs[0])->GetTensor();
67 arm_compute::ICLTensor& output = static_cast<IClTensorHandle*>(this->m_Data.m_Outputs[0])->GetTensor();
68
69 auto numDims = info.m_InputTensorInfos[0].GetNumDimensions();
70 auto unsignedAxis = armnnUtils::GetUnsignedAxis(numDims, m_Data.m_Parameters.m_Axis);
Matthew Sloyan171214c2020-09-09 09:07:37 +010071 int aclAxis = armnn::numeric_cast<int>(CalcAclAxis(numDims, unsignedAxis));
James Conroy2dc05722019-09-19 17:00:31 +010072
James Conroy2dc05722019-09-19 17:00:31 +010073 {
Kevin May9f6862d2021-10-22 15:42:28 +010074 ARMNN_SCOPED_PROFILING_EVENT(Compute::Undefined, "ClArgMinMaxWorkload_configure");
75 if (m_Data.m_Parameters.m_Function == ArgMinMaxFunction::Max)
76 {
77 m_ArgMinMaxLayer.configure(&input, aclAxis, &output, arm_compute::ReductionOperation::ARG_IDX_MAX);
78 }
79 else
80 {
81 m_ArgMinMaxLayer.configure(clCompileContext,
82 &input,
83 aclAxis,
84 &output,
85 arm_compute::ReductionOperation::ARG_IDX_MIN);
86 }
James Conroy2dc05722019-09-19 17:00:31 +010087 }
88}
89
90void ClArgMinMaxWorkload::Execute() const
91{
Keith Davisbcd860a2021-08-05 14:20:33 +010092 ARMNN_SCOPED_PROFILING_EVENT_CL_GUID("ClArgMinMaxWorkload_Execute", this->GetGuid());
James Conroy2dc05722019-09-19 17:00:31 +010093 RunClFunction(m_ArgMinMaxLayer, CHECK_LOCATION());
94}
95
96} //namespace armnn
97