ArmNN
 20.11
NeonArgMinMaxWorkload Class Reference

#include <NeonArgMinMaxWorkload.hpp>

Inheritance diagram for NeonArgMinMaxWorkload:
BaseWorkload< ArgMinMaxQueueDescriptor > IWorkload

Public Member Functions

 NeonArgMinMaxWorkload (const ArgMinMaxQueueDescriptor &descriptor, const WorkloadInfo &info)
 
virtual void Execute () const override
 
- Public Member Functions inherited from BaseWorkload< ArgMinMaxQueueDescriptor >
 BaseWorkload (const ArgMinMaxQueueDescriptor &descriptor, const WorkloadInfo &info)
 
void PostAllocationConfigure () override
 
const ArgMinMaxQueueDescriptorGetData () const
 
profiling::ProfilingGuid GetGuid () const final
 
- Public Member Functions inherited from IWorkload
virtual ~IWorkload ()
 
virtual void RegisterDebugCallback (const DebugCallbackFunction &)
 

Additional Inherited Members

- Protected Attributes inherited from BaseWorkload< ArgMinMaxQueueDescriptor >
const ArgMinMaxQueueDescriptor m_Data
 
const profiling::ProfilingGuid m_Guid
 

Detailed Description

Definition at line 20 of file NeonArgMinMaxWorkload.hpp.

Constructor & Destructor Documentation

◆ NeonArgMinMaxWorkload()

NeonArgMinMaxWorkload ( const ArgMinMaxQueueDescriptor descriptor,
const WorkloadInfo info 
)

Definition at line 55 of file NeonArgMinMaxWorkload.cpp.

References armnnUtils::GetUnsignedAxis(), ArgMinMaxDescriptor::m_Axis, BaseWorkload< ArgMinMaxQueueDescriptor >::m_Data, ArgMinMaxDescriptor::m_Function, QueueDescriptor::m_Inputs, WorkloadInfo::m_InputTensorInfos, QueueDescriptor::m_Outputs, QueueDescriptorWithParameters< LayerDescriptor >::m_Parameters, armnn::Max, and armnn::numeric_cast().

57  : BaseWorkload<ArgMinMaxQueueDescriptor>(descriptor, info)
58 {
59  arm_compute::ITensor& input = PolymorphicDowncast<IAclTensorHandle*>(m_Data.m_Inputs[0])->GetTensor();
60  arm_compute::ITensor& output = PolymorphicDowncast<IAclTensorHandle*>(m_Data.m_Outputs[0])->GetTensor();
61 
62  auto numDims = info.m_InputTensorInfos[0].GetNumDimensions();
63  auto unsignedAxis = armnnUtils::GetUnsignedAxis(numDims, m_Data.m_Parameters.m_Axis);
64  int aclAxis = armnn::numeric_cast<int>(CalcAclAxis(numDims, unsignedAxis));
65 
66  auto layer = std::make_unique<arm_compute::NEArgMinMaxLayer>();
67 
69  {
70  layer->configure(&input, aclAxis, &output, arm_compute::ReductionOperation::ARG_IDX_MAX);
71  }
72  else
73  {
74  layer->configure(&input, aclAxis, &output, arm_compute::ReductionOperation::ARG_IDX_MIN);
75  }
76 
77  m_ArgMinMaxLayer.reset(layer.release());
78 }
const ArgMinMaxQueueDescriptor m_Data
Definition: Workload.hpp:46
ArgMinMaxFunction m_Function
Specify if the function is to find Min or Max.
Definition: Descriptors.hpp:65
unsigned int GetUnsignedAxis(const unsigned int inputDimension, const int axis)
std::vector< ITensorHandle * > m_Outputs
std::enable_if_t< std::is_unsigned< Source >::value &&std::is_unsigned< Dest >::value, Dest > numeric_cast(Source source)
Definition: NumericCast.hpp:35
int m_Axis
Axis to reduce across the input tensor.
Definition: Descriptors.hpp:67
std::vector< ITensorHandle * > m_Inputs

Member Function Documentation

◆ Execute()

void Execute ( ) const
overridevirtual

Implements IWorkload.

Definition at line 80 of file NeonArgMinMaxWorkload.cpp.

References ARMNN_SCOPED_PROFILING_EVENT_NEON.

81 {
82  ARMNN_SCOPED_PROFILING_EVENT_NEON("NeonArgMinMaxWorkload_Execute");
83  m_ArgMinMaxLayer->run();
84 }
#define ARMNN_SCOPED_PROFILING_EVENT_NEON(name)

The documentation for this class was generated from the following files: