ArmNN
 21.02
GatherQueueDescriptor Struct Reference

#include <WorkloadData.hpp>

Inheritance diagram for GatherQueueDescriptor:
QueueDescriptorWithParameters< GatherDescriptor > QueueDescriptor

Public Member Functions

void Validate (const WorkloadInfo &workloadInfo) const
 
- Public Member Functions inherited from QueueDescriptor
void ValidateInputsOutputs (const std::string &descName, unsigned int numExpectedIn, unsigned int numExpectedOut) const
 
template<typename T >
const T * GetAdditionalInformation () const
 

Additional Inherited Members

- Public Attributes inherited from QueueDescriptorWithParameters< GatherDescriptor >
GatherDescriptor m_Parameters
 
- Public Attributes inherited from QueueDescriptor
std::vector< ITensorHandle * > m_Inputs
 
std::vector< ITensorHandle * > m_Outputs
 
void * m_AdditionalInfoObject
 
- Protected Member Functions inherited from QueueDescriptorWithParameters< GatherDescriptor >
 ~QueueDescriptorWithParameters ()=default
 
 QueueDescriptorWithParameters ()=default
 
 QueueDescriptorWithParameters (QueueDescriptorWithParameters const &)=default
 
QueueDescriptorWithParametersoperator= (QueueDescriptorWithParameters const &)=default
 
- Protected Member Functions inherited from QueueDescriptor
 ~QueueDescriptor ()=default
 
 QueueDescriptor ()
 
 QueueDescriptor (QueueDescriptor const &)=default
 
QueueDescriptoroperator= (QueueDescriptor const &)=default
 

Detailed Description

Definition at line 497 of file WorkloadData.hpp.

Member Function Documentation

◆ Validate()

void Validate ( const WorkloadInfo workloadInfo) const

Definition at line 2606 of file WorkloadData.cpp.

References armnn::BFloat16, armnn::Float16, armnn::Float32, TensorInfo::GetDataType(), TensorInfo::GetNumDimensions(), WorkloadInfo::m_InputTensorInfos, WorkloadInfo::m_OutputTensorInfos, armnn::QAsymmS8, armnn::QAsymmU8, armnn::QSymmS16, and armnn::Signed32.

2607 {
2608  const std::string descriptorName{"GatherQueueDescriptor"};
2609 
2610  ValidateNumInputs(workloadInfo, descriptorName, 2);
2611  ValidateNumOutputs(workloadInfo, descriptorName, 1);
2612 
2613  const TensorInfo& indicesTensorInfo = workloadInfo.m_InputTensorInfos[1];
2614  if (indicesTensorInfo.GetDataType() != DataType::Signed32)
2615  {
2616  throw InvalidArgumentException(descriptorName + ": Indices tensor type must be Int32.");
2617  }
2618 
2619  const TensorInfo& inputTensorInfo = workloadInfo.m_InputTensorInfos[0];
2620  const TensorInfo& outputTensorInfo = workloadInfo.m_OutputTensorInfos[0];
2621 
2622  std::vector<DataType> supportedTypes =
2623  {
2631  };
2632 
2633  ValidateDataTypes(inputTensorInfo, supportedTypes, descriptorName);
2634 
2635  ValidateTensorDataTypesMatch(inputTensorInfo, outputTensorInfo, descriptorName, "input", "output");
2636 
2637  unsigned int outputDim = inputTensorInfo.GetNumDimensions() + indicesTensorInfo.GetNumDimensions() - 1;
2638  ValidateTensorNumDimensions(outputTensorInfo, descriptorName, outputDim, "output");
2639 }
std::vector< TensorInfo > m_InputTensorInfos
DataType GetDataType() const
Definition: Tensor.hpp:194
std::vector< TensorInfo > m_OutputTensorInfos
unsigned int GetNumDimensions() const
Definition: Tensor.hpp:191

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