diff options
author | Derek Lamberti <derek.lamberti@arm.com> | 2019-03-25 15:41:58 +0000 |
---|---|---|
committer | derek.lamberti <derek.lamberti@arm.com> | 2019-03-27 16:06:46 +0000 |
commit | a9cca6aa935b3e290181a05fdb2c5f5557a49c09 (patch) | |
tree | 60493eeada1357fa2334f7f952879561480e192f /src/armnn/test/NetworkTests.cpp | |
parent | 045ea78ab73b1c88a38d3ecb501583a38161ca0e (diff) | |
download | armnn-a9cca6aa935b3e290181a05fdb2c5f5557a49c09.tar.gz |
IVGCVSW-2870 Support QuantizeLayer on frontend
Change-Id: I2014a8d801f1f222d27a80dddf4f188ddcb3a5c9
Signed-off-by: Derek Lamberti <derek.lamberti@arm.com>
Diffstat (limited to 'src/armnn/test/NetworkTests.cpp')
-rw-r--r-- | src/armnn/test/NetworkTests.cpp | 51 |
1 files changed, 51 insertions, 0 deletions
diff --git a/src/armnn/test/NetworkTests.cpp b/src/armnn/test/NetworkTests.cpp index 0963df6222..4de09a2804 100644 --- a/src/armnn/test/NetworkTests.cpp +++ b/src/armnn/test/NetworkTests.cpp @@ -6,6 +6,7 @@ #include "GraphUtils.hpp" #include <armnn/ArmNN.hpp> +#include <armnn/LayerVisitorBase.hpp> #include <Network.hpp> #include <boost/test/unit_test.hpp> @@ -366,4 +367,54 @@ BOOST_AUTO_TEST_CASE(NetworkModification_SplitterMultiplication) prevLayer->GetOutputSlot(0).Connect(layer->GetInputSlot(0)); } +BOOST_AUTO_TEST_CASE(Network_AddQuantize) +{ + struct Test : public armnn::LayerVisitorBase<armnn::VisitorNoThrowPolicy> + { + void VisitQuantizeLayer(const armnn::IConnectableLayer* layer, const char* name) override + { + m_Visited = true; + + BOOST_TEST(layer); + + std::string expectedName = std::string("quantize"); + BOOST_TEST(std::string(layer->GetName()) == expectedName); + BOOST_TEST(std::string(name) == expectedName); + + BOOST_TEST(layer->GetNumInputSlots() == 1); + BOOST_TEST(layer->GetNumOutputSlots() == 1); + + const armnn::TensorInfo& infoIn = layer->GetInputSlot(0).GetConnection()->GetTensorInfo(); + BOOST_TEST((infoIn.GetDataType() == armnn::DataType::Float32)); + + const armnn::TensorInfo& infoOut = layer->GetOutputSlot(0).GetTensorInfo(); + BOOST_TEST((infoOut.GetDataType() == armnn::DataType::QuantisedAsymm8)); + } + + bool m_Visited = false; + }; + + + auto graph = armnn::INetwork::Create(); + + auto input = graph->AddInputLayer(0, "input"); + auto quantize = graph->AddQuantizeLayer("quantize"); + auto output = graph->AddOutputLayer(1, "output"); + + input->GetOutputSlot(0).Connect(quantize->GetInputSlot(0)); + quantize->GetOutputSlot(0).Connect(output->GetInputSlot(0)); + + armnn::TensorInfo infoIn({3,1}, armnn::DataType::Float32); + input->GetOutputSlot(0).SetTensorInfo(infoIn); + + armnn::TensorInfo infoOut({3,1}, armnn::DataType::QuantisedAsymm8); + quantize->GetOutputSlot(0).SetTensorInfo(infoOut); + + Test testQuantize; + graph->Accept(testQuantize); + + BOOST_TEST(testQuantize.m_Visited == true); + +} + BOOST_AUTO_TEST_SUITE_END() |