blob: 2218d821efc0b45590b2e3238728308a36e7b0d6 [file] [log] [blame]
arovir0143095f32018-10-09 18:04:24 +01001//
2// Copyright © 2017 Arm Ltd. All rights reserved.
3// SPDX-License-Identifier: MIT
4//
5
Aron Virginas-Tar56055192018-11-12 18:10:43 +00006#include "ClWorkloadFactoryHelper.hpp"
7
Aron Virginas-Tarc9cc8042018-11-01 16:15:57 +00008#include <layers/ConvertFp16ToFp32Layer.hpp>
9#include <layers/ConvertFp32ToFp16Layer.hpp>
10#include <test/TensorHelpers.hpp>
arovir0143095f32018-10-09 18:04:24 +010011
Aron Virginas-Tarc9cc8042018-11-01 16:15:57 +000012#include <backendsCommon/CpuTensorHandle.hpp>
13#include <cl/ClWorkloadFactory.hpp>
14#include <cl/test/ClContextControlFixture.hpp>
15#include <backendsCommon/test/IsLayerSupportedTestImpl.hpp>
16#include <backendsCommon/test/LayerTests.hpp>
arovir0143095f32018-10-09 18:04:24 +010017
18#include <boost/test/unit_test.hpp>
19
20#include <string>
21
22BOOST_AUTO_TEST_SUITE(ClLayerSupport)
23
24BOOST_FIXTURE_TEST_CASE(IsLayerSupportedFloat16Cl, ClContextControlFixture)
25{
Aron Virginas-Tar56055192018-11-12 18:10:43 +000026 armnn::ClWorkloadFactory factory = ClWorkloadFactoryHelper::GetFactory();
arovir0143095f32018-10-09 18:04:24 +010027 IsLayerSupportedTests<armnn::ClWorkloadFactory, armnn::DataType::Float16>(&factory);
28}
29
30BOOST_FIXTURE_TEST_CASE(IsLayerSupportedFloat32Cl, ClContextControlFixture)
31{
Aron Virginas-Tar56055192018-11-12 18:10:43 +000032 armnn::ClWorkloadFactory factory = ClWorkloadFactoryHelper::GetFactory();
arovir0143095f32018-10-09 18:04:24 +010033 IsLayerSupportedTests<armnn::ClWorkloadFactory, armnn::DataType::Float32>(&factory);
34}
35
36BOOST_FIXTURE_TEST_CASE(IsLayerSupportedUint8Cl, ClContextControlFixture)
37{
Aron Virginas-Tar56055192018-11-12 18:10:43 +000038 armnn::ClWorkloadFactory factory = ClWorkloadFactoryHelper::GetFactory();
arovir0143095f32018-10-09 18:04:24 +010039 IsLayerSupportedTests<armnn::ClWorkloadFactory, armnn::DataType::QuantisedAsymm8>(&factory);
40}
41
42BOOST_FIXTURE_TEST_CASE(IsConvertFp16ToFp32SupportedCl, ClContextControlFixture)
43{
44 std::string reasonIfUnsupported;
45
46 bool result = IsConvertLayerSupportedTests<armnn::ClWorkloadFactory, armnn::ConvertFp16ToFp32Layer,
47 armnn::DataType::Float16, armnn::DataType::Float32>(reasonIfUnsupported);
48
49 BOOST_CHECK(result);
50}
51
52BOOST_FIXTURE_TEST_CASE(IsConvertFp16ToFp32SupportedFp32InputCl, ClContextControlFixture)
53{
54 std::string reasonIfUnsupported;
55
56 bool result = IsConvertLayerSupportedTests<armnn::ClWorkloadFactory, armnn::ConvertFp16ToFp32Layer,
57 armnn::DataType::Float32, armnn::DataType::Float32>(reasonIfUnsupported);
58
59 BOOST_CHECK(!result);
60 BOOST_CHECK_EQUAL(reasonIfUnsupported, "Input should be Float16");
61}
62
63BOOST_FIXTURE_TEST_CASE(IsConvertFp16ToFp32SupportedFp16OutputCl, ClContextControlFixture)
64{
65 std::string reasonIfUnsupported;
66
67 bool result = IsConvertLayerSupportedTests<armnn::ClWorkloadFactory, armnn::ConvertFp16ToFp32Layer,
68 armnn::DataType::Float16, armnn::DataType::Float16>(reasonIfUnsupported);
69
70 BOOST_CHECK(!result);
71 BOOST_CHECK_EQUAL(reasonIfUnsupported, "Output should be Float32");
72}
73
74BOOST_FIXTURE_TEST_CASE(IsConvertFp32ToFp16SupportedCl, ClContextControlFixture)
75{
76 std::string reasonIfUnsupported;
77
78 bool result = IsConvertLayerSupportedTests<armnn::ClWorkloadFactory, armnn::ConvertFp32ToFp16Layer,
79 armnn::DataType::Float32, armnn::DataType::Float16>(reasonIfUnsupported);
80
81 BOOST_CHECK(result);
82}
83
84BOOST_FIXTURE_TEST_CASE(IsConvertFp32ToFp16SupportedFp16InputCl, ClContextControlFixture)
85{
86 std::string reasonIfUnsupported;
87
88 bool result = IsConvertLayerSupportedTests<armnn::ClWorkloadFactory, armnn::ConvertFp32ToFp16Layer,
89 armnn::DataType::Float16, armnn::DataType::Float16>(reasonIfUnsupported);
90
91 BOOST_CHECK(!result);
92 BOOST_CHECK_EQUAL(reasonIfUnsupported, "Input should be Float32");
93}
94
95BOOST_FIXTURE_TEST_CASE(IsConvertFp32ToFp16SupportedFp32OutputCl, ClContextControlFixture)
96{
97 std::string reasonIfUnsupported;
98
99 bool result = IsConvertLayerSupportedTests<armnn::ClWorkloadFactory, armnn::ConvertFp32ToFp16Layer,
100 armnn::DataType::Float32, armnn::DataType::Float32>(reasonIfUnsupported);
101
102 BOOST_CHECK(!result);
103 BOOST_CHECK_EQUAL(reasonIfUnsupported, "Output should be Float16");
104}
105
106BOOST_AUTO_TEST_SUITE_END()