ArmNN
 20.02
ClPooling2dWorkload Class Reference

#include <ClPooling2dWorkload.hpp>

Inheritance diagram for ClPooling2dWorkload:
BaseWorkload< Pooling2dQueueDescriptor > IWorkload

Public Member Functions

 ClPooling2dWorkload (const Pooling2dQueueDescriptor &descriptor, const WorkloadInfo &info)
 
void Execute () const override
 
- Public Member Functions inherited from BaseWorkload< Pooling2dQueueDescriptor >
 BaseWorkload (const Pooling2dQueueDescriptor &descriptor, const WorkloadInfo &info)
 
void PostAllocationConfigure () override
 
const Pooling2dQueueDescriptorGetData () 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< Pooling2dQueueDescriptor >
const Pooling2dQueueDescriptor m_Data
 
const profiling::ProfilingGuid m_Guid
 

Detailed Description

Definition at line 19 of file ClPooling2dWorkload.hpp.

Constructor & Destructor Documentation

◆ ClPooling2dWorkload()

ClPooling2dWorkload ( const Pooling2dQueueDescriptor descriptor,
const WorkloadInfo info 
)

Definition at line 30 of file ClPooling2dWorkload.cpp.

References BaseWorkload< Pooling2dQueueDescriptor >::m_Data, QueueDescriptor::m_Inputs, QueueDescriptor::m_Outputs, and QueueDescriptor::ValidateInputsOutputs().

32  : BaseWorkload<Pooling2dQueueDescriptor>(descriptor, info)
33 {
34  m_Data.ValidateInputsOutputs("ClPooling2dWorkload", 1, 1);
35 
36  arm_compute::ICLTensor& input = static_cast<IClTensorHandle*>(m_Data.m_Inputs[0])->GetTensor();
37  arm_compute::ICLTensor& output = static_cast<IClTensorHandle*>(m_Data.m_Outputs[0])->GetTensor();
38 
39  arm_compute::DataLayout aclDataLayout = ConvertDataLayout(m_Data.m_Parameters.m_DataLayout);
40  input.info()->set_data_layout(aclDataLayout);
41  output.info()->set_data_layout(aclDataLayout);
42 
43  // flag to use wider accumulators (32 bit instead of 16 for FP16) to improve accuracy
44  // enable fp_mixed_precision for the the FP16 cases that
45  // accumulation reaches a limit beyond which there is no more increment of the value
46  bool fpMixedPrecision = false;
47 
48  arm_compute::PoolingLayerInfo layerInfo = BuildArmComputePoolingLayerInfo(m_Data.m_Parameters, fpMixedPrecision);
49 
50  // Run the layer.
51  m_PoolingLayer.configure(&input, &output, layerInfo);
52 }
DataLayout
Definition: Types.hpp:49
const Pooling2dQueueDescriptor m_Data
Definition: Workload.hpp:46
void ValidateInputsOutputs(const std::string &descName, unsigned int numExpectedIn, unsigned int numExpectedOut) const
DataLayout m_DataLayout
The data layout to be used (NCHW, NHWC).
std::vector< ITensorHandle * > m_Outputs
std::vector< ITensorHandle * > m_Inputs

Member Function Documentation

◆ Execute()

void Execute ( ) const
overridevirtual

Implements IWorkload.

Definition at line 54 of file ClPooling2dWorkload.cpp.

References ARMNN_SCOPED_PROFILING_EVENT_CL, CHECK_LOCATION, and armnn::RunClFunction().

55 {
56  ARMNN_SCOPED_PROFILING_EVENT_CL("ClPooling2dWorkload_Execute");
57  RunClFunction(m_PoolingLayer, CHECK_LOCATION());
58 }
#define ARMNN_SCOPED_PROFILING_EVENT_CL(name)
void RunClFunction(arm_compute::IFunction &function, const CheckLocation &location)
#define CHECK_LOCATION()
Definition: Exceptions.hpp:192

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