From c577f2c6a3b4ddb6ba87a882723c53a248afbeba Mon Sep 17 00:00:00 2001 From: telsoa01 Date: Fri, 31 Aug 2018 09:22:23 +0100 Subject: Release 18.08 --- .../test/GetSubgraphInputsOutputs.cpp | 230 +++++++++++++++++++++ 1 file changed, 230 insertions(+) create mode 100644 src/armnnTfLiteParser/test/GetSubgraphInputsOutputs.cpp (limited to 'src/armnnTfLiteParser/test/GetSubgraphInputsOutputs.cpp') diff --git a/src/armnnTfLiteParser/test/GetSubgraphInputsOutputs.cpp b/src/armnnTfLiteParser/test/GetSubgraphInputsOutputs.cpp new file mode 100644 index 0000000000..7e6808d11e --- /dev/null +++ b/src/armnnTfLiteParser/test/GetSubgraphInputsOutputs.cpp @@ -0,0 +1,230 @@ +// +// Copyright © 2017 Arm Ltd. All rights reserved. +// See LICENSE file in the project root for full license information. +// +#include +#include "ParserFlatbuffersFixture.hpp" +#include "../TfLiteParser.hpp" + +using armnnTfLiteParser::TfLiteParser; +using ModelPtr = TfLiteParser::ModelPtr; +using TensorRawPtr = TfLiteParser::TensorRawPtr; + +BOOST_AUTO_TEST_SUITE(TensorflowLiteParser) + +struct GetSubgraphInputsOutputsMainFixture : public ParserFlatbuffersFixture +{ + explicit GetSubgraphInputsOutputsMainFixture(const std::string& inputs, const std::string& outputs) + { + m_JsonString = R"( + { + "version": 3, + "operator_codes": [ { "builtin_code": "AVERAGE_POOL_2D" }, { "builtin_code": "CONV_2D" } ], + "subgraphs": [ + { + "tensors": [ + { + "shape": [ 1, 1, 1, 1 ] , + "type": "UINT8", + "buffer": 0, + "name": "OutputTensor", + "quantization": { + "min": [ 0.0 ], + "max": [ 255.0 ], + "scale": [ 1.0 ], + "zero_point": [ 0 ] + } + }, + { + "shape": [ 1, 2, 2, 1 ] , + "type": "UINT8", + "buffer": 1, + "name": "InputTensor", + "quantization": { + "min": [ -1.2 ], + "max": [ 25.5 ], + "scale": [ 0.25 ], + "zero_point": [ 10 ] + } + } + ], + "inputs": )" + + inputs + + R"(, + "outputs": )" + + outputs + + R"(, + "operators": [ { + "opcode_index": 0, + "inputs": [ 1 ], + "outputs": [ 0 ], + "builtin_options_type": "Pool2DOptions", + "builtin_options": + { + "padding": "VALID", + "stride_w": 2, + "stride_h": 2, + "filter_width": 2, + "filter_height": 2, + "fused_activation_function": "NONE" + }, + "custom_options_format": "FLEXBUFFERS" + } ] + }, + { + "tensors": [ + { + "shape": [ 1, 3, 3, 1 ], + "type": "UINT8", + "buffer": 0, + "name": "ConvInputTensor", + "quantization": { + "scale": [ 1.0 ], + "zero_point": [ 0 ], + } + }, + { + "shape": [ 1, 1, 1, 1 ], + "type": "UINT8", + "buffer": 1, + "name": "ConvOutputTensor", + "quantization": { + "min": [ 0.0 ], + "max": [ 511.0 ], + "scale": [ 2.0 ], + "zero_point": [ 0 ], + } + }, + { + "shape": [ 1, 3, 3, 1 ], + "type": "UINT8", + "buffer": 2, + "name": "filterTensor", + "quantization": { + "min": [ 0.0 ], + "max": [ 255.0 ], + "scale": [ 1.0 ], + "zero_point": [ 0 ], + } + } + ], + "inputs": [ 0 ], + "outputs": [ 1 ], + "operators": [ + { + "opcode_index": 0, + "inputs": [ 0, 2 ], + "outputs": [ 1 ], + "builtin_options_type": "Conv2DOptions", + "builtin_options": { + "padding": "VALID", + "stride_w": 1, + "stride_h": 1, + "fused_activation_function": "NONE" + }, + "custom_options_format": "FLEXBUFFERS" + } + ], + } + ], + "description": "Test Subgraph Inputs Outputs", + "buffers" : [ + { }, + { }, + { "data": [ 2,1,0, 6,2,1, 4,1,2 ], }, + { }, + ] + })"; + + ReadStringToBinary(); + } + +}; + +struct GetEmptySubgraphInputsOutputsFixture : GetSubgraphInputsOutputsMainFixture +{ + GetEmptySubgraphInputsOutputsFixture() : GetSubgraphInputsOutputsMainFixture("[ ]", "[ ]") {} +}; + +struct GetSubgraphInputsOutputsFixture : GetSubgraphInputsOutputsMainFixture +{ + GetSubgraphInputsOutputsFixture() : GetSubgraphInputsOutputsMainFixture("[ 1 ]", "[ 0 ]") {} +}; + +BOOST_FIXTURE_TEST_CASE(GetEmptySubgraphInputs, GetEmptySubgraphInputsOutputsFixture) +{ + TfLiteParser::ModelPtr model = TfLiteParser::LoadModelFromBinary(m_GraphBinary.data(), m_GraphBinary.size()); + TfLiteParser::TensorIdRawPtrVector subgraphTensors = TfLiteParser::GetSubgraphInputs(model, 0); + BOOST_CHECK_EQUAL(0, subgraphTensors.size()); +} + +BOOST_FIXTURE_TEST_CASE(GetEmptySubgraphOutputs, GetEmptySubgraphInputsOutputsFixture) +{ + TfLiteParser::ModelPtr model = TfLiteParser::LoadModelFromBinary(m_GraphBinary.data(), m_GraphBinary.size()); + TfLiteParser::TensorIdRawPtrVector subgraphTensors = TfLiteParser::GetSubgraphOutputs(model, 0); + BOOST_CHECK_EQUAL(0, subgraphTensors.size()); +} + +BOOST_FIXTURE_TEST_CASE(GetSubgraphInputs, GetSubgraphInputsOutputsFixture) +{ + TfLiteParser::ModelPtr model = TfLiteParser::LoadModelFromBinary(m_GraphBinary.data(), m_GraphBinary.size()); + TfLiteParser::TensorIdRawPtrVector subgraphTensors = TfLiteParser::GetSubgraphInputs(model, 0); + BOOST_CHECK_EQUAL(1, subgraphTensors.size()); + BOOST_CHECK_EQUAL(1, subgraphTensors[0].first); + CheckTensors(subgraphTensors[0].second, 4, { 1, 2, 2, 1 }, tflite::TensorType::TensorType_UINT8, 1, + "InputTensor", { -1.2f }, { 25.5f }, { 0.25f }, { 10 }); +} + +BOOST_FIXTURE_TEST_CASE(GetSubgraphOutputsSimpleQuantized, GetSubgraphInputsOutputsFixture) +{ + TfLiteParser::ModelPtr model = TfLiteParser::LoadModelFromBinary(m_GraphBinary.data(), m_GraphBinary.size()); + TfLiteParser::TensorIdRawPtrVector subgraphTensors = TfLiteParser::GetSubgraphOutputs(model, 0); + BOOST_CHECK_EQUAL(1, subgraphTensors.size()); + BOOST_CHECK_EQUAL(0, subgraphTensors[0].first); + CheckTensors(subgraphTensors[0].second, 4, { 1, 1, 1, 1 }, tflite::TensorType::TensorType_UINT8, 0, + "OutputTensor", { 0.0f }, { 255.0f }, { 1.0f }, { 0 }); +} + +BOOST_FIXTURE_TEST_CASE(GetSubgraphInputsEmptyMinMax, GetSubgraphInputsOutputsFixture) +{ + TfLiteParser::ModelPtr model = TfLiteParser::LoadModelFromBinary(m_GraphBinary.data(), m_GraphBinary.size()); + TfLiteParser::TensorIdRawPtrVector subgraphTensors = TfLiteParser::GetSubgraphInputs(model, 1); + BOOST_CHECK_EQUAL(1, subgraphTensors.size()); + BOOST_CHECK_EQUAL(0, subgraphTensors[0].first); + CheckTensors(subgraphTensors[0].second, 4, { 1, 3, 3, 1 }, tflite::TensorType::TensorType_UINT8, 0, + "ConvInputTensor", { }, { }, { 1.0f }, { 0 }); +} + +BOOST_FIXTURE_TEST_CASE(GetSubgraphOutputs, GetSubgraphInputsOutputsFixture) +{ + TfLiteParser::ModelPtr model = TfLiteParser::LoadModelFromBinary(m_GraphBinary.data(), m_GraphBinary.size()); + TfLiteParser::TensorIdRawPtrVector subgraphTensors = TfLiteParser::GetSubgraphOutputs(model, 1); + BOOST_CHECK_EQUAL(1, subgraphTensors.size()); + BOOST_CHECK_EQUAL(1, subgraphTensors[0].first); + CheckTensors(subgraphTensors[0].second, 4, { 1, 1, 1, 1 }, tflite::TensorType::TensorType_UINT8, 1, + "ConvOutputTensor", { 0.0f }, { 511.0f }, { 2.0f }, { 0 }); +} + +BOOST_AUTO_TEST_CASE(GetSubgraphInputsNullModel) +{ + BOOST_CHECK_THROW(TfLiteParser::GetSubgraphInputs(nullptr, 0), armnn::ParseException); +} + +BOOST_AUTO_TEST_CASE(GetSubgraphOutputsNullModel) +{ + BOOST_CHECK_THROW(TfLiteParser::GetSubgraphOutputs(nullptr, 0), armnn::ParseException); +} + +BOOST_FIXTURE_TEST_CASE(GetSubgraphInputsInvalidSubgraph, GetSubgraphInputsOutputsFixture) +{ + TfLiteParser::ModelPtr model = TfLiteParser::LoadModelFromBinary(m_GraphBinary.data(), m_GraphBinary.size()); + BOOST_CHECK_THROW(TfLiteParser::GetSubgraphInputs(model, 2), armnn::ParseException); +} + +BOOST_FIXTURE_TEST_CASE(GetSubgraphOutputsInvalidSubgraph, GetSubgraphInputsOutputsFixture) +{ + TfLiteParser::ModelPtr model = TfLiteParser::LoadModelFromBinary(m_GraphBinary.data(), m_GraphBinary.size()); + BOOST_CHECK_THROW(TfLiteParser::GetSubgraphOutputs(model, 2), armnn::ParseException); +} + +BOOST_AUTO_TEST_SUITE_END() \ No newline at end of file -- cgit v1.2.1