ArmNN
 20.08
armnnDeserializer Namespace Reference

Classes

struct  BindingPointInfo
 
class  Deserializer
 
class  IDeserializer
 

Typedefs

using IDeserializerPtr = std::unique_ptr< IDeserializer, void(*)(IDeserializer *parser)>
 

Functions

bool CheckShape (const armnn::TensorShape &actual, const std::vector< uint32_t > &expected)
 
armnn::DataLayout ToDataLayout (armnnSerializer::DataLayout dataLayout)
 
armnn::ActivationFunction ToActivationFunction (armnnSerializer::ActivationFunction function)
 
armnn::ArgMinMaxFunction ToArgMinMaxFunction (armnnSerializer::ArgMinMaxFunction function)
 
armnn::ComparisonOperation ToComparisonOperation (armnnSerializer::ComparisonOperation operation)
 
armnn::UnaryOperation ToUnaryOperation (armnnSerializer::UnaryOperation operation)
 
armnn::ResizeMethod ToResizeMethod (armnnSerializer::ResizeMethod method)
 
armnn::TensorInfo ToTensorInfo (Deserializer::TensorRawPtr tensorPtr)
 
armnn::ConstTensor ToConstTensor (Deserializer::ConstTensorRawPtr constTensorPtr)
 
const armnnSerializer::OriginsDescriptor * GetOriginsDescriptor (const armnnSerializer::SerializedGraph *graph, unsigned int layerIndex)
 

Typedef Documentation

◆ IDeserializerPtr

using IDeserializerPtr = std::unique_ptr<IDeserializer, void(*)(IDeserializer* parser)>

Definition at line 25 of file IDeserializer.hpp.

Function Documentation

◆ CheckShape()

bool armnnDeserializer::CheckShape ( const armnn::TensorShape actual,
const std::vector< uint32_t > &  expected 
)

Definition at line 163 of file Deserializer.cpp.

References TensorShape::GetNumDimensions().

Referenced by Deserializer::OutputShapeOfReshape(), and TfLiteParser::OutputShapeOfReshape().

164 {
165  const unsigned int actualSize = actual.GetNumDimensions();
166  if (actualSize != expected.size())
167  {
168  return false;
169  }
170 
171  for (unsigned int i = 0u; i < actualSize; i++)
172  {
173  if (actual[i] != static_cast<unsigned int>(expected[i]))
174  {
175  return false;
176  }
177  }
178 
179  return true;
180 }
unsigned int GetNumDimensions() const
Function that returns the tensor rank.
Definition: Tensor.cpp:175

◆ GetOriginsDescriptor()

const armnnSerializer::OriginsDescriptor* armnnDeserializer::GetOriginsDescriptor ( const armnnSerializer::SerializedGraph *  graph,
unsigned int  layerIndex 
)

Definition at line 1610 of file Deserializer.cpp.

References CHECK_LAYERS, CHECK_LOCATION, CHECK_VALID_SIZE, Deserializer::GetInputs(), Deserializer::GetLayerName(), Deserializer::GetOutputs(), IConnectableLayer::GetOutputSlot(), FullyConnectedDescriptor::m_BiasEnabled, ComparisonDescriptor::m_Operation, ElementwiseUnaryDescriptor::m_Operation, FullyConnectedDescriptor::m_TransposeWeightMatrix, IOutputSlot::SetTensorInfo(), ToComparisonOperation(), ToConstTensor(), ToTensorInfo(), and ToUnaryOperation().

1612 {
1613  auto layerType = graph->layers()->Get(layerIndex)->layer_type();
1614 
1615  switch (layerType)
1616  {
1617  case Layer::Layer_ConcatLayer:
1618  return graph->layers()->Get(layerIndex)->layer_as_ConcatLayer()->descriptor();
1619  case Layer::Layer_MergerLayer:
1620  return graph->layers()->Get(layerIndex)->layer_as_MergerLayer()->descriptor();
1621  default:
1622  throw armnn::Exception("unknown layer type, should be concat or merger");
1623  }
1624 }
Base class for all ArmNN exceptions so that users can filter to just those.
Definition: Exceptions.hpp:46

◆ ToActivationFunction()

