2 // Copyright © 2017 Arm Ltd. All rights reserved.
3 // SPDX-License-Identifier: MIT
6 #include <layers/ConvertFp16ToFp32Layer.hpp>
7 #include <layers/ConvertFp32ToFp16Layer.hpp>
8 #include <test/TensorHelpers.hpp>
10 #include <backendsCommon/CpuTensorHandle.hpp>
11 #include <cl/ClWorkloadFactory.hpp>
12 #include <cl/test/ClContextControlFixture.hpp>
13 #include <backendsCommon/test/IsLayerSupportedTestImpl.hpp>
14 #include <backendsCommon/test/LayerTests.hpp>
16 #include <boost/test/unit_test.hpp>
20 BOOST_AUTO_TEST_SUITE(ClLayerSupport)
22 BOOST_FIXTURE_TEST_CASE(IsLayerSupportedFloat16Cl, ClContextControlFixture)
24 armnn::ClWorkloadFactory factory;
25 IsLayerSupportedTests<armnn::ClWorkloadFactory, armnn::DataType::Float16>(&factory);
28 BOOST_FIXTURE_TEST_CASE(IsLayerSupportedFloat32Cl, ClContextControlFixture)
30 armnn::ClWorkloadFactory factory;
31 IsLayerSupportedTests<armnn::ClWorkloadFactory, armnn::DataType::Float32>(&factory);
34 BOOST_FIXTURE_TEST_CASE(IsLayerSupportedUint8Cl, ClContextControlFixture)
36 armnn::ClWorkloadFactory factory;
37 IsLayerSupportedTests<armnn::ClWorkloadFactory, armnn::DataType::QuantisedAsymm8>(&factory);
40 BOOST_FIXTURE_TEST_CASE(IsConvertFp16ToFp32SupportedCl, ClContextControlFixture)
42 std::string reasonIfUnsupported;
44 bool result = IsConvertLayerSupportedTests<armnn::ClWorkloadFactory, armnn::ConvertFp16ToFp32Layer,
45 armnn::DataType::Float16, armnn::DataType::Float32>(reasonIfUnsupported);
50 BOOST_FIXTURE_TEST_CASE(IsConvertFp16ToFp32SupportedFp32InputCl, ClContextControlFixture)
52 std::string reasonIfUnsupported;
54 bool result = IsConvertLayerSupportedTests<armnn::ClWorkloadFactory, armnn::ConvertFp16ToFp32Layer,
55 armnn::DataType::Float32, armnn::DataType::Float32>(reasonIfUnsupported);
58 BOOST_CHECK_EQUAL(reasonIfUnsupported, "Input should be Float16");
61 BOOST_FIXTURE_TEST_CASE(IsConvertFp16ToFp32SupportedFp16OutputCl, ClContextControlFixture)
63 std::string reasonIfUnsupported;
65 bool result = IsConvertLayerSupportedTests<armnn::ClWorkloadFactory, armnn::ConvertFp16ToFp32Layer,
66 armnn::DataType::Float16, armnn::DataType::Float16>(reasonIfUnsupported);
69 BOOST_CHECK_EQUAL(reasonIfUnsupported, "Output should be Float32");
72 BOOST_FIXTURE_TEST_CASE(IsConvertFp32ToFp16SupportedCl, ClContextControlFixture)
74 std::string reasonIfUnsupported;
76 bool result = IsConvertLayerSupportedTests<armnn::ClWorkloadFactory, armnn::ConvertFp32ToFp16Layer,
77 armnn::DataType::Float32, armnn::DataType::Float16>(reasonIfUnsupported);
82 BOOST_FIXTURE_TEST_CASE(IsConvertFp32ToFp16SupportedFp16InputCl, ClContextControlFixture)
84 std::string reasonIfUnsupported;
86 bool result = IsConvertLayerSupportedTests<armnn::ClWorkloadFactory, armnn::ConvertFp32ToFp16Layer,
87 armnn::DataType::Float16, armnn::DataType::Float16>(reasonIfUnsupported);
90 BOOST_CHECK_EQUAL(reasonIfUnsupported, "Input should be Float32");
93 BOOST_FIXTURE_TEST_CASE(IsConvertFp32ToFp16SupportedFp32OutputCl, ClContextControlFixture)
95 std::string reasonIfUnsupported;
97 bool result = IsConvertLayerSupportedTests<armnn::ClWorkloadFactory, armnn::ConvertFp32ToFp16Layer,
98 armnn::DataType::Float32, armnn::DataType::Float32>(reasonIfUnsupported);
100 BOOST_CHECK(!result);
101 BOOST_CHECK_EQUAL(reasonIfUnsupported, "Output should be Float16");
104 BOOST_AUTO_TEST_SUITE_END()