From cb549301bc4c5a405e02c1f433537557423d2e36 Mon Sep 17 00:00:00 2001 From: Aron Virginas-Tar Date: Fri, 21 Jun 2019 13:53:38 +0100 Subject: IVGCVSW-3321 Add serialization support for TransposeConvolution2dLayer Signed-off-by: Aron Virginas-Tar Change-Id: If0c8f3662d5e03696f97040abed784c0fbcdbc6f --- src/armnnSerializer/Serializer.cpp | 27 ++++++++++++++++++++++++++- 1 file changed, 26 insertions(+), 1 deletion(-) (limited to 'src/armnnSerializer/Serializer.cpp') diff --git a/src/armnnSerializer/Serializer.cpp b/src/armnnSerializer/Serializer.cpp index efadbb38ca..126247bb8c 100644 --- a/src/armnnSerializer/Serializer.cpp +++ b/src/armnnSerializer/Serializer.cpp @@ -952,7 +952,32 @@ void SerializerVisitor::VisitTransposeConvolution2dLayer( const armnn::Optional& biases, const char* name) { - throw UnimplementedException("SerializerVisitor::VisitTransposeConvolution2dLayer is not implemented"); + auto fbBaseLayer = CreateLayerBase(layer, serializer::LayerType::LayerType_Convolution2d); + auto fbDescriptor = CreateTransposeConvolution2dDescriptor(m_flatBufferBuilder, + descriptor.m_PadLeft, + descriptor.m_PadRight, + descriptor.m_PadTop, + descriptor.m_PadBottom, + descriptor.m_StrideX, + descriptor.m_StrideY, + descriptor.m_BiasEnabled, + GetFlatBufferDataLayout(descriptor.m_DataLayout)); + + // weights & biases + auto fbWeightsConstTensorInfo = CreateConstTensorInfo(weights); + flatbuffers::Offset fbBiasesConstTensorInfo; + if (biases.has_value()) + { + fbBiasesConstTensorInfo = CreateConstTensorInfo(biases.value()); + } + + auto fbLayer = CreateTransposeConvolution2dLayer(m_flatBufferBuilder, + fbBaseLayer, + fbDescriptor, + fbWeightsConstTensorInfo, + fbBiasesConstTensorInfo); + + CreateAnyLayer(fbLayer.o, serializer::Layer::Layer_TransposeConvolution2dLayer); } fb::Offset SerializerVisitor::CreateLayerBase(const IConnectableLayer* layer, -- cgit v1.2.1