aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAron Virginas-Tar <Aron.Virginas-Tar@arm.com>2019-09-18 13:36:52 +0100
committerNikhil Raj Arm <nikhil.raj@arm.com>2019-09-19 15:42:10 +0000
commit2fda80b2f3b81f89e5748404041786f0a6c3735f (patch)
treeb91b412ce46eb9ffe1dbee1826916839cdacd3df
parent75ae2b026c99896ec0aa574ff985992ff422c3b2 (diff)
downloadarmnn-2fda80b2f3b81f89e5748404041786f0a6c3735f.tar.gz
IVGCVSW-3880 Add serialization support for SLICE
Signed-off-by: Aron Virginas-Tar <Aron.Virginas-Tar@arm.com> Change-Id: I5eaf61cfd2c875805d2f37cd967d75ad1d20ad6d
-rw-r--r--src/armnnDeserializer/Deserializer.cpp42
-rw-r--r--src/armnnDeserializer/Deserializer.hpp1
-rw-r--r--src/armnnDeserializer/DeserializerSupport.md1
-rw-r--r--src/armnnSerializer/ArmnnSchema.fbs16
-rw-r--r--src/armnnSerializer/Serializer.cpp9
-rw-r--r--src/armnnSerializer/SerializerSupport.md1
-rw-r--r--src/armnnSerializer/test/SerializerTests.cpp59
7 files changed, 124 insertions, 5 deletions
diff --git a/src/armnnDeserializer/Deserializer.cpp b/src/armnnDeserializer/Deserializer.cpp
index 1dab9bf74f..1c4d86cf34 100644
--- a/src/armnnDeserializer/Deserializer.cpp
+++ b/src/armnnDeserializer/Deserializer.cpp
@@ -222,6 +222,7 @@ m_ParserFunctions(Layer_MAX+1, &Deserializer::ParseUnsupportedLayer)
m_ParserFunctions[Layer_ResizeBilinearLayer] = &Deserializer::ParseResizeBilinear;
m_ParserFunctions[Layer_ResizeLayer] = &Deserializer::ParseResize;
m_ParserFunctions[Layer_RsqrtLayer] = &Deserializer::ParseRsqrt;
+ m_ParserFunctions[Layer_SliceLayer] = &Deserializer::ParseSlice;
m_ParserFunctions[Layer_SoftmaxLayer] = &Deserializer::ParseSoftmax;
m_ParserFunctions[Layer_SpaceToBatchNdLayer] = &Deserializer::ParseSpaceToBatchNd;
m_ParserFunctions[Layer_SpaceToDepthLayer] = &Deserializer::ParseSpaceToDepth;
@@ -317,6 +318,8 @@ Deserializer::LayerBaseRawPtr Deserializer::GetBaseLayer(const GraphPtr& graphPt
return graphPtr->layers()->Get(layerIndex)->layer_as_ResizeLayer()->base();
case Layer::Layer_RsqrtLayer:
return graphPtr->layers()->Get(layerIndex)->layer_as_RsqrtLayer()->base();
+ case Layer::Layer_SliceLayer:
+ return graphPtr->layers()->Get(layerIndex)->layer_as_SliceLayer()->base();
case Layer::Layer_SoftmaxLayer:
return graphPtr->layers()->Get(layerIndex)->layer_as_SoftmaxLayer()->base();
case Layer::Layer_SpaceToBatchNdLayer:
@@ -338,8 +341,8 @@ Deserializer::LayerBaseRawPtr Deserializer::GetBaseLayer(const GraphPtr& graphPt
case Layer::Layer_NONE:
default:
throw ParseException(boost::str(
- boost::format("Layer must have a type %1%") %
- Layer::Layer_NONE));
+ boost::format("Layer type %1% not recognized") %
+ layerType));
}
}
@@ -1989,6 +1992,41 @@ void Deserializer::ParseRsqrt(GraphPtr graph, unsigned int layerIndex)
RegisterOutputSlots(graph, layerIndex, layer);
}
+void Deserializer::ParseSlice(GraphPtr graph, unsigned int layerIndex)
+{
+ CHECK_LAYERS(graph, 0, layerIndex);
+
+ auto inputs = GetInputs(graph, layerIndex);
+ CHECK_VALID_SIZE(inputs.size(), 1);
+
+ auto outputs = GetOutputs(graph, layerIndex);
+ CHECK_VALID_SIZE(outputs.size(), 1);
+
+ auto fbDescriptor = graph->layers()->Get(layerIndex)->layer_as_SliceLayer()->descriptor();
+
+ auto fbBegin = fbDescriptor->begin();
+ auto fbSize = fbDescriptor->size();
+
+ if (fbBegin->Length() != fbSize->Length())
+ {
+ throw ParseException(boost::str(
+ boost::format("Begin and size descriptors must have the same length %1%") % CHECK_LOCATION().AsString()));
+ }
+
+ armnn::SliceDescriptor descriptor;
+ descriptor.m_Begin.insert(descriptor.m_Begin.end(), fbBegin->begin(), fbBegin->end());
+ descriptor.m_Size.insert(descriptor.m_Size.end(), fbSize->begin(), fbSize->end());
+
+ auto layerName = GetLayerName(graph, layerIndex);
+ IConnectableLayer* layer = m_Network->AddSliceLayer(descriptor, layerName.c_str());
+
+ armnn::TensorInfo outputTensorInfo = ToTensorInfo(outputs[0]);
+ layer->GetOutputSlot(0).SetTensorInfo(outputTensorInfo);
+
+ RegisterInputSlots(graph, layerIndex, layer);
+ RegisterOutputSlots(graph, layerIndex, layer);
+}
+
void Deserializer::ParseStridedSlice(GraphPtr graph, unsigned int layerIndex)
{
CHECK_LAYERS(graph, 0, layerIndex);
diff --git a/src/armnnDeserializer/Deserializer.hpp b/src/armnnDeserializer/Deserializer.hpp
index f7743bcf5b..30af024f5e 100644
--- a/src/armnnDeserializer/Deserializer.hpp
+++ b/src/armnnDeserializer/Deserializer.hpp
@@ -113,6 +113,7 @@ private:
void ParseResize(GraphPtr graph, unsigned int layerIndex);
void ParseResizeBilinear(GraphPtr graph, unsigned int layerIndex);
void ParseRsqrt(GraphPtr graph, unsigned int layerIndex);
+ void ParseSlice(GraphPtr graph, unsigned int layerIndex);
void ParseSoftmax(GraphPtr graph, unsigned int layerIndex);
void ParseSpaceToBatchNd(GraphPtr graph, unsigned int layerIndex);
void ParseSpaceToDepth(GraphPtr graph, unsigned int layerIndex);
diff --git a/src/armnnDeserializer/DeserializerSupport.md b/src/armnnDeserializer/DeserializerSupport.md
index 2fd706d9a7..46bf92eadd 100644
--- a/src/armnnDeserializer/DeserializerSupport.md
+++ b/src/armnnDeserializer/DeserializerSupport.md
@@ -41,6 +41,7 @@ The Arm NN SDK Deserialize parser currently supports the following layers:
* Reshape
* ResizeBilinear
* Rsqrt
+* Slice
* Softmax
* SpaceToBatchNd
* SpaceToDepth
diff --git a/src/armnnSerializer/ArmnnSchema.fbs b/src/armnnSerializer/ArmnnSchema.fbs
index 97d2780368..6b07510a21 100644
--- a/src/armnnSerializer/ArmnnSchema.fbs
+++ b/src/armnnSerializer/ArmnnSchema.fbs
@@ -139,7 +139,8 @@ enum LayerType : uint {
Stack = 44,
QuantizedLstm = 45,
Abs = 46,
- ArgMinMax = 47
+ ArgMinMax = 47,
+ Slice = 48
}
// Base layer table to be used as part of other layers
@@ -471,6 +472,16 @@ table ResizeBilinearDescriptor {
dataLayout:DataLayout;
}
+table SliceLayer {
+ base:LayerBase;
+ descriptor:SliceDescriptor;
+}
+
+table SliceDescriptor {
+ begin:[uint];
+ size:[uint];
+}
+
table StridedSliceLayer {
base:LayerBase;
descriptor:StridedSliceDescriptor;
@@ -710,7 +721,8 @@ union Layer {
ResizeLayer,
StackLayer,
AbsLayer,
- ArgMinMaxLayer
+ ArgMinMaxLayer,
+ SliceLayer
}
table AnyLayer {
diff --git a/src/armnnSerializer/Serializer.cpp b/src/armnnSerializer/Serializer.cpp
index 06bfb91e83..16b7cff808 100644
--- a/src/armnnSerializer/Serializer.cpp
+++ b/src/armnnSerializer/Serializer.cpp
@@ -749,7 +749,14 @@ void SerializerVisitor::VisitSliceLayer(const armnn::IConnectableLayer* layer,
const armnn::SliceDescriptor& sliceDescriptor,
const char* name)
{
- throw UnimplementedException("SerializerVisitor::VisitSliceLayer is not implemented");
+ auto fbSliceBaseLayer = CreateLayerBase(layer, serializer::LayerType::LayerType_Slice);
+ auto fbSliceDescriptor = CreateSliceDescriptor(m_flatBufferBuilder,
+ m_flatBufferBuilder.CreateVector(sliceDescriptor.m_Begin),
+ m_flatBufferBuilder.CreateVector(sliceDescriptor.m_Size));
+
+ auto fbSliceLayer = serializer::CreateSliceLayer(m_flatBufferBuilder, fbSliceBaseLayer, fbSliceDescriptor);
+
+ CreateAnyLayer(fbSliceLayer.o, serializer::Layer::Layer_SliceLayer);
}
// Build FlatBuffer for Softmax Layer
diff --git a/src/armnnSerializer/SerializerSupport.md b/src/armnnSerializer/SerializerSupport.md
index 534e9faf5b..136998c3f2 100644
--- a/src/armnnSerializer/SerializerSupport.md
+++ b/src/armnnSerializer/SerializerSupport.md
@@ -42,6 +42,7 @@ The Arm NN SDK Serializer currently supports the following layers:
* Resize
* ResizeBilinear
* Rsqrt
+* Slice
* Softmax
* SpaceToBatchNd
* SpaceToDepth
diff --git a/src/armnnSerializer/test/SerializerTests.cpp b/src/armnnSerializer/test/SerializerTests.cpp
index bbd5402c7c..d4ad6236b4 100644
--- a/src/armnnSerializer/test/SerializerTests.cpp
+++ b/src/armnnSerializer/test/SerializerTests.cpp
@@ -2259,6 +2259,65 @@ BOOST_AUTO_TEST_CASE(SerializeRsqrt)
deserializedNetwork->Accept(verifier);
}
+BOOST_AUTO_TEST_CASE(SerializeSlice)
+{
+ class SliceLayerVerifier : public LayerVerifierBase
+ {
+ public:
+ SliceLayerVerifier(const std::string& layerName,
+ const std::vector<armnn::TensorInfo>& inputInfos,
+ const std::vector<armnn::TensorInfo>& outputInfos,
+ const armnn::SliceDescriptor& descriptor)
+ : LayerVerifierBase(layerName, inputInfos, outputInfos)
+ , m_Descriptor(descriptor) {}
+
+ void VisitSliceLayer(const armnn::IConnectableLayer* layer,
+ const armnn::SliceDescriptor& descriptor,
+ const char* name) override
+ {
+ VerifyNameAndConnections(layer, name);
+ VerifyDescriptor(descriptor);
+ }
+
+ private:
+ void VerifyDescriptor(const armnn::SliceDescriptor& descriptor)
+ {
+ BOOST_CHECK_EQUAL_COLLECTIONS(descriptor.m_Begin.begin(), descriptor.m_Begin.end(),
+ m_Descriptor.m_Begin.begin(), m_Descriptor.m_Begin.end());
+
+ BOOST_CHECK_EQUAL_COLLECTIONS(descriptor.m_Size.begin(), descriptor.m_Size.end(),
+ m_Descriptor.m_Size.begin(), m_Descriptor.m_Size.end());
+ }
+
+ armnn::SliceDescriptor m_Descriptor;
+ };
+
+ const std::string layerName{"slice"};
+
+ const armnn::TensorInfo inputInfo = armnn::TensorInfo({3, 2, 3, 1}, armnn::DataType::Float32);
+ const armnn::TensorInfo outputInfo = armnn::TensorInfo({2, 2, 2, 1}, armnn::DataType::Float32);
+
+ armnn::SliceDescriptor descriptor({ 0, 0, 1, 0}, {2, 2, 2, 1});
+
+ armnn::INetworkPtr network = armnn::INetwork::Create();
+
+ armnn::IConnectableLayer* const inputLayer = network->AddInputLayer(0);
+ armnn::IConnectableLayer* const sliceLayer = network->AddSliceLayer(descriptor, layerName.c_str());
+ armnn::IConnectableLayer* const outputLayer = network->AddOutputLayer(0);
+
+ inputLayer->GetOutputSlot(0).Connect(sliceLayer->GetInputSlot(0));
+ sliceLayer->GetOutputSlot(0).Connect(outputLayer->GetInputSlot(0));
+
+ inputLayer->GetOutputSlot(0).SetTensorInfo(inputInfo);
+ sliceLayer->GetOutputSlot(0).SetTensorInfo(outputInfo);
+
+ armnn::INetworkPtr deserializedNetwork = DeserializeNetwork(SerializeNetwork(*network));
+ BOOST_CHECK(deserializedNetwork);
+
+ SliceLayerVerifier verifier(layerName, {inputInfo}, {outputInfo}, descriptor);
+ deserializedNetwork->Accept(verifier);
+}
+
BOOST_AUTO_TEST_CASE(SerializeSoftmax)
{
class SoftmaxLayerVerifier : public LayerVerifierBase