ArmNN
 23.02
SerializerUtils.cpp
Go to the documentation of this file.
1 //
2 // Copyright © 2017 Arm Ltd and Contributors. All rights reserved.
3 // SPDX-License-Identifier: MIT
4 //
5 
6 #include "SerializerUtils.hpp"
7 
8 namespace armnnSerializer
9 {
10 
12 {
13  switch (comparisonOperation)
14  {
16  return armnnSerializer::ComparisonOperation::ComparisonOperation_Equal;
18  return armnnSerializer::ComparisonOperation::ComparisonOperation_Greater;
20  return armnnSerializer::ComparisonOperation::ComparisonOperation_GreaterOrEqual;
22  return armnnSerializer::ComparisonOperation::ComparisonOperation_Less;
24  return armnnSerializer::ComparisonOperation::ComparisonOperation_LessOrEqual;
26  default:
27  return armnnSerializer::ComparisonOperation::ComparisonOperation_NotEqual;
28  }
29 }
30 
32  armnn::LogicalBinaryOperation logicalBinaryOperation)
33 {
34  switch (logicalBinaryOperation)
35  {
37  return armnnSerializer::LogicalBinaryOperation::LogicalBinaryOperation_LogicalAnd;
39  return armnnSerializer::LogicalBinaryOperation::LogicalBinaryOperation_LogicalOr;
40  default:
41  throw armnn::InvalidArgumentException("Logical Binary operation unknown");
42  }
43 }
44 
45 armnnSerializer::ConstTensorData GetFlatBufferConstTensorData(armnn::DataType dataType)
46 {
47  switch (dataType)
48  {
51  return armnnSerializer::ConstTensorData::ConstTensorData_IntData;
54  return armnnSerializer::ConstTensorData::ConstTensorData_ShortData;
59  return armnnSerializer::ConstTensorData::ConstTensorData_ByteData;
61  return armnnSerializer::ConstTensorData::ConstTensorData_LongData;
62  default:
63  return armnnSerializer::ConstTensorData::ConstTensorData_NONE;
64  }
65 }
66 
68 {
69  switch (dataType)
70  {
72  return armnnSerializer::DataType::DataType_Float32;
74  return armnnSerializer::DataType::DataType_Float16;
76  return armnnSerializer::DataType::DataType_Signed32;
78  return armnnSerializer::DataType::DataType_Signed64;
80  return armnnSerializer::DataType::DataType_QSymmS16;
82  return armnnSerializer::DataType::DataType_QAsymmS8;
84  return armnnSerializer::DataType::DataType_QAsymmU8;
86  return armnnSerializer::DataType::DataType_QSymmS8;
88  return armnnSerializer::DataType::DataType_Boolean;
89  default:
90  return armnnSerializer::DataType::DataType_Float16;
91  }
92 }
93 
95 {
96  switch (dataLayout)
97  {
99  return armnnSerializer::DataLayout::DataLayout_NHWC;
101  return armnnSerializer::DataLayout::DataLayout_NDHWC;
103  return armnnSerializer::DataLayout::DataLayout_NCDHW;
105  default:
106  return armnnSerializer::DataLayout::DataLayout_NCHW;
107  }
108 }
109 
111 {
112  switch (comparisonOperation)
113  {
115  return armnnSerializer::UnaryOperation::UnaryOperation_Abs;
117  return armnnSerializer::UnaryOperation::UnaryOperation_Rsqrt;
119  return armnnSerializer::UnaryOperation::UnaryOperation_Sqrt;
121  return armnnSerializer::UnaryOperation::UnaryOperation_Exp;
123  return armnnSerializer::UnaryOperation::UnaryOperation_Neg;
125  return armnnSerializer::UnaryOperation::UnaryOperation_LogicalNot;
127  return armnnSerializer::UnaryOperation::UnaryOperation_Log;
129  return armnnSerializer::UnaryOperation::UnaryOperation_Sin;
130  default:
131  throw armnn::InvalidArgumentException("Unary operation unknown");
132  }
133 }
134 
136 {
137  switch (poolingAlgorithm)
138  {
140  return armnnSerializer::PoolingAlgorithm::PoolingAlgorithm_Average;
142  return armnnSerializer::PoolingAlgorithm::PoolingAlgorithm_L2;
144  default:
145  return armnnSerializer::PoolingAlgorithm::PoolingAlgorithm_Max;
146  }
147 }
148 
150 {
151  switch (outputShapeRounding)
152  {
154  return armnnSerializer::OutputShapeRounding::OutputShapeRounding_Ceiling;
156  default:
157  return armnnSerializer::OutputShapeRounding::OutputShapeRounding_Floor;
158  }
159 }
160 
162 {
163  switch (paddingMethod)
164  {
166  return armnnSerializer::PaddingMethod::PaddingMethod_IgnoreValue;
168  default:
169  return armnnSerializer::PaddingMethod::PaddingMethod_Exclude;
170  }
171 }
172 
174 {
175  switch (paddingMode)
176  {
178  return armnnSerializer::PaddingMode::PaddingMode_Reflect;
180  return armnnSerializer::PaddingMode::PaddingMode_Symmetric;
181  default:
182  return armnnSerializer::PaddingMode::PaddingMode_Constant;
183  }
184 }
185 
187  armnn::NormalizationAlgorithmChannel normalizationAlgorithmChannel)
188 {
189  switch (normalizationAlgorithmChannel)
190  {
192  return armnnSerializer::NormalizationAlgorithmChannel::NormalizationAlgorithmChannel_Across;
194  return armnnSerializer::NormalizationAlgorithmChannel::NormalizationAlgorithmChannel_Within;
195  default:
196  return armnnSerializer::NormalizationAlgorithmChannel::NormalizationAlgorithmChannel_Across;
197  }
198 }
199 
201  armnn::NormalizationAlgorithmMethod normalizationAlgorithmMethod)
202 {
203  switch (normalizationAlgorithmMethod)
204  {
206  return armnnSerializer::NormalizationAlgorithmMethod::NormalizationAlgorithmMethod_LocalBrightness;
208  return armnnSerializer::NormalizationAlgorithmMethod::NormalizationAlgorithmMethod_LocalContrast;
209  default:
210  return armnnSerializer::NormalizationAlgorithmMethod::NormalizationAlgorithmMethod_LocalBrightness;
211  }
212 }
213 
215 {
216  switch (method)
217  {
219  return armnnSerializer::ResizeMethod_NearestNeighbor;
221  return armnnSerializer::ResizeMethod_Bilinear;
222  default:
223  return armnnSerializer::ResizeMethod_NearestNeighbor;
224  }
225 }
226 
228 {
229  switch (reduceOperation)
230  {
232  return armnnSerializer::ReduceOperation::ReduceOperation_Sum;
234  return armnnSerializer::ReduceOperation::ReduceOperation_Max;
236  return armnnSerializer::ReduceOperation::ReduceOperation_Mean;
238  return armnnSerializer::ReduceOperation::ReduceOperation_Min;
240  return armnnSerializer::ReduceOperation::ReduceOperation_Prod;
241  default:
242  return armnnSerializer::ReduceOperation::ReduceOperation_Sum;
243  }
244 }
245 
246 } // namespace armnnSerializer
armnn::ReduceOperation::Mean
@ Mean
armnn::NormalizationAlgorithmMethod
NormalizationAlgorithmMethod
Definition: Types.hpp:199
armnnSerializer::GetFlatBufferOutputShapeRounding
armnnSerializer::OutputShapeRounding GetFlatBufferOutputShapeRounding(armnn::OutputShapeRounding outputShapeRounding)
Definition: SerializerUtils.cpp:149
armnn::OutputShapeRounding::Ceiling
@ Ceiling
armnn::OutputShapeRounding
OutputShapeRounding
Definition: Types.hpp:207
armnn::DataType::QAsymmU8
@ QAsymmU8
armnnSerializer
Definition: ISerializer.hpp:11
armnn::NormalizationAlgorithmChannel
NormalizationAlgorithmChannel
Definition: Types.hpp:193
armnn::ComparisonOperation::Equal
@ Equal
SerializerUtils.hpp
armnn::DataLayout
DataLayout
Definition: Types.hpp:62
armnn::LogicalBinaryOperation::LogicalAnd
@ LogicalAnd
armnn::DataType::Float16
@ Float16
armnn::OutputShapeRounding::Floor
@ Floor
armnn::NormalizationAlgorithmMethod::LocalContrast
@ LocalContrast
Jarret 2009: Local Contrast Normalization.
armnn::ComparisonOperation::NotEqual
@ NotEqual
armnnSerializer::GetFlatBufferLogicalBinaryOperation
armnnSerializer::LogicalBinaryOperation GetFlatBufferLogicalBinaryOperation(armnn::LogicalBinaryOperation logicalBinaryOperation)
Definition: SerializerUtils.cpp:31
armnn::UnaryOperation::Exp
@ Exp
armnn::UnaryOperation::Sqrt
@ Sqrt
armnn::DataType::Signed32
@ Signed32
armnn::UnaryOperation::Neg
@ Neg
armnn::ComparisonOperation::LessOrEqual
@ LessOrEqual
armnn::DataType::QAsymmS8
@ QAsymmS8
armnn::PaddingMethod::IgnoreValue
@ IgnoreValue
The padding fields count, but are ignored.
armnn::PoolingAlgorithm::L2
@ L2
armnn::NormalizationAlgorithmChannel::Within
@ Within
armnnSerializer::GetFlatBufferDataType
armnnSerializer::DataType GetFlatBufferDataType(armnn::DataType dataType)
Definition: SerializerUtils.cpp:67
armnn::ReduceOperation::Min
@ Min
armnnSerializer::GetFlatBufferPaddingMethod
armnnSerializer::PaddingMethod GetFlatBufferPaddingMethod(armnn::PaddingMethod paddingMethod)
Definition: SerializerUtils.cpp:161
armnn::LogicalBinaryOperation
LogicalBinaryOperation
Definition: Types.hpp:118
armnn::ResizeMethod::NearestNeighbor
@ NearestNeighbor
armnnSerializer::GetFlatBufferPoolingAlgorithm
armnnSerializer::PoolingAlgorithm GetFlatBufferPoolingAlgorithm(armnn::PoolingAlgorithm poolingAlgorithm)
Definition: SerializerUtils.cpp:135
armnn::PoolingAlgorithm
PoolingAlgorithm
Definition: Types.hpp:136
armnn::ResizeMethod
ResizeMethod
Definition: Types.hpp:152
armnn::ReduceOperation::Sum
@ Sum
armnn::LogicalBinaryOperation::LogicalOr
@ LogicalOr
armnnSerializer::GetFlatBufferComparisonOperation
armnnSerializer::ComparisonOperation GetFlatBufferComparisonOperation(armnn::ComparisonOperation comparisonOperation)
Definition: SerializerUtils.cpp:11
armnn::DataLayout::NCHW
@ NCHW
armnn::ReduceOperation::Max
@ Max
armnn::ReduceOperation
ReduceOperation
Definition: Types.hpp:143
armnnSerializer::GetFlatBufferUnaryOperation
armnnSerializer::UnaryOperation GetFlatBufferUnaryOperation(armnn::UnaryOperation comparisonOperation)
Definition: SerializerUtils.cpp:110
armnn::NormalizationAlgorithmChannel::Across
@ Across
armnn::NormalizationAlgorithmMethod::LocalBrightness
@ LocalBrightness
Krichevsky 2012: Local Brightness Normalization.
armnn::DataLayout::NCDHW
@ NCDHW
armnn::ComparisonOperation::Greater
@ Greater
armnnSerializer::GetFlatBufferPaddingMode
armnnSerializer::PaddingMode GetFlatBufferPaddingMode(armnn::PaddingMode paddingMode)
Definition: SerializerUtils.cpp:173
armnn::ComparisonOperation::GreaterOrEqual
@ GreaterOrEqual
armnnSerializer::GetFlatBufferResizeMethod
armnnSerializer::ResizeMethod GetFlatBufferResizeMethod(armnn::ResizeMethod method)
Definition: SerializerUtils.cpp:214
armnn::DataType::Float32
@ Float32
armnn::ResizeMethod::Bilinear
@ Bilinear
armnn::ComparisonOperation
ComparisonOperation
Definition: Types.hpp:108
armnn::PaddingMode
PaddingMode
The padding mode controls whether the padding should be filled with constant values (Constant),...
Definition: Types.hpp:186
armnn::DataType::Signed64
@ Signed64
armnn::UnaryOperation
UnaryOperation
Definition: Types.hpp:124
armnnSerializer::GetFlatBufferNormalizationAlgorithmChannel
armnnSerializer::NormalizationAlgorithmChannel GetFlatBufferNormalizationAlgorithmChannel(armnn::NormalizationAlgorithmChannel normalizationAlgorithmChannel)
Definition: SerializerUtils.cpp:186
armnn::PaddingMethod
PaddingMethod
The padding method modifies the output of pooling layers.
Definition: Types.hpp:174
armnn::DataLayout::NHWC
@ NHWC
armnn::PaddingMode::Reflect
@ Reflect
armnn::UnaryOperation::Abs
@ Abs
armnn::DataType
DataType
Definition: Types.hpp:48
armnnSerializer::GetFlatBufferConstTensorData
armnnSerializer::ConstTensorData GetFlatBufferConstTensorData(armnn::DataType dataType)
Definition: SerializerUtils.cpp:45
armnn::PaddingMode::Symmetric
@ Symmetric
armnn::PoolingAlgorithm::Max
@ Max
armnn::UnaryOperation::LogicalNot
@ LogicalNot
armnn::UnaryOperation::Sin
@ Sin
armnn::PoolingAlgorithm::Average
@ Average
armnn::DataType::QSymmS8
@ QSymmS8
armnnSerializer::GetFlatBufferReduceOperation
armnnSerializer::ReduceOperation GetFlatBufferReduceOperation(armnn::ReduceOperation reduceOperation)
Definition: SerializerUtils.cpp:227
armnnSerializer::GetFlatBufferDataLayout
armnnSerializer::DataLayout GetFlatBufferDataLayout(armnn::DataLayout dataLayout)
Definition: SerializerUtils.cpp:94
armnn::UnaryOperation::Rsqrt
@ Rsqrt
armnn::DataType::QSymmS16
@ QSymmS16
armnn::ReduceOperation::Prod
@ Prod
armnn::PaddingMethod::Exclude
@ Exclude
The padding fields don't count and are ignored.
armnn::DataLayout::NDHWC
@ NDHWC
armnn::DataType::Boolean
@ Boolean
armnn::InvalidArgumentException
Definition: Exceptions.hpp:80
armnn::ComparisonOperation::Less
@ Less
armnnSerializer::GetFlatBufferNormalizationAlgorithmMethod
armnnSerializer::NormalizationAlgorithmMethod GetFlatBufferNormalizationAlgorithmMethod(armnn::NormalizationAlgorithmMethod normalizationAlgorithmMethod)
Definition: SerializerUtils.cpp:200
armnn::UnaryOperation::Log
@ Log