armnn::ActivationFunction armnnDeserializer::ToActivationFunction ( armnnSerializer::ActivationFunction  function)

Definition at line 411 of file Deserializer.cpp.

References armnn::Abs, armnn::BoundedReLu, armnn::Elu, armnn::HardSwish, armnn::LeakyReLu, armnn::Linear, armnn::ReLu, armnn::Sigmoid, armnn::Sqrt, armnn::Square, and armnn::TanH.

Referenced by Deserializer::GetNetworkOutputBindingInfo().

412 {
413  switch (function)
414  {
415  case armnnSerializer::ActivationFunction_Sigmoid:
417  case armnnSerializer::ActivationFunction_TanH:
419  case armnnSerializer::ActivationFunction_Linear:
421  case armnnSerializer::ActivationFunction_ReLu:
423  case armnnSerializer::ActivationFunction_BoundedReLu:
425  case armnnSerializer::ActivationFunction_LeakyReLu:
427  case armnnSerializer::ActivationFunction_Abs:
429  case armnnSerializer::ActivationFunction_Sqrt:
431  case armnnSerializer::ActivationFunction_Square:
433  case armnnSerializer::ActivationFunction_Elu:
435  case armnnSerializer::ActivationFunction_HardSwish:
437  default:
439  }
440 }
min(a, max(b, input)) ReLu1 & ReLu6.

◆ ToArgMinMaxFunction()

armnn::ArgMinMaxFunction armnnDeserializer::ToArgMinMaxFunction ( armnnSerializer::ArgMinMaxFunction  function)

Definition at line 442 of file Deserializer.cpp.

References armnn::Max, and armnn::Min.

Referenced by Deserializer::GetNetworkOutputBindingInfo().

443 {
444  switch (function)
445  {
446  case armnnSerializer::ArgMinMaxFunction::ArgMinMaxFunction_Max:
448  case armnnSerializer::ArgMinMaxFunction::ArgMinMaxFunction_Min:
449  default:
451  }
452 }

◆ ToComparisonOperation()

armnn::ComparisonOperation armnnDeserializer::ToComparisonOperation ( armnnSerializer::ComparisonOperation  operation)

Definition at line 454 of file Deserializer.cpp.

References armnn::Equal, armnn::Greater, armnn::GreaterOrEqual, armnn::Less, armnn::LessOrEqual, and armnn::NotEqual.

Referenced by GetOriginsDescriptor().

455 {
456  switch (operation)
457  {
458  case armnnSerializer::ComparisonOperation::ComparisonOperation_Equal:
460  case armnnSerializer::ComparisonOperation::ComparisonOperation_Greater:
462  case armnnSerializer::ComparisonOperation::ComparisonOperation_GreaterOrEqual:
464  case armnnSerializer::ComparisonOperation::ComparisonOperation_Less:
466  case armnnSerializer::ComparisonOperation::ComparisonOperation_LessOrEqual:
468  case armnnSerializer::ComparisonOperation::ComparisonOperation_NotEqual:
469  default:
471  }
472 }

◆ ToConstTensor()

armnn::ConstTensor armnnDeserializer::ToConstTensor ( Deserializer::ConstTensorRawPtr  constTensorPtr)

Definition at line 593 of file Deserializer.cpp.

References CheckLocation::AsString(), CHECK_CONST_TENSOR_PTR, CHECK_CONST_TENSOR_SIZE, CHECK_LOCATION, TensorInfo::GetNumElements(), and ToTensorInfo().

Referenced by Deserializer::GetLstmDescriptor(), Deserializer::GetNetworkOutputBindingInfo(), GetOriginsDescriptor(), and Deserializer::GetQLstmDescriptor().

