diff options
author | Nattapat Chaimanowong <nattapat.chaimanowong@arm.com> | 2019-02-20 17:31:34 +0000 |
---|---|---|
committer | Nattapat Chaimanowong <nattapat.chaimanowong@arm.com> | 2019-02-20 17:31:34 +0000 |
commit | 30b0020478652e441a5dff4880261f7c7007bb6c (patch) | |
tree | fed46af6b7a62acdcd9ffb906e00efb679572883 /src/armnnSerializer/test | |
parent | af484013329a8ca5b3c4c9d16395fb79dd19b1b2 (diff) | |
download | armnn-30b0020478652e441a5dff4880261f7c7007bb6c.tar.gz |
IVGCVSW-2702 Add Serializer and Deserializer for Permute
Change-Id: I56322cb935de42cfa25bd1fbb0c09d00c7a5dd2b
Signed-off-by: Nattapat Chaimanowong <nattapat.chaimanowong@arm.com>
Diffstat (limited to 'src/armnnSerializer/test')
-rw-r--r-- | src/armnnSerializer/test/SerializerTests.cpp | 32 |
1 files changed, 31 insertions, 1 deletions
diff --git a/src/armnnSerializer/test/SerializerTests.cpp b/src/armnnSerializer/test/SerializerTests.cpp index 7dad6accd0..c4c6eedb20 100644 --- a/src/armnnSerializer/test/SerializerTests.cpp +++ b/src/armnnSerializer/test/SerializerTests.cpp @@ -364,4 +364,34 @@ BOOST_AUTO_TEST_CASE(SerializeDeserializePooling2d) outputInfo.GetShape()); } -BOOST_AUTO_TEST_SUITE_END()
\ No newline at end of file +BOOST_AUTO_TEST_CASE(SerializeDeserializePermute) +{ + unsigned int inputShape[] = { 4, 3, 2, 1 }; + unsigned int outputShape[] = { 1, 2, 3, 4 }; + unsigned int dimsMapping[] = { 3, 2, 1, 0 }; + + auto inputTensorInfo = armnn::TensorInfo(4, inputShape, armnn::DataType::Float32); + auto outputTensorInfo = armnn::TensorInfo(4, outputShape, armnn::DataType::Float32); + + armnn::PermuteDescriptor permuteDescriptor(armnn::PermutationVector(dimsMapping, 4)); + + armnn::INetworkPtr network = armnn::INetwork::Create(); + armnn::IConnectableLayer *const inputLayer = network->AddInputLayer(0); + armnn::IConnectableLayer *const permuteLayer = network->AddPermuteLayer(permuteDescriptor, "PermuteLayer"); + armnn::IConnectableLayer *const outputLayer = network->AddOutputLayer(0); + + inputLayer->GetOutputSlot(0).Connect(permuteLayer->GetInputSlot(0)); + inputLayer->GetOutputSlot(0).SetTensorInfo(inputTensorInfo); + permuteLayer->GetOutputSlot(0).Connect(outputLayer->GetInputSlot(0)); + permuteLayer->GetOutputSlot(0).SetTensorInfo(outputTensorInfo); + + armnn::INetworkPtr deserializedNetwork = DeserializeNetwork(SerializeNetwork(*network)); + BOOST_CHECK(deserializedNetwork); + + CheckDeserializedNetworkAgainstOriginal(*network, + *deserializedNetwork, + inputTensorInfo.GetShape(), + outputTensorInfo.GetShape()); +} + +BOOST_AUTO_TEST_SUITE_END() |