ArmNN
 21.02
ClMultiplicationWorkload Class Reference

#include <ClMultiplicationWorkload.hpp>

Inheritance diagram for ClMultiplicationWorkload:
BaseWorkload< MultiplicationQueueDescriptor > IWorkload

Public Member Functions

 ClMultiplicationWorkload (const MultiplicationQueueDescriptor &descriptor, const WorkloadInfo &info, const arm_compute::CLCompileContext &clCompileContext)
 
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,
const arm_compute::CLCompileContext &  clCompileContext 
)

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().

50  : BaseWorkload<MultiplicationQueueDescriptor>(descriptor, info)
51 {
52  m_Data.ValidateInputsOutputs("ClMultiplicationWorkload", 2, 1);
53 
54  arm_compute::ICLTensor& input0 = static_cast<IClTensorHandle*>(m_Data.m_Inputs[0])->GetTensor();
55  arm_compute::ICLTensor& input1 = static_cast<IClTensorHandle*>(m_Data.m_Inputs[1])->GetTensor();
56  arm_compute::ICLTensor& output = static_cast<IClTensorHandle*>(m_Data.m_Outputs[0])->GetTensor();
57 
58  auto convertPolicy = (IsQuantizedType(info.m_InputTensorInfos[0].GetDataType()) ||
59  IsQuantizedType(info.m_InputTensorInfos[1].GetDataType())) ?
60  arm_compute::ConvertPolicy::SATURATE :
61  arm_compute::ConvertPolicy::WRAP;
62 
63  const arm_compute::ActivationLayerInfo activationInfo = ConvertAdditionalInfoToAclActivationLayerInfo(descriptor);
64 
65  // Construct
66  m_PixelWiseMultiplication.configure(clCompileContext,
67  &input0,
68  &input1,
69  &output,
70  1.0f,
71  convertPolicy,
72  arm_compute::RoundingPolicy::TO_NEAREST_EVEN,
73  activationInfo);
74 }
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 76 of file ClMultiplicationWorkload.cpp.

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

77 {
78  ARMNN_SCOPED_PROFILING_EVENT_CL("ClMultiplicationWorkload_Execute");
79  RunClFunction(m_PixelWiseMultiplication, CHECK_LOCATION());
80 }
#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: