ArmNN
 20.11
ClMultiplicationWorkload Class Reference

#include <ClMultiplicationWorkload.hpp>

Inheritance diagram for ClMultiplicationWorkload:
BaseWorkload< MultiplicationQueueDescriptor > IWorkload

Public Member Functions

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

Detailed Description

Definition at line 20 of file ClMultiplicationWorkload.hpp.

Constructor & Destructor Documentation

◆ ClMultiplicationWorkload()

ClMultiplicationWorkload ( const MultiplicationQueueDescriptor descriptor,
const WorkloadInfo info 
)

Definition at line 47 of file ClMultiplicationWorkload.cpp.

References armnn::ConvertAdditionalInfoToAclActivationLayerInfo(), armnn::IsQuantizedType(), BaseWorkload< MultiplicationQueueDescriptor >::m_Data, QueueDescriptor::m_Inputs, WorkloadInfo::m_InputTensorInfos, QueueDescriptor::m_Outputs, and QueueDescriptor::ValidateInputsOutputs().

49  : BaseWorkload<MultiplicationQueueDescriptor>(descriptor, info)
50 {
51  m_Data.ValidateInputsOutputs("ClMultiplicationWorkload", 2, 1);
52 
53  arm_compute::ICLTensor& input0 = static_cast<IClTensorHandle*>(m_Data.m_Inputs[0])->GetTensor();
54  arm_compute::ICLTensor& input1 = static_cast<IClTensorHandle*>(m_Data.m_Inputs[1])->GetTensor();
55  arm_compute::ICLTensor& output = static_cast<IClTensorHandle*>(m_Data.m_Outputs[0])->GetTensor();
56 
57  auto convertPolicy = (IsQuantizedType(info.m_InputTensorInfos[0].GetDataType()) ||
58  IsQuantizedType(info.m_InputTensorInfos[1].GetDataType())) ?
59  arm_compute::ConvertPolicy::SATURATE :
60  arm_compute::ConvertPolicy::WRAP;
61 
62  const arm_compute::ActivationLayerInfo activationInfo = ConvertAdditionalInfoToAclActivationLayerInfo(descriptor);
63 
64  // Construct
65  m_PixelWiseMultiplication.configure(&input0,
66  &input1,
67  &output,
68  1.0f,
69  convertPolicy,
70  arm_compute::RoundingPolicy::TO_NEAREST_EVEN,
71  activationInfo);
72 }
constexpr bool IsQuantizedType()
Definition: TypesUtils.hpp:249
const MultiplicationQueueDescriptor m_Data
Definition: Workload.hpp:46
arm_compute::ActivationLayerInfo ConvertAdditionalInfoToAclActivationLayerInfo(const QueueDescriptor &queueDescriptor)
void ValidateInputsOutputs(const std::string &descName, unsigned int numExpectedIn, unsigned int numExpectedOut) const
std::vector< ITensorHandle * > m_Outputs
std::vector< ITensorHandle * > m_Inputs

Member Function Documentation

◆ Execute()

void Execute ( ) const
overridevirtual

Implements IWorkload.

Definition at line 74 of file ClMultiplicationWorkload.cpp.

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

75 {
76  ARMNN_SCOPED_PROFILING_EVENT_CL("ClMultiplicationWorkload_Execute");
77  RunClFunction(m_PixelWiseMultiplication, CHECK_LOCATION());
78 }
#define ARMNN_SCOPED_PROFILING_EVENT_CL(name)
void RunClFunction(arm_compute::IFunction &function, const CheckLocation &location)
#define CHECK_LOCATION()
Definition: Exceptions.hpp:197

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