ArmNN
 20.08
ClConstantWorkload Class Reference

#include <ClConstantWorkload.hpp>

Inheritance diagram for ClConstantWorkload:
BaseWorkload< ConstantQueueDescriptor > IWorkload

Public Member Functions

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

Detailed Description

Definition at line 15 of file ClConstantWorkload.hpp.

Constructor & Destructor Documentation

◆ ClConstantWorkload()

ClConstantWorkload ( const ConstantQueueDescriptor descriptor,
const WorkloadInfo info 
)

Definition at line 44 of file ClConstantWorkload.cpp.

45  : BaseWorkload<ConstantQueueDescriptor>(descriptor, info)
46  , m_RanOnce(false)
47 {
48 }

Member Function Documentation

◆ Execute()

void Execute ( ) const
overridevirtual

Implements IWorkload.

Definition at line 50 of file ClConstantWorkload.cpp.

References ARMNN_ASSERT, ARMNN_ASSERT_MSG, ARMNN_SCOPED_PROFILING_EVENT_CL, armnn::CopyArmComputeClTensorData(), ConstCpuTensorHandle::GetConstTensor(), BaseWorkload< ConstantQueueDescriptor >::m_Data, ConstantQueueDescriptor::m_LayerOutput, and QueueDescriptor::m_Outputs.

51 {
52  ARMNN_SCOPED_PROFILING_EVENT_CL("ClConstantWorkload_Execute");
53 
54  // The intermediate tensor held by the corresponding layer output handler can be initialised with the given data
55  // on the first inference, then reused for subsequent inferences.
56  // The initialisation cannot happen at workload construction time since the ACL kernel for the next layer may not
57  // have been configured at the time.
58  if (!m_RanOnce)
59  {
60  const ConstantQueueDescriptor& data = this->m_Data;
61 
62  ARMNN_ASSERT(data.m_LayerOutput != nullptr);
63  arm_compute::CLTensor& output = static_cast<ClTensorHandle*>(data.m_Outputs[0])->GetTensor();
64  arm_compute::DataType computeDataType = static_cast<ClTensorHandle*>(data.m_Outputs[0])->GetDataType();
65 
66  switch (computeDataType)
67  {
68  case arm_compute::DataType::F16:
69  {
70  CopyArmComputeClTensorData(output, data.m_LayerOutput->GetConstTensor<Half>());
71  break;
72  }
73  case arm_compute::DataType::F32:
74  {
75  CopyArmComputeClTensorData(output, data.m_LayerOutput->GetConstTensor<float>());
76  break;
77  }
78  case arm_compute::DataType::QASYMM8:
79  {
80  CopyArmComputeClTensorData(output, data.m_LayerOutput->GetConstTensor<uint8_t>());
81  break;
82  }
83  case arm_compute::DataType::QASYMM8_SIGNED:
84  {
85  CopyArmComputeClTensorData(output, data.m_LayerOutput->GetConstTensor<int8_t>());
86  break;
87  }
88  case arm_compute::DataType::QSYMM16:
89  {
90  CopyArmComputeClTensorData(output, data.m_LayerOutput->GetConstTensor<int16_t>());
91  break;
92  }
93  case arm_compute::DataType::QSYMM8:
94  case arm_compute::DataType::QSYMM8_PER_CHANNEL:
95  {
96  CopyArmComputeClTensorData(output, data.m_LayerOutput->GetConstTensor<int8_t>());
97  break;
98  }
99  case arm_compute::DataType::S32:
100  {
101  CopyArmComputeClTensorData(output, data.m_LayerOutput->GetConstTensor<int32_t>());
102  break;
103  }
104  default:
105  {
106  ARMNN_ASSERT_MSG(false, "Unknown data type");
107  break;
108  }
109  }
110 
111  m_RanOnce = true;
112  }
113 }
#define ARMNN_SCOPED_PROFILING_EVENT_CL(name)
const ConstantQueueDescriptor m_Data
Definition: Workload.hpp:46
DataType
Definition: Types.hpp:32
#define ARMNN_ASSERT_MSG(COND, MSG)
Definition: Assert.hpp:15
#define ARMNN_ASSERT(COND)
Definition: Assert.hpp:14
void CopyArmComputeClTensorData(arm_compute::CLTensor &dstTensor, const T *srcData)
half_float::half Half
Definition: Half.hpp:16

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