diff options
Diffstat (limited to 'src/armnnTfParser/test')
-rw-r--r-- | src/armnnTfParser/test/Split.cpp | 218 |
1 files changed, 218 insertions, 0 deletions
diff --git a/src/armnnTfParser/test/Split.cpp b/src/armnnTfParser/test/Split.cpp index bf42bf7c5d..10ff04df89 100644 --- a/src/armnnTfParser/test/Split.cpp +++ b/src/armnnTfParser/test/Split.cpp @@ -173,4 +173,222 @@ BOOST_FIXTURE_TEST_CASE(ParseSplit, InputFirstSplitFixture) { "Relu_2", { 0.25, 9.0f, 0.25f, 3.0625f } } }); } +struct SplitLastDimFixture : public armnnUtils::ParserPrototxtFixture<armnnTfParser::ITfParser> +{ + SplitLastDimFixture(bool withDimZero=false) { + m_Prototext = R"( + node { + name: "Placeholder" + op: "Placeholder" + attr { + key: "dtype" + value { + type: DT_FLOAT + } + } + attr { + key: "shape" + value { + shape { + dim { + size: 1 + } + dim { + size: 2 + } + dim { + size: 2 + } + dim { + size: 3 + } + } + } + } + } + node { + name: "Const" + op: "Const" + attr { + key: "dtype" + value { + type: DT_INT32 + } + } + attr { + key: "value" + value { + tensor { + dtype: DT_INT32 + tensor_shape { + } + int_val: 3 + } + } + } + } + node { + name: "split/split_dim" + op: "Const" + attr { + key: "dtype" + value { + type: DT_INT32 + } + } + attr { + key: "value" + value { + tensor { + dtype: DT_INT32 + tensor_shape { + } + int_val: 3 + } + } + } + } + node { + name: "split" + op: "Split" + input: "split/split_dim" + input: "Placeholder" + attr { + key: "T" + value { + type: DT_FLOAT + } + } + attr { + key: "num_split" + value { + i: 3 + } + } + } + node { + name: "sub0/y" + op: "Const" + attr { + key: "dtype" + value { + type: DT_FLOAT + } + } + attr { + key: "value" + value { + tensor { + dtype: DT_FLOAT + tensor_shape { + } + float_val: 3.0 + } + } + } + } + node { + name: "sub0" + op: "Sub" + input: "split" + input: "sub0/y" + attr { + key: "T" + value { + type: DT_FLOAT + } + } + } + node { + name: "sub1/y" + op: "Const" + attr { + key: "dtype" + value { + type: DT_FLOAT + } + } + attr { + key: "value" + value { + tensor { + dtype: DT_FLOAT + tensor_shape { + } + float_val: 2.0 + } + } + } + } + node { + name: "sub1" + op: "Sub" + input: "split:1" + input: "sub1/y" + attr { + key: "T" + value { + type: DT_FLOAT + } + } + } + node { + name: "sub2/y" + op: "Const" + attr { + key: "dtype" + value { + type: DT_FLOAT + } + } + attr { + key: "value" + value { + tensor { + dtype: DT_FLOAT + tensor_shape { + } + float_val: 1.0 + } + } + } + } + node { + name: "sub2" + op: "Sub" + input: "split:2" + input: "sub2/y" + attr { + key: "T" + value { + type: DT_FLOAT + } + } + } + versions { + producer: 27 + } )"; + + Setup( { { "Placeholder", { 1, 2, 2 , 3} } }, + { "sub0", "sub1", "sub2" }); + } +}; + +BOOST_FIXTURE_TEST_CASE(SplitLastDimTest, SplitLastDimFixture) +{ + BOOST_TEST( + (m_Parser->GetNetworkOutputBindingInfo("sub0").second.GetShape() == armnn::TensorShape({ 1, 2, 2, 1 }))); + + BOOST_TEST( + (m_Parser->GetNetworkOutputBindingInfo("sub1").second.GetShape() == armnn::TensorShape({ 1, 2, 2, 1 }))); + + BOOST_TEST( + (m_Parser->GetNetworkOutputBindingInfo("sub2").second.GetShape() == armnn::TensorShape({ 1, 2, 2, 1 }))); + + RunTest<4>({ { "Placeholder", { 1.0f, 2.0f, 3.0f, 4.0f, 5.0f, 6.0f, 7.0f, 8.0f, 9.0f, 10.0f, 11.0f, 12.0f } } }, + { { "sub0", { -2.0f, 1.0f, 4.0f, 7.0f } }, + { "sub1", { 0.0f, 3.0f, 6.0f, 9.0f } }, + { "sub2", { 2.0f, 5.0f, 8.0f, 11.0f } } }); +} + BOOST_AUTO_TEST_SUITE_END() |