blob: eb9d393fda83608ecec109acacad5544e990be7b [file] [log] [blame]
James Conroyd47a0642019-09-17 14:22:06 +01001//
Mike Kelly7cbe7812023-07-25 17:37:33 +01002// Copyright © 2019-2023 Arm Ltd and Contributors. All rights reserved.
James Conroyd47a0642019-09-17 14:22:06 +01003// SPDX-License-Identifier: MIT
4//
5
6#include "NeonArgMinMaxWorkload.hpp"
7#include "NeonWorkloadUtils.hpp"
8
9#include <aclCommon/ArmComputeTensorUtils.hpp>
Matteo Martincighe011d202019-11-28 11:35:47 +000010
Colm Donelan0c479742021-12-10 12:43:54 +000011#include <armnn/backends/TensorHandle.hpp>
Matteo Martincighe011d202019-11-28 11:35:47 +000012
Matthew Sloyan171214c2020-09-09 09:07:37 +010013#include <armnn/utility/NumericCast.hpp>
Jan Eilersbb446e52020-04-02 13:56:54 +010014#include <armnn/utility/PolymorphicDowncast.hpp>
Matteo Martincighe011d202019-11-28 11:35:47 +000015#include <armnnUtils/TensorUtils.hpp>
James Conroyd47a0642019-09-17 14:22:06 +010016
17#include <arm_compute/runtime/NEON/functions/NEArgMinMaxLayer.h>
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 NeonArgMinMaxWorkloadValidate(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 Conroyd47a0642019-09-17 14:22:06 +010041
42 if (descriptor.m_Function == ArgMinMaxFunction::Max)
43 {
44 return arm_compute::NEArgMinMaxLayer::validate(&aclInput, aclAxis, &aclOutput,
45 arm_compute::ReductionOperation::ARG_IDX_MAX);
46 }
47 else
48 {
49 return arm_compute::NEArgMinMaxLayer::validate(&aclInput, aclAxis, &aclOutput,
50 arm_compute::ReductionOperation::ARG_IDX_MIN);
51 }
52}
53
54
55NeonArgMinMaxWorkload::NeonArgMinMaxWorkload(const ArgMinMaxQueueDescriptor& descriptor,
56 const WorkloadInfo& info)
Teresa Charlin588cbdf2022-01-19 15:55:37 +000057 : NeonBaseWorkload<ArgMinMaxQueueDescriptor>(descriptor, info)
James Conroyd47a0642019-09-17 14:22:06 +010058{
Keith Davis2d0679f2021-08-05 11:35:00 +010059 // Report Profiling Details
60 ARMNN_REPORT_PROFILING_WORKLOAD_DESC("NeonArgMinMaxWorkload_Construct",
61 descriptor.m_Parameters,
62 info,
63 this->GetGuid());
64
Jan Eilersbb446e52020-04-02 13:56:54 +010065 arm_compute::ITensor& input = PolymorphicDowncast<IAclTensorHandle*>(m_Data.m_Inputs[0])->GetTensor();
66 arm_compute::ITensor& output = PolymorphicDowncast<IAclTensorHandle*>(m_Data.m_Outputs[0])->GetTensor();
James Conroyd47a0642019-09-17 14:22:06 +010067
68 auto numDims = info.m_InputTensorInfos[0].GetNumDimensions();
69 auto unsignedAxis = armnnUtils::GetUnsignedAxis(numDims, m_Data.m_Parameters.m_Axis);
Matthew Sloyan171214c2020-09-09 09:07:37 +010070 int aclAxis = armnn::numeric_cast<int>(CalcAclAxis(numDims, unsignedAxis));
James Conroyd47a0642019-09-17 14:22:06 +010071
James Conroy663c1842019-11-01 15:21:48 +000072 auto layer = std::make_unique<arm_compute::NEArgMinMaxLayer>();
73
James Conroyd47a0642019-09-17 14:22:06 +010074 if (m_Data.m_Parameters.m_Function == ArgMinMaxFunction::Max)
75 {
James Conroy663c1842019-11-01 15:21:48 +000076 layer->configure(&input, aclAxis, &output, arm_compute::ReductionOperation::ARG_IDX_MAX);
James Conroyd47a0642019-09-17 14:22:06 +010077 }
78 else
79 {
James Conroy663c1842019-11-01 15:21:48 +000080 layer->configure(&input, aclAxis, &output, arm_compute::ReductionOperation::ARG_IDX_MIN);
James Conroyd47a0642019-09-17 14:22:06 +010081 }
James Conroy663c1842019-11-01 15:21:48 +000082
83 m_ArgMinMaxLayer.reset(layer.release());
James Conroyd47a0642019-09-17 14:22:06 +010084}
85
86void NeonArgMinMaxWorkload::Execute() const
87{
Mike Kelly7cbe7812023-07-25 17:37:33 +010088 ARMNN_SCOPED_PROFILING_EVENT_NEON_NAME_GUID("NeonArgMinMaxWorkload_Execute");
James Conroy663c1842019-11-01 15:21:48 +000089 m_ArgMinMaxLayer->run();
James Conroyd47a0642019-09-17 14:22:06 +010090}
91
92} //namespace armnn
93