blob: acfd8c34837ae3579ef8ba87e213f65fd94e408e [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-Tar5caf9072018-11-14 18:35:18 +000026 armnn::ClWorkloadFactory factory =
27 ClWorkloadFactoryHelper::GetFactory(ClWorkloadFactoryHelper::GetMemoryManager());
arovir0143095f32018-10-09 18:04:24 +010028 IsLayerSupportedTests<armnn::ClWorkloadFactory, armnn::DataType::Float16>(&factory);
29}
30
31BOOST_FIXTURE_TEST_CASE(IsLayerSupportedFloat32Cl, ClContextControlFixture)
32{
Aron Virginas-Tar5caf9072018-11-14 18:35:18 +000033 armnn::ClWorkloadFactory factory =
34 ClWorkloadFactoryHelper::GetFactory(ClWorkloadFactoryHelper::GetMemoryManager());
arovir0143095f32018-10-09 18:04:24 +010035 IsLayerSupportedTests<armnn::ClWorkloadFactory, armnn::DataType::Float32>(&factory);
36}
37
38BOOST_FIXTURE_TEST_CASE(IsLayerSupportedUint8Cl, ClContextControlFixture)
39{
Aron Virginas-Tar5caf9072018-11-14 18:35:18 +000040 armnn::ClWorkloadFactory factory =
41 ClWorkloadFactoryHelper::GetFactory(ClWorkloadFactoryHelper::GetMemoryManager());
arovir0143095f32018-10-09 18:04:24 +010042 IsLayerSupportedTests<armnn::ClWorkloadFactory, armnn::DataType::QuantisedAsymm8>(&factory);
43}
44
45BOOST_FIXTURE_TEST_CASE(IsConvertFp16ToFp32SupportedCl, ClContextControlFixture)
46{
47 std::string reasonIfUnsupported;
48
49 bool result = IsConvertLayerSupportedTests<armnn::ClWorkloadFactory, armnn::ConvertFp16ToFp32Layer,
50 armnn::DataType::Float16, armnn::DataType::Float32>(reasonIfUnsupported);
51
52 BOOST_CHECK(result);
53}
54
55BOOST_FIXTURE_TEST_CASE(IsConvertFp16ToFp32SupportedFp32InputCl, ClContextControlFixture)
56{
57 std::string reasonIfUnsupported;
58
59 bool result = IsConvertLayerSupportedTests<armnn::ClWorkloadFactory, armnn::ConvertFp16ToFp32Layer,
60 armnn::DataType::Float32, armnn::DataType::Float32>(reasonIfUnsupported);
61
62 BOOST_CHECK(!result);
63 BOOST_CHECK_EQUAL(reasonIfUnsupported, "Input should be Float16");
64}
65
66BOOST_FIXTURE_TEST_CASE(IsConvertFp16ToFp32SupportedFp16OutputCl, ClContextControlFixture)
67{
68 std::string reasonIfUnsupported;
69
70 bool result = IsConvertLayerSupportedTests<armnn::ClWorkloadFactory, armnn::ConvertFp16ToFp32Layer,
71 armnn::DataType::Float16, armnn::DataType::Float16>(reasonIfUnsupported);
72
73 BOOST_CHECK(!result);
74 BOOST_CHECK_EQUAL(reasonIfUnsupported, "Output should be Float32");
75}
76
77BOOST_FIXTURE_TEST_CASE(IsConvertFp32ToFp16SupportedCl, ClContextControlFixture)
78{
79 std::string reasonIfUnsupported;
80
81 bool result = IsConvertLayerSupportedTests<armnn::ClWorkloadFactory, armnn::ConvertFp32ToFp16Layer,
82 armnn::DataType::Float32, armnn::DataType::Float16>(reasonIfUnsupported);
83
84 BOOST_CHECK(result);
85}
86
87BOOST_FIXTURE_TEST_CASE(IsConvertFp32ToFp16SupportedFp16InputCl, ClContextControlFixture)
88{
89 std::string reasonIfUnsupported;
90
91 bool result = IsConvertLayerSupportedTests<armnn::ClWorkloadFactory, armnn::ConvertFp32ToFp16Layer,
92 armnn::DataType::Float16, armnn::DataType::Float16>(reasonIfUnsupported);
93
94 BOOST_CHECK(!result);
95 BOOST_CHECK_EQUAL(reasonIfUnsupported, "Input should be Float32");
96}
97
98BOOST_FIXTURE_TEST_CASE(IsConvertFp32ToFp16SupportedFp32OutputCl, ClContextControlFixture)
99{
100 std::string reasonIfUnsupported;
101
102 bool result = IsConvertLayerSupportedTests<armnn::ClWorkloadFactory, armnn::ConvertFp32ToFp16Layer,
103 armnn::DataType::Float32, armnn::DataType::Float32>(reasonIfUnsupported);
104
105 BOOST_CHECK(!result);
106 BOOST_CHECK_EQUAL(reasonIfUnsupported, "Output should be Float16");
107}
108
109BOOST_AUTO_TEST_SUITE_END()