blob: 6bfe67b587ab183fc56f7e2be44d70752794a1f6 [file] [log] [blame]
Sanghoon Lee1fad27a2018-04-05 10:57:57 +01001/*
Michalis Spyrou80943252019-01-10 17:19:50 +00002 * Copyright (c) 2017-2019 ARM Limited.
Sanghoon Lee1fad27a2018-04-05 10:57:57 +01003 *
4 * SPDX-License-Identifier: MIT
5 *
6 * Permission is hereby granted, free of charge, to any person obtaining a copy
7 * of this software and associated documentation files (the "Software"), to
8 * deal in the Software without restriction, including without limitation the
9 * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
10 * sell copies of the Software, and to permit persons to whom the Software is
11 * furnished to do so, subject to the following conditions:
12 *
13 * The above copyright notice and this permission notice shall be included in all
14 * copies or substantial portions of the Software.
15 *
16 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
19 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
21 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
22 * SOFTWARE.
23 */
24#include "arm_compute/runtime/CL/CLMultiImage.h"
25#include "arm_compute/runtime/CL/CLTensor.h"
26#include "arm_compute/runtime/CL/CLTensorAllocator.h"
27#include "arm_compute/runtime/CL/functions/CLColorConvert.h"
28#include "tests/CL/CLAccessor.h"
29#include "tests/datasets/ShapeDatasets.h"
30#include "tests/framework/Asserts.h"
31#include "tests/framework/Macros.h"
32#include "tests/validation/Validation.h"
33#include "tests/validation/fixtures/ColorConvertFixture.h"
34
35namespace arm_compute
36{
37namespace test
38{
39namespace validation
40{
41namespace
42{
Sanghoon Leedec32a92018-06-29 10:52:57 +010043constexpr AbsoluteTolerance<uint8_t> tolerance_nv(2);
44
Sanghoon Lee1fad27a2018-04-05 10:57:57 +010045// Input data sets
Sanghoon Leec7b82f12018-07-06 13:27:27 +010046const auto RGBDataset = framework::dataset::make("FormatType", { Format::RGB888, Format::RGBA8888 });
47const auto YUYVDataset = framework::dataset::make("FormatType", { Format::YUYV422, Format::UYVY422 });
Sanghoon Lee1fad27a2018-04-05 10:57:57 +010048
Sanghoon Leec7b82f12018-07-06 13:27:27 +010049const auto ColorConvert_RGBA_to_RGB = combine(framework::dataset::make("FormatType", { Format::RGBA8888 }),
50 framework::dataset::make("FormatType", { Format::RGB888 }));
Sanghoon Lee1fad27a2018-04-05 10:57:57 +010051
Sanghoon Leec7b82f12018-07-06 13:27:27 +010052const auto ColorConvert_RGB_to_RGBA = combine(framework::dataset::make("FormatType", { Format::RGB888 }),
53 framework::dataset::make("FormatType", { Format::RGBA8888 }));
Sanghoon Lee1fad27a2018-04-05 10:57:57 +010054
Manuel Bottiniacaf21d2018-09-26 17:38:19 +010055const auto ColorConvert_RGB_to_U8 = combine(framework::dataset::make("FormatType", { Format::RGB888 }),
56 framework::dataset::make("FormatType", { Format::U8 }));
57
Sanghoon Leec7b82f12018-07-06 13:27:27 +010058const auto ColorConvert_YUYV_to_RGBDataset = combine(YUYVDataset,
59 RGBDataset);
Sanghoon Leedec32a92018-06-29 10:52:57 +010060
Sanghoon Leec7b82f12018-07-06 13:27:27 +010061const auto ColorConvert_YUVPlanar_to_RGBDataset = combine(framework::dataset::make("FormatType", { Format::IYUV, Format::NV12, Format::NV21 }),
62 RGBDataset);
Sanghoon Leedec32a92018-06-29 10:52:57 +010063
Sanghoon Leec7b82f12018-07-06 13:27:27 +010064const auto ColorConvert_RGBDataset_to_NVDataset = combine(RGBDataset,
65 framework::dataset::make("FormatType", { Format::NV12, Format::IYUV, Format::YUV444 }));
66
67const auto ColorConvert_YUYVDataset_to_NVDataset = combine(YUYVDataset,
68 framework::dataset::make("FormatType", { Format::NV12, Format::IYUV }));
69
70const auto ColorConvert_NVDataset_to_YUVDataset = combine(framework::dataset::make("FormatType", { Format::NV12, Format::NV21 }),
71 framework::dataset::make("FormatType", { Format::IYUV, Format::YUV444 }));
Sanghoon Leedec32a92018-06-29 10:52:57 +010072
Sanghoon Lee1fad27a2018-04-05 10:57:57 +010073inline void validate_configuration(const TensorShape &shape, Format src_format, Format dst_format)
74{
75 const unsigned int src_num_planes = num_planes_from_format(src_format);
Sanghoon Leedec32a92018-06-29 10:52:57 +010076 const unsigned int dst_num_planes = num_planes_from_format(dst_format);
Sanghoon Lee1fad27a2018-04-05 10:57:57 +010077
Sanghoon Leedec32a92018-06-29 10:52:57 +010078 TensorShape input = adjust_odd_shape(shape, src_format);
79 input = adjust_odd_shape(input, src_format);
Sanghoon Lee1fad27a2018-04-05 10:57:57 +010080
81 // Create tensors
Sanghoon Leedec32a92018-06-29 10:52:57 +010082 CLMultiImage ref_src = create_multi_image<CLMultiImage>(input, src_format);
83 CLMultiImage ref_dst = create_multi_image<CLMultiImage>(input, dst_format);
Sanghoon Lee1fad27a2018-04-05 10:57:57 +010084
85 // Create and Configure function
86 CLColorConvert color_convert;
87
88 if(1U == src_num_planes)
89 {
Sanghoon Leedec32a92018-06-29 10:52:57 +010090 const CLTensor *src_plane = ref_src.cl_plane(0);
Sanghoon Lee1fad27a2018-04-05 10:57:57 +010091
Sanghoon Leedec32a92018-06-29 10:52:57 +010092 if(1U == dst_num_planes)
93 {
94 CLTensor *dst_plane = ref_dst.cl_plane(0);
95 color_convert.configure(src_plane, dst_plane);
96 }
97 else
98 {
99 color_convert.configure(src_plane, &ref_dst);
100 }
Sanghoon Lee1fad27a2018-04-05 10:57:57 +0100101 }
102 else
103 {
Sanghoon Leedec32a92018-06-29 10:52:57 +0100104 if(1U == dst_num_planes)
105 {
106 CLTensor *dst_plane = ref_dst.cl_plane(0);
107 color_convert.configure(&ref_src, dst_plane);
108 }
109 else
110 {
111 color_convert.configure(&ref_src, &ref_dst);
112 }
113 }
114
115 for(unsigned int plane_idx = 0; plane_idx < src_num_planes; ++plane_idx)
116 {
117 const CLTensor *src_plane = ref_src.cl_plane(plane_idx);
118
119 ARM_COMPUTE_EXPECT(src_plane->info()->is_resizable(), framework::LogLevel::ERRORS);
120 }
121 for(unsigned int plane_idx = 0; plane_idx < dst_num_planes; ++plane_idx)
122 {
123 const CLTensor *dst_plane = ref_dst.cl_plane(plane_idx);
124
125 ARM_COMPUTE_EXPECT(dst_plane->info()->is_resizable(), framework::LogLevel::ERRORS);
Sanghoon Lee1fad27a2018-04-05 10:57:57 +0100126 }
127}
128} // namespace
129
130TEST_SUITE(CL)
131TEST_SUITE(ColorConvert)
132
Sanghoon Leedec32a92018-06-29 10:52:57 +0100133template <typename T>
134using CLColorConvertFixture = ColorConvertValidationFixture<CLMultiImage, CLTensor, CLAccessor, CLColorConvert, T>;
135
Sanghoon Lee1fad27a2018-04-05 10:57:57 +0100136TEST_SUITE(Configuration)
Michalis Spyrou80943252019-01-10 17:19:50 +0000137DATA_TEST_CASE(RGBA, framework::DatasetMode::ALL, combine(datasets::Small2DShapes(), ColorConvert_RGBA_to_RGB),
Sanghoon Lee1fad27a2018-04-05 10:57:57 +0100138 shape, src_format, dst_format)
139{
140 validate_configuration(shape, src_format, dst_format);
141}
142
Michalis Spyrou80943252019-01-10 17:19:50 +0000143DATA_TEST_CASE(RGB, framework::DatasetMode::ALL, combine(datasets::Small2DShapes(), ColorConvert_RGB_to_RGBA),
Sanghoon Lee1fad27a2018-04-05 10:57:57 +0100144 shape, src_format, dst_format)
145{
146 validate_configuration(shape, src_format, dst_format);
147}
148
Michalis Spyrou80943252019-01-10 17:19:50 +0000149DATA_TEST_CASE(RGBtoU8, framework::DatasetMode::ALL, combine(datasets::Small2DShapes(), ColorConvert_RGB_to_U8),
Manuel Bottiniacaf21d2018-09-26 17:38:19 +0100150 shape, src_format, dst_format)
151{
152 validate_configuration(shape, src_format, dst_format);
153}
154
Michalis Spyrou80943252019-01-10 17:19:50 +0000155DATA_TEST_CASE(YUV, framework::DatasetMode::ALL, combine(datasets::Small2DShapes(), ColorConvert_YUYV_to_RGBDataset),
Sanghoon Lee1fad27a2018-04-05 10:57:57 +0100156 shape, src_format, dst_format)
157{
158 validate_configuration(shape, src_format, dst_format);
159}
160
Michalis Spyrou80943252019-01-10 17:19:50 +0000161DATA_TEST_CASE(YUVPlanar, framework::DatasetMode::ALL, combine(datasets::Small2DShapes(), ColorConvert_YUVPlanar_to_RGBDataset),
Sanghoon Lee1fad27a2018-04-05 10:57:57 +0100162 shape, src_format, dst_format)
163{
164 validate_configuration(shape, src_format, dst_format);
165}
Sanghoon Lee1fad27a2018-04-05 10:57:57 +0100166
Michalis Spyrou80943252019-01-10 17:19:50 +0000167DATA_TEST_CASE(NV, framework::DatasetMode::ALL, combine(datasets::Small2DShapes(), ColorConvert_RGBDataset_to_NVDataset),
Sanghoon Leedec32a92018-06-29 10:52:57 +0100168 shape, src_format, dst_format)
169{
170 validate_configuration(shape, src_format, dst_format);
171}
172
Michalis Spyrou80943252019-01-10 17:19:50 +0000173DATA_TEST_CASE(YUYVtoNV, framework::DatasetMode::ALL, combine(datasets::Small2DShapes(), ColorConvert_YUYVDataset_to_NVDataset),
Sanghoon Leedec32a92018-06-29 10:52:57 +0100174 shape, src_format, dst_format)
175{
176 validate_configuration(shape, src_format, dst_format);
177}
178
Michalis Spyrou80943252019-01-10 17:19:50 +0000179DATA_TEST_CASE(NVtoYUV, framework::DatasetMode::ALL, combine(datasets::Small2DShapes(), ColorConvert_NVDataset_to_YUVDataset),
Sanghoon Leedec32a92018-06-29 10:52:57 +0100180 shape, src_format, dst_format)
181{
182 validate_configuration(shape, src_format, dst_format);
183}
184TEST_SUITE_END()
Sanghoon Lee1fad27a2018-04-05 10:57:57 +0100185
186TEST_SUITE(RGBA)
Sanghoon Leec7b82f12018-07-06 13:27:27 +0100187FIXTURE_DATA_TEST_CASE(RunSmall, CLColorConvertFixture<uint8_t>, framework::DatasetMode::PRECOMMIT, combine(datasets::Small2DShapes(), ColorConvert_RGBA_to_RGB))
Sanghoon Lee1fad27a2018-04-05 10:57:57 +0100188{
189 // Validate output
Sanghoon Leedec32a92018-06-29 10:52:57 +0100190 for(unsigned int plane_idx = 0; plane_idx < _dst_num_planes; ++plane_idx)
191 {
192 validate(CLAccessor(*_target.cl_plane(plane_idx)), _reference[plane_idx]);
193 }
Sanghoon Lee1fad27a2018-04-05 10:57:57 +0100194}
195
Sanghoon Leec7b82f12018-07-06 13:27:27 +0100196FIXTURE_DATA_TEST_CASE(RunLarge, CLColorConvertFixture<uint8_t>, framework::DatasetMode::NIGHTLY, combine(datasets::Large2DShapes(), ColorConvert_RGBA_to_RGB))
Sanghoon Lee1fad27a2018-04-05 10:57:57 +0100197{
198 // Validate output
Sanghoon Leedec32a92018-06-29 10:52:57 +0100199 for(unsigned int plane_idx = 0; plane_idx < _dst_num_planes; ++plane_idx)
200 {
201 validate(CLAccessor(*_target.cl_plane(plane_idx)), _reference[plane_idx]);
202 }
Sanghoon Lee1fad27a2018-04-05 10:57:57 +0100203}
204TEST_SUITE_END()
205
206TEST_SUITE(RGB)
Sanghoon Leec7b82f12018-07-06 13:27:27 +0100207FIXTURE_DATA_TEST_CASE(RunSmall, CLColorConvertFixture<uint8_t>, framework::DatasetMode::PRECOMMIT, combine(datasets::Small2DShapes(), ColorConvert_RGB_to_RGBA))
Sanghoon Lee1fad27a2018-04-05 10:57:57 +0100208{
209 // Validate output
Sanghoon Leedec32a92018-06-29 10:52:57 +0100210 for(unsigned int plane_idx = 0; plane_idx < _dst_num_planes; ++plane_idx)
211 {
212 validate(CLAccessor(*_target.cl_plane(plane_idx)), _reference[plane_idx]);
213 }
Sanghoon Lee1fad27a2018-04-05 10:57:57 +0100214}
Sanghoon Leec7b82f12018-07-06 13:27:27 +0100215FIXTURE_DATA_TEST_CASE(RunLarge, CLColorConvertFixture<uint8_t>, framework::DatasetMode::NIGHTLY, combine(datasets::Large2DShapes(), ColorConvert_RGB_to_RGBA))
216{
217 // Validate output
218 for(unsigned int plane_idx = 0; plane_idx < _dst_num_planes; ++plane_idx)
219 {
220 validate(CLAccessor(*_target.cl_plane(plane_idx)), _reference[plane_idx]);
221 }
222}
223TEST_SUITE_END()
224
Manuel Bottiniacaf21d2018-09-26 17:38:19 +0100225TEST_SUITE(RGBtoU8)
226FIXTURE_DATA_TEST_CASE(RunSmall, CLColorConvertFixture<uint8_t>, framework::DatasetMode::PRECOMMIT, combine(datasets::Small2DShapes(), ColorConvert_RGB_to_U8))
227{
228 // Validate output
229 for(unsigned int plane_idx = 0; plane_idx < _dst_num_planes; ++plane_idx)
230 {
231 validate(CLAccessor(*_target.cl_plane(plane_idx)), _reference[plane_idx]);
232 }
233}
234FIXTURE_DATA_TEST_CASE(RunLarge, CLColorConvertFixture<uint8_t>, framework::DatasetMode::NIGHTLY, combine(datasets::Large2DShapes(), ColorConvert_RGB_to_U8))
235{
236 // Validate output
237 for(unsigned int plane_idx = 0; plane_idx < _dst_num_planes; ++plane_idx)
238 {
239 validate(CLAccessor(*_target.cl_plane(plane_idx)), _reference[plane_idx]);
240 }
241}
242TEST_SUITE_END()
243
Sanghoon Leec7b82f12018-07-06 13:27:27 +0100244TEST_SUITE(YUV)
245FIXTURE_DATA_TEST_CASE(RunSmall, CLColorConvertFixture<uint8_t>, framework::DatasetMode::PRECOMMIT, combine(datasets::Small2DShapes(), ColorConvert_YUYV_to_RGBDataset))
246{
247 // Validate output
248 for(unsigned int plane_idx = 0; plane_idx < _dst_num_planes; ++plane_idx)
249 {
250 validate(CLAccessor(*_target.cl_plane(plane_idx)), _reference[plane_idx]);
251 }
252}
253FIXTURE_DATA_TEST_CASE(RunLarge, CLColorConvertFixture<uint8_t>, framework::DatasetMode::NIGHTLY, combine(datasets::Large2DShapes(), ColorConvert_YUYV_to_RGBDataset))
254{
255 // Validate output
256 for(unsigned int plane_idx = 0; plane_idx < _dst_num_planes; ++plane_idx)
257 {
258 validate(CLAccessor(*_target.cl_plane(plane_idx)), _reference[plane_idx]);
259 }
260}
261TEST_SUITE_END()
262
263TEST_SUITE(YUVPlanar)
264FIXTURE_DATA_TEST_CASE(RunSmall, CLColorConvertFixture<uint8_t>, framework::DatasetMode::PRECOMMIT, combine(datasets::Small2DShapes(), ColorConvert_YUVPlanar_to_RGBDataset))
265{
266 // Validate output
267 for(unsigned int plane_idx = 0; plane_idx < _dst_num_planes; ++plane_idx)
268 {
269 validate(CLAccessor(*_target.cl_plane(plane_idx)), _reference[plane_idx]);
270 }
271}
272FIXTURE_DATA_TEST_CASE(RunLarge, CLColorConvertFixture<uint8_t>, framework::DatasetMode::NIGHTLY, combine(datasets::Large2DShapes(), ColorConvert_YUVPlanar_to_RGBDataset))
Sanghoon Lee1fad27a2018-04-05 10:57:57 +0100273{
274 // Validate output
Sanghoon Leedec32a92018-06-29 10:52:57 +0100275 for(unsigned int plane_idx = 0; plane_idx < _dst_num_planes; ++plane_idx)
276 {
277 validate(CLAccessor(*_target.cl_plane(plane_idx)), _reference[plane_idx]);
278 }
Sanghoon Lee1fad27a2018-04-05 10:57:57 +0100279}
280TEST_SUITE_END()
Sanghoon Leedec32a92018-06-29 10:52:57 +0100281
282TEST_SUITE(NV)
Sanghoon Leec7b82f12018-07-06 13:27:27 +0100283FIXTURE_DATA_TEST_CASE(RunSmall, CLColorConvertFixture<uint8_t>, framework::DatasetMode::PRECOMMIT, combine(datasets::Small2DShapes(), ColorConvert_RGBDataset_to_NVDataset))
Sanghoon Leedec32a92018-06-29 10:52:57 +0100284{
285 // Validate output
286 for(unsigned int plane_idx = 0; plane_idx < _dst_num_planes; ++plane_idx)
287 {
288 validate(CLAccessor(*_target.cl_plane(plane_idx)), _reference[plane_idx], tolerance_nv);
289 }
290}
Sanghoon Leec7b82f12018-07-06 13:27:27 +0100291FIXTURE_DATA_TEST_CASE(RunLarge, CLColorConvertFixture<uint8_t>, framework::DatasetMode::NIGHTLY, combine(datasets::Large2DShapes(), ColorConvert_RGBDataset_to_NVDataset))
Sanghoon Leedec32a92018-06-29 10:52:57 +0100292{
293 // Validate output
294 for(unsigned int plane_idx = 0; plane_idx < _dst_num_planes; ++plane_idx)
295 {
296 validate(CLAccessor(*_target.cl_plane(plane_idx)), _reference[plane_idx], tolerance_nv);
297 }
298}
299TEST_SUITE_END()
300
301TEST_SUITE(YUYVtoNV)
Sanghoon Leec7b82f12018-07-06 13:27:27 +0100302FIXTURE_DATA_TEST_CASE(RunSmall, CLColorConvertFixture<uint8_t>, framework::DatasetMode::PRECOMMIT, combine(datasets::Small2DShapes(), ColorConvert_YUYVDataset_to_NVDataset))
Sanghoon Leedec32a92018-06-29 10:52:57 +0100303{
304 // Validate output
305 for(unsigned int plane_idx = 0; plane_idx < _dst_num_planes; ++plane_idx)
306 {
307 validate(CLAccessor(*_target.cl_plane(plane_idx)), _reference[plane_idx]);
308 }
309}
Sanghoon Leec7b82f12018-07-06 13:27:27 +0100310FIXTURE_DATA_TEST_CASE(RunLarge, CLColorConvertFixture<uint8_t>, framework::DatasetMode::NIGHTLY, combine(datasets::Large2DShapes(), ColorConvert_YUYVDataset_to_NVDataset))
Sanghoon Leedec32a92018-06-29 10:52:57 +0100311{
312 // Validate output
313 for(unsigned int plane_idx = 0; plane_idx < _dst_num_planes; ++plane_idx)
314 {
315 validate(CLAccessor(*_target.cl_plane(plane_idx)), _reference[plane_idx]);
316 }
317}
318
319TEST_SUITE_END()
320
321TEST_SUITE(NVtoYUV)
Sanghoon Leec7b82f12018-07-06 13:27:27 +0100322FIXTURE_DATA_TEST_CASE(RunSmall, CLColorConvertFixture<uint8_t>, framework::DatasetMode::PRECOMMIT, combine(datasets::Small2DShapes(), ColorConvert_NVDataset_to_YUVDataset))
Sanghoon Leedec32a92018-06-29 10:52:57 +0100323{
324 // Validate output
325 for(unsigned int plane_idx = 0; plane_idx < _dst_num_planes; ++plane_idx)
326 {
327 validate(CLAccessor(*_target.cl_plane(plane_idx)), _reference[plane_idx]);
328 }
329}
Sanghoon Leec7b82f12018-07-06 13:27:27 +0100330FIXTURE_DATA_TEST_CASE(RunLarge, CLColorConvertFixture<uint8_t>, framework::DatasetMode::NIGHTLY, combine(datasets::Large2DShapes(), ColorConvert_NVDataset_to_YUVDataset))
Sanghoon Leedec32a92018-06-29 10:52:57 +0100331{
332 // Validate output
333 for(unsigned int plane_idx = 0; plane_idx < _dst_num_planes; ++plane_idx)
334 {
335 validate(CLAccessor(*_target.cl_plane(plane_idx)), _reference[plane_idx]);
336 }
337}
338
339TEST_SUITE_END()
340
Sanghoon Lee1fad27a2018-04-05 10:57:57 +0100341TEST_SUITE_END()
342TEST_SUITE_END()
343} // namespace validation
344} // namespace test
345} // namespace arm_compute