| // |
| // Copyright © 2017 Arm Ltd. All rights reserved. |
| // SPDX-License-Identifier: MIT |
| // |
| |
| #include <backendsCommon/test/EndToEndTestImpl.hpp> |
| #include <backendsCommon/test/ConcatTestImpl.hpp> |
| #include <backendsCommon/test/ArithmeticTestImpl.hpp> |
| #include <backendsCommon/test/SplitterEndToEndTestImpl.hpp> |
| |
| #include <boost/test/unit_test.hpp> |
| |
| BOOST_AUTO_TEST_SUITE(ClEndToEnd) |
| |
| std::vector<armnn::BackendId> defaultBackends = {armnn::Compute::GpuAcc}; |
| |
| BOOST_AUTO_TEST_CASE(ConstantUsage_Cl_Float32) |
| { |
| ConstantUsageFloat32Test(defaultBackends); |
| } |
| |
| BOOST_AUTO_TEST_CASE(ClConcatEndToEndDim0Test) |
| { |
| ConcatDim0EndToEnd<armnn::DataType::Float32>(defaultBackends); |
| } |
| |
| BOOST_AUTO_TEST_CASE(ClConcatEndToEndDim0Uint8Test) |
| { |
| ConcatDim0EndToEnd<armnn::DataType::QuantisedAsymm8>(defaultBackends); |
| } |
| |
| BOOST_AUTO_TEST_CASE(ClConcatEndToEndDim1Test) |
| { |
| ConcatDim1EndToEnd<armnn::DataType::Float32>(defaultBackends); |
| } |
| |
| BOOST_AUTO_TEST_CASE(ClConcatEndToEndDim1Uint8Test) |
| { |
| ConcatDim1EndToEnd<armnn::DataType::QuantisedAsymm8>(defaultBackends); |
| } |
| |
| BOOST_AUTO_TEST_CASE(ClConcatEndToEndDim3Test) |
| { |
| ConcatDim3EndToEnd<armnn::DataType::Float32>(defaultBackends); |
| } |
| |
| BOOST_AUTO_TEST_CASE(ClConcatEndToEndDim3Uint8Test) |
| { |
| ConcatDim3EndToEnd<armnn::DataType::QuantisedAsymm8>(defaultBackends); |
| } |
| |
| BOOST_AUTO_TEST_CASE(ClGreaterSimpleEndToEndTest) |
| { |
| const std::vector<uint8_t> expectedOutput({ 0, 0, 0, 0, 1, 1, 1, 1, |
| 0, 0, 0, 0, 0, 0, 0, 0 }); |
| |
| ArithmeticSimpleEndToEnd<armnn::DataType::Float32, armnn::DataType::Boolean>(defaultBackends, |
| LayerType::Greater, |
| expectedOutput); |
| } |
| |
| BOOST_AUTO_TEST_CASE(ClGreaterSimpleEndToEndUint8Test) |
| { |
| const std::vector<uint8_t> expectedOutput({ 0, 0, 0, 0, 1, 1, 1, 1, |
| 0, 0, 0, 0, 0, 0, 0, 0 }); |
| |
| ArithmeticSimpleEndToEnd<armnn::DataType::QuantisedAsymm8, armnn::DataType::Boolean>(defaultBackends, |
| LayerType::Greater, |
| expectedOutput); |
| } |
| |
| BOOST_AUTO_TEST_CASE(ClGreaterBroadcastEndToEndTest) |
| { |
| const std::vector<uint8_t> expectedOutput({ 0, 1, 0, 0, 0, 1, |
| 1, 1, 1, 1, 1, 1 }); |
| |
| ArithmeticBroadcastEndToEnd<armnn::DataType::Float32, armnn::DataType::Boolean>(defaultBackends, |
| LayerType::Greater, |
| expectedOutput); |
| } |
| |
| BOOST_AUTO_TEST_CASE(ClGreaterBroadcastEndToEndUint8Test) |
| { |
| const std::vector<uint8_t> expectedOutput({ 0, 1, 0, 0, 0, 1, |
| 1, 1, 1, 1, 1, 1 }); |
| |
| ArithmeticBroadcastEndToEnd<armnn::DataType::QuantisedAsymm8, armnn::DataType::Boolean>(defaultBackends, |
| LayerType::Greater, |
| expectedOutput); |
| } |
| |
| BOOST_AUTO_TEST_CASE(ClSplitDim0EndToEndTest) |
| { |
| SplitterDim0EndToEnd<armnn::DataType::Float32>(defaultBackends); |
| } |
| |
| BOOST_AUTO_TEST_CASE(ClSplitDim1EndToEndTest) |
| { |
| SplitterDim1EndToEnd<armnn::DataType::Float32>(defaultBackends); |
| } |
| |
| BOOST_AUTO_TEST_CASE(ClSplitDim2EndToEndTest) |
| { |
| SplitterDim2EndToEnd<armnn::DataType::Float32>(defaultBackends); |
| } |
| |
| BOOST_AUTO_TEST_CASE(ClSplitDim3EndToEndTest) |
| { |
| SplitterDim3EndToEnd<armnn::DataType::Float32>(defaultBackends); |
| } |
| |
| BOOST_AUTO_TEST_CASE(ClSplitDim0EndToEndUint8Test) |
| { |
| SplitterDim0EndToEnd<armnn::DataType::QuantisedAsymm8>(defaultBackends); |
| } |
| |
| BOOST_AUTO_TEST_CASE(ClSplitDim1EndToEndUint8Test) |
| { |
| SplitterDim1EndToEnd<armnn::DataType::QuantisedAsymm8>(defaultBackends); |
| } |
| |
| BOOST_AUTO_TEST_CASE(ClSplitDim2EndToEndUint8Test) |
| { |
| SplitterDim2EndToEnd<armnn::DataType::QuantisedAsymm8>(defaultBackends); |
| } |
| |
| BOOST_AUTO_TEST_CASE(ClSplitDim3EndToEndUint8Test) |
| { |
| SplitterDim3EndToEnd<armnn::DataType::QuantisedAsymm8>(defaultBackends); |
| } |
| |
| |
| BOOST_AUTO_TEST_SUITE_END() |