aboutsummaryrefslogtreecommitdiff
path: root/src/armnnTfLiteParser/test/ReshapeDynamic.cpp
diff options
context:
space:
mode:
authorCathal Corbett <cathal.corbett@arm.com>2021-12-10 13:38:52 +0000
committerCathal Corbett <cathal.corbett@arm.com>2021-12-22 12:23:40 +0000
commitd2f7323b7ddf8f811f19ba7ae9987dcc6bf672a6 (patch)
tree175ce51982d34bc3f11d98315be434de1699de4b /src/armnnTfLiteParser/test/ReshapeDynamic.cpp
parentfcd598d3fd21d8ae9600e9e9f07e0dc8d20a23fe (diff)
downloadarmnn-d2f7323b7ddf8f811f19ba7ae9987dcc6bf672a6.tar.gz
IVGCVSW-6252 Armnn Error: Failed to parse operator #1 within
subgraph #0 error: Operator not supported * Added missing support for reshape operator in tflite parser when the target shape is dynamic and batch size is unknown * Added corresponding unit test Change-Id: I35e159c9c70440168c6092d2ad02828bb2b81cd9 Signed-off-by: Cathal Corbett <cathal.corbett@arm.com>
Diffstat (limited to 'src/armnnTfLiteParser/test/ReshapeDynamic.cpp')
-rw-r--r--src/armnnTfLiteParser/test/ReshapeDynamic.cpp497
1 files changed, 497 insertions, 0 deletions
diff --git a/src/armnnTfLiteParser/test/ReshapeDynamic.cpp b/src/armnnTfLiteParser/test/ReshapeDynamic.cpp
new file mode 100644
index 0000000000..31e23620c7
--- /dev/null
+++ b/src/armnnTfLiteParser/test/ReshapeDynamic.cpp
@@ -0,0 +1,497 @@
+//
+// Copyright © 2021 Arm Ltd and Contributors. All rights reserved.
+// SPDX-License-Identifier: MIT
+//
+
+#include "ParserFlatbuffersFixture.hpp"
+
+
+TEST_SUITE("TensorflowLiteParser_Reshape_Dynamic")
+{
+struct ReshapeDynamicFixture1 : public ParserFlatbuffersFixture
+{
+ explicit ReshapeDynamicFixture1()
+ {
+ m_JsonString = R"(
+{
+ "version": 3,
+ "operator_codes": [
+ {
+ "deprecated_builtin_code": 77,
+ "version": 1,
+ "builtin_code": "ADD"
+ },
+ {
+ "deprecated_builtin_code": 22,
+ "version": 1,
+ "builtin_code": "ADD"
+ }
+ ],
+ "subgraphs": [
+ {
+ "tensors": [
+ {
+ "shape": [
+ 2,
+ 5
+ ],
+ "type": "FLOAT32",
+ "buffer": 1,
+ "name": "input_33",
+ "quantization": {
+ "details_type": "NONE",
+ "quantized_dimension": 0
+ },
+ "is_variable": false,
+ "shape_signature": [
+ -1,
+ 10
+ ]
+ },
+ {
+ "shape": [
+ 2
+ ],
+ "type": "INT32",
+ "buffer": 2,
+ "name": "functional_15/tf_op_layer_Shape_9/Shape_9",
+ "quantization": {
+ "details_type": "NONE",
+ "quantized_dimension": 0
+ },
+ "is_variable": false
+ },
+ {
+ "shape": [
+ 2,
+ 5
+ ],
+ "type": "FLOAT32",
+ "buffer": 3,
+ "name": "Identity",
+ "quantization": {
+ "details_type": "NONE",
+ "quantized_dimension": 0
+ },
+ "is_variable": false,
+ "shape_signature": [
+ -1,
+ 5
+ ]
+ }
+ ],
+ "inputs": [
+ 0
+ ],
+ "outputs": [
+ 2
+ ],
+ "operators": [
+ {
+ "opcode_index": 0,
+ "inputs": [
+ 0
+ ],
+ "outputs": [
+ 1
+ ],
+ "builtin_options_type": "ShapeOptions",
+ "builtin_options": {
+ "out_type": "INT32"
+ },
+ "custom_options_format": "FLEXBUFFERS"
+ },
+ {
+ "opcode_index": 1,
+ "inputs": [
+ 0,
+ 1
+ ],
+ "outputs": [
+ 2
+ ],
+ "builtin_options_type": "NONE",
+ "custom_options_format": "FLEXBUFFERS"
+ }
+ ],
+ "name": "main"
+ }
+ ],
+ "description": "MLIR Converted.",
+ "buffers": [
+ {
+ },
+ {
+ },
+ {
+ },
+ {
+ },
+ {
+ "data": [
+ 49,
+ 46,
+ 49,
+ 48,
+ 46,
+ 48,
+ 0,
+ 0,
+ 0,
+ 0,
+ 0,
+ 0,
+ 0,
+ 0,
+ 0,
+ 0
+ ]
+ }
+ ],
+ "metadata": [
+ {
+ "name": "min_runtime_version",
+ "buffer": 4
+ }
+ ]
+}
+)";
+
+ }
+};
+
+// ParseReshape test case: reshapeShapes[0] == 2
+TEST_CASE_FIXTURE(ReshapeDynamicFixture1, "ParseReshapeDynamic1")
+{
+ SetupSingleInputSingleOutput("input_33", "Identity");
+ RunTest<2, armnn::DataType::Float32>(0,
+ { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 },
+ { 1, 2, 3, 4, 5,
+ 6, 7, 8, 9, 10 });
+
+ CHECK((m_Parser->GetNetworkOutputBindingInfo(0, "Identity").second.GetShape()
+ == armnn::TensorShape({2,5})));
+}
+
+struct ReshapeDynamicFixture2 : public ParserFlatbuffersFixture
+{
+ explicit ReshapeDynamicFixture2()
+ {
+ m_JsonString = R"(
+{
+ "version": 3,
+ "operator_codes": [
+ {
+ "deprecated_builtin_code": 77,
+ "version": 1,
+ "builtin_code": "ADD"
+ },
+ {
+ "deprecated_builtin_code": 22,
+ "version": 1,
+ "builtin_code": "ADD"
+ }
+ ],
+ "subgraphs": [
+ {
+ "tensors": [
+ {
+ "shape": [
+ -1,
+ 10
+ ],
+ "type": "FLOAT32",
+ "buffer": 1,
+ "name": "input_33",
+ "quantization": {
+ "details_type": "NONE",
+ "quantized_dimension": 0
+ },
+ "is_variable": false,
+ "shape_signature": [
+ 2,
+ 5
+ ]
+ },
+ {
+ "shape": [
+ 1
+ ],
+ "type": "INT32",
+ "buffer": 2,
+ "name": "functional_15/tf_op_layer_Shape_9/Shape_9",
+ "quantization": {
+ "details_type": "NONE",
+ "quantized_dimension": 0
+ },
+ "is_variable": false
+ },
+ {
+ "shape": [
+ 10
+ ],
+ "type": "FLOAT32",
+ "buffer": 3,
+ "name": "Identity",
+ "quantization": {
+ "details_type": "NONE",
+ "quantized_dimension": 0
+ },
+ "is_variable": false,
+ "shape_signature": [
+ -1,
+ 10
+ ]
+ }
+ ],
+ "inputs": [
+ 0
+ ],
+ "outputs": [
+ 2
+ ],
+ "operators": [
+ {
+ "opcode_index": 0,
+ "inputs": [
+ 0
+ ],
+ "outputs": [
+ 1
+ ],
+ "builtin_options_type": "ShapeOptions",
+ "builtin_options": {
+ "out_type": "INT32"
+ },
+ "custom_options_format": "FLEXBUFFERS"
+ },
+ {
+ "opcode_index": 1,
+ "inputs": [
+ 0,
+ 1
+ ],
+ "outputs": [
+ 2
+ ],
+ "builtin_options_type": "NONE",
+ "custom_options_format": "FLEXBUFFERS"
+ }
+ ],
+ "name": "main"
+ }
+ ],
+ "description": "MLIR Converted.",
+ "buffers": [
+ {
+ },
+ {
+ },
+ {
+ },
+ {
+ },
+ {
+ "data": [
+ 49,
+ 46,
+ 49,
+ 48,
+ 46,
+ 48,
+ 0,
+ 0,
+ 0,
+ 0,
+ 0,
+ 0,
+ 0,
+ 0,
+ 0,
+ 0
+ ]
+ }
+ ],
+ "metadata": [
+ {
+ "name": "min_runtime_version",
+ "buffer": 4
+ }
+ ]
+}
+)";
+
+ }
+};
+
+// ParseReshape test case: reshapeShapes[0] == 1
+TEST_CASE_FIXTURE(ReshapeDynamicFixture2, "ParseReshapeDynamic2")
+{
+ SetupSingleInputSingleOutput("input_33", "Identity");
+ RunTest<1, armnn::DataType::Float32>(0,
+ { 1, 2, 3, 4, 5,
+ 6, 7, 8, 9, 10 },
+ { 1, 2, 3, 4, 5, 6, 7, 8 ,9, 10 });
+ CHECK((m_Parser->GetNetworkOutputBindingInfo(0, "Identity").second.GetShape()
+ == armnn::TensorShape({10})));
+}
+
+struct ReshapeDynamicFixture3 : public ParserFlatbuffersFixture
+{
+ explicit ReshapeDynamicFixture3()
+ {
+ m_JsonString = R"(
+{
+ "version": 3,
+ "operator_codes": [
+ {
+ "deprecated_builtin_code": 77,
+ "version": 1,
+ "builtin_code": "ADD"
+ },
+ {
+ "deprecated_builtin_code": 22,
+ "version": 1,
+ "builtin_code": "ADD"
+ }
+ ],
+ "subgraphs": [
+ {
+ "tensors": [
+ {
+ "shape": [
+ 1,
+ 9
+ ],
+ "type": "FLOAT32",
+ "buffer": 1,
+ "name": "input_33",
+ "quantization": {
+ "details_type": "NONE",
+ "quantized_dimension": 0
+ },
+ "is_variable": false,
+ "shape_signature": [
+ -1,
+ 9
+ ]
+ },
+ {
+ "shape": [
+ 3
+ ],
+ "type": "INT32",
+ "buffer": 2,
+ "name": "functional_15/tf_op_layer_Shape_9/Shape_9",
+ "quantization": {
+ "details_type": "NONE",
+ "quantized_dimension": 0
+ },
+ "is_variable": false
+ },
+ {
+ "shape": [
+ 1,
+ 9
+ ],
+ "type": "FLOAT32",
+ "buffer": 3,
+ "name": "Identity",
+ "quantization": {
+ "details_type": "NONE",
+ "quantized_dimension": 0
+ },
+ "is_variable": false,
+ "shape_signature": [
+ -1,
+ 9
+ ]
+ }
+ ],
+ "inputs": [
+ 0
+ ],
+ "outputs": [
+ 2
+ ],
+ "operators": [
+ {
+ "opcode_index": 0,
+ "inputs": [
+ 0
+ ],
+ "outputs": [
+ 1
+ ],
+ "builtin_options_type": "ShapeOptions",
+ "builtin_options": {
+ "out_type": "INT32"
+ },
+ "custom_options_format": "FLEXBUFFERS"
+ },
+ {
+ "opcode_index": 1,
+ "inputs": [
+ 0,
+ 1
+ ],
+ "outputs": [
+ 2
+ ],
+ "builtin_options_type": "NONE",
+ "custom_options_format": "FLEXBUFFERS"
+ }
+ ],
+ "name": "main"
+ }
+ ],
+ "description": "MLIR Converted.",
+ "buffers": [
+ {
+ },
+ {
+ },
+ {
+ },
+ {
+ },
+ {
+ "data": [
+ 49,
+ 46,
+ 49,
+ 48,
+ 46,
+ 48,
+ 0,
+ 0,
+ 0,
+ 0,
+ 0,
+ 0,
+ 0,
+ 0,
+ 0,
+ 0
+ ]
+ }
+ ],
+ "metadata": [
+ {
+ "name": "min_runtime_version",
+ "buffer": 4
+ }
+ ]
+}
+)";
+
+ }
+};
+
+// ParseReshape test case: reshapeShapes[0] > 2
+TEST_CASE_FIXTURE(ReshapeDynamicFixture3, "ParseReshapeDynamic3")
+{
+ CHECK_THROWS_AS(SetupSingleInputSingleOutput("input_33", "Identity"), armnn::ParseException);
+}
+
+}