594 {
595  CHECK_CONST_TENSOR_PTR(constTensorPtr);
596  armnn::TensorInfo tensorInfo = ToTensorInfo(constTensorPtr->info());
597 
598  switch (constTensorPtr->data_type())
599  {
600  case ConstTensorData_ByteData:
601  {
602  auto byteData = constTensorPtr->data_as_ByteData()->data();
603  CHECK_CONST_TENSOR_SIZE(byteData->size(), tensorInfo.GetNumElements());
604  return armnn::ConstTensor(tensorInfo, byteData->data());
605  }
606  case ConstTensorData_ShortData:
607  {
608  auto shortData = constTensorPtr->data_as_ShortData()->data();
609  CHECK_CONST_TENSOR_SIZE(shortData->size(), tensorInfo.GetNumElements());
610  return armnn::ConstTensor(tensorInfo, shortData->data());
611  }
612  case ConstTensorData_IntData:
613  {
614  auto intData = constTensorPtr->data_as_IntData()->data();
615  CHECK_CONST_TENSOR_SIZE(intData->size(), tensorInfo.GetNumElements());
616  return armnn::ConstTensor(tensorInfo, intData->data());
617  }
618  case ConstTensorData_LongData:
619  {
620  auto longData = constTensorPtr->data_as_LongData()->data();
621  CHECK_CONST_TENSOR_SIZE(longData->size(), tensorInfo.GetNumElements());
622  return armnn::ConstTensor(tensorInfo, longData->data());
623  }
624  default:
625  {
626  CheckLocation location = CHECK_LOCATION();
627  throw ParseException(
628  boost::str(boost::format("Unsupported data type %1% = %2%. %3%") %
629  constTensorPtr->data_type() %
630  EnumNameConstTensorData(constTensorPtr->data_type()) %
631  location.AsString()));
632  }
633  }
634 }
std::string AsString() const
Definition: Exceptions.hpp:29
#define CHECK_CONST_TENSOR_SIZE(CONST_TENSOR_SIZE, TENSOR_SIZE)
armnn::TensorInfo ToTensorInfo(Deserializer::TensorRawPtr tensorPtr)
A tensor defined by a TensorInfo (shape and data type) and an immutable backing store.
Definition: Tensor.hpp:298
#define CHECK_CONST_TENSOR_PTR(TENSOR_PTR)
#define CHECK_LOCATION()
Definition: Exceptions.hpp:197
unsigned int GetNumElements() const
Definition: Tensor.hpp:192

◆ ToDataLayout()

armnn::DataLayout armnnDeserializer::ToDataLayout ( armnnSerializer::DataLayout  dataLayout)

Definition at line 399 of file Deserializer.cpp.

References armnn::NCHW, and armnn::NHWC.

Referenced by Deserializer::GetNetworkOutputBindingInfo(), Deserializer::GetNormalizationDescriptor(), Deserializer::GetQLstmDescriptor(), and Deserializer::OutputShapeOfReshape().

400 {
401  switch (dataLayout)
402  {
403  case armnnSerializer::DataLayout::DataLayout_NHWC:
405  case armnnSerializer::DataLayout::DataLayout_NCHW:
406  default:
408  }
409 }

◆ ToResizeMethod()

armnn::ResizeMethod armnnDeserializer::ToResizeMethod ( armnnSerializer::ResizeMethod  method)

Definition at line 493 of file Deserializer.cpp.

References armnn::Bilinear, and armnn::NearestNeighbor.

Referenced by Deserializer::OutputShapeOfReshape().

494 {
495  switch (method)
496  {
497  case armnnSerializer::ResizeMethod_NearestNeighbor:
499  case armnnSerializer::ResizeMethod_Bilinear:
501  default:
503  }
504 }

◆ ToTensorInfo()

armnn::TensorInfo armnnDeserializer::ToTensorInfo ( Deserializer::TensorRawPtr  tensorPtr)

Definition at line 506 of file Deserializer.cpp.

References CheckLocation::AsString(), armnn::Boolean, CHECK_LOCATION, CHECK_TENSOR_PTR, armnn::Float16, armnn::Float32, armnn::QAsymmS8, armnn::QAsymmU8, armnn::QSymmS16, armnn::QSymmS8, armnn::Scalar, and armnn::Signed32.

