aboutsummaryrefslogtreecommitdiff
path: root/src/armnn/test/OptimizerTests.cpp
diff options
context:
space:
mode:
authornarpra01 <narumol.prangnawarat@arm.com>2019-01-16 17:22:19 +0000
committerAron Virginas-Tar <aron.virginas-tar@arm.com>2019-01-22 17:08:42 +0000
commit33f8e3b6c71070fd867809ca6934069a950081dc (patch)
tree7738f96c7108cd38eb06f780f08d1e4bfb46c080 /src/armnn/test/OptimizerTests.cpp
parent649dd9515ddf4bd00a0bff64d51dfd835a6c7b39 (diff)
downloadarmnn-33f8e3b6c71070fd867809ca6934069a950081dc.tar.gz
IVGCVSW-2509 Add GatherLayer implementation
* implementation of ValidateTensorShapesFromInputs * unit tests Change-Id: I1ed88f8ba0ea20329a259c5f36caea4b1fbeb013
Diffstat (limited to 'src/armnn/test/OptimizerTests.cpp')
-rw-r--r--src/armnn/test/OptimizerTests.cpp55
1 files changed, 55 insertions, 0 deletions
diff --git a/src/armnn/test/OptimizerTests.cpp b/src/armnn/test/OptimizerTests.cpp
index 80addb4bfd..3b079864c2 100644
--- a/src/armnn/test/OptimizerTests.cpp
+++ b/src/armnn/test/OptimizerTests.cpp
@@ -995,4 +995,59 @@ BOOST_AUTO_TEST_CASE(ResizeBilinearValidateTensorShapesFromInputsNhwc)
BOOST_CHECK_NO_THROW(graph.InferTensorInfos());
}
+
+void CreateGatherGraph(Graph& graph, const armnn::TensorInfo& paramsInfo, const armnn::TensorInfo& indicesInfo,
+ const armnn::TensorInfo& outputInfo)
+{
+ Layer* input0 = graph.AddLayer<InputLayer>(0, "params");
+ input0->GetOutputSlot().SetTensorInfo(paramsInfo);
+
+ Layer* input1 = graph.AddLayer<InputLayer>(1, "indices");
+ input1->GetOutputSlot().SetTensorInfo(indicesInfo);
+
+ GatherLayer* layer = graph.AddLayer<GatherLayer>("gather");
+ layer->GetOutputSlot().SetTensorInfo(outputInfo);
+
+ Layer* output = graph.AddLayer<OutputLayer>(0, "output");
+ input0->GetOutputSlot().Connect(layer->GetInputSlot(0));
+ input1->GetOutputSlot().Connect(layer->GetInputSlot(1));
+ layer->GetOutputSlot().Connect(output->GetInputSlot(0));
+}
+
+BOOST_AUTO_TEST_CASE(GatherValidateTensorShapesFromInputs)
+{
+ Graph graph;
+ armnn::TensorInfo paramsInfo({10, 5}, DataType::Float32);
+ armnn::TensorInfo indicesInfo({3}, DataType::Signed32);
+ armnn::TensorInfo outputInfo({3, 5}, DataType::Float32);
+
+ CreateGatherGraph(graph, paramsInfo, indicesInfo, outputInfo);
+
+ BOOST_CHECK_NO_THROW(graph.InferTensorInfos());
+}
+
+BOOST_AUTO_TEST_CASE(GatherValidateTensorShapesFromInputs1DParams)
+{
+ Graph graph;
+ armnn::TensorInfo paramsInfo({8}, DataType::Float32);
+ armnn::TensorInfo indicesInfo({5}, DataType::Signed32);
+ armnn::TensorInfo outputInfo( {5}, DataType::Float32);
+
+ CreateGatherGraph(graph, paramsInfo, indicesInfo, outputInfo);
+
+ BOOST_CHECK_NO_THROW(graph.InferTensorInfos());
+}
+
+BOOST_AUTO_TEST_CASE(GatherValidateTensorShapesFromInputsMultiDimIndices)
+{
+ Graph graph;
+ armnn::TensorInfo paramsInfo({3, 2, 5}, DataType::Float32);
+ armnn::TensorInfo indicesInfo({2, 2}, DataType::Signed32);
+ armnn::TensorInfo outputInfo({2, 2, 2, 5}, DataType::Float32);
+
+ CreateGatherGraph(graph, paramsInfo, indicesInfo, outputInfo);
+
+ BOOST_CHECK_NO_THROW(graph.InferTensorInfos());
+}
+
BOOST_AUTO_TEST_SUITE_END()