Referenced by armnnTfLiteParser::ComputeWrappedIndex(), TfLiteParser::CreateNetworkFromBinary(), OnnxParser::CreateNetworkFromString(), Deserializer::GetLstmDescriptor(), OnnxParser::GetNetworkInputBindingInfo(), TfLiteParser::GetNetworkInputBindingInfo(), Deserializer::GetNetworkOutputBindingInfo(), OnnxParser::GetNetworkOutputBindingInfo(), TfLiteParser::GetNetworkOutputBindingInfo(), Deserializer::GetNormalizationDescriptor(), GetOriginsDescriptor(), TfLiteParser::GetOutputTensorIds(), Deserializer::GetPoolingDescriptor(), Deserializer::GetQLstmDescriptor(), Deserializer::OutputShapeOfReshape(), TfLiteParser::OutputShapeOfReshape(), TfLiteParser::OutputShapeOfSqueeze(), TfLiteParser::TfLiteParser(), and ToConstTensor().

507 {
508  armnn::DataType type;
509  CHECK_TENSOR_PTR(tensorPtr);
510 
511  switch (tensorPtr->dataType())
512  {
513  case DataType_QAsymmS8:
515  break;
516  case DataType_QSymmS8:
518  break;
519  case DataType_QuantisedAsymm8:
520  case DataType_QAsymmU8:
522  break;
523  case DataType_QSymmS16:
524  case DataType_QuantisedSymm16:
526  break;
527  case DataType_Signed32:
529  break;
530  case DataType_Float32:
532  break;
533  case DataType_Float16:
535  break;
536  case DataType_Boolean:
538  break;
539  default:
540  {
541  CheckLocation location = CHECK_LOCATION();
542  throw ParseException(
543  boost::str(
544  boost::format("Unsupported data type %1% = %2%. %3%") %
545  tensorPtr->dataType() %
546  EnumNameDataType(tensorPtr->dataType()) %
547  location.AsString()));
548  }
549  }
550 
551  if (tensorPtr->dimensionality() == static_cast<unsigned int>(Dimensionality::Scalar))
552  {
553  float quantizationScale = tensorPtr->quantizationScale();
554  int32_t quantizationOffset = tensorPtr->quantizationOffset();
555 
557  type,
558  quantizationScale,
559  quantizationOffset);
560  }
561 
562  auto dimensions = tensorPtr->dimensions();
563  unsigned int size = dimensions->size();
564  std::vector<unsigned int> outputDims(dimensions->begin(), dimensions->begin() + size);
565 
566  auto quantizationScales = tensorPtr->quantizationScales();
567 
568  if (quantizationScales)
569  {
570  unsigned int quantizationScalesSize = quantizationScales->size();
571  std::vector<float> scales(quantizationScales->begin(), quantizationScales->begin() + quantizationScalesSize);
572  unsigned int quantizationDim = tensorPtr->quantizationDim();
573  armnn::TensorInfo result(size,
574  outputDims.data(),
575  type,
576  scales,
577  quantizationDim);
578  return result;
579  }
580 
581  float quantizationScale = tensorPtr->quantizationScale();
582  int32_t quantizationOffset = tensorPtr->quantizationOffset();
583 
584  // two statements (on purpose) for easier debugging:
585  armnn::TensorInfo result(size,
586  outputDims.data(),
587  type,
588  quantizationScale,
589  quantizationOffset);
590  return result;
591 }
std::string AsString() const
Definition: Exceptions.hpp:29
#define CHECK_TENSOR_PTR(TENSOR_PTR)
DataType
Definition: Types.hpp:32
#define CHECK_LOCATION()
Definition: Exceptions.hpp:197

◆ ToUnaryOperation()

armnn::UnaryOperation armnnDeserializer::ToUnaryOperation ( armnnSerializer::UnaryOperation  operation)

Definition at line 474 of file Deserializer.cpp.

References armnn::Abs, armnn::Exp, armnn::Neg, armnn::Rsqrt, and armnn::Sqrt.

Referenced by GetOriginsDescriptor().

475 {
476  switch (operation)
477  {
478  case armnnSerializer::UnaryOperation::UnaryOperation_Abs:
480  case armnnSerializer::UnaryOperation::UnaryOperation_Rsqrt:
482  case armnnSerializer::UnaryOperation::UnaryOperation_Sqrt:
484  case armnnSerializer::UnaryOperation::UnaryOperation_Exp:
486  case armnnSerializer::UnaryOperation::UnaryOperation_Neg:
488  default:
489  throw armnn::InvalidArgumentException("Unary operation unknown");
490  }
491 }