blob: c34df2b55781122c9264ce94ccf9a39dcea3eb5d [file] [log] [blame]
Sanghoon Lee1fad27a2018-04-05 10:57:57 +01001/*
2 * Copyright (c) 2017-2018 ARM Limited.
3 *
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/MultiImage.h"
25#include "arm_compute/runtime/NEON/functions/NEColorConvert.h"
26#include "arm_compute/runtime/Tensor.h"
27#include "arm_compute/runtime/TensorAllocator.h"
28#include "tests/NEON/Accessor.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
Sanghoon Leec7b82f12018-07-06 13:27:27 +010055const auto ColorConvert_YUYVDataset_to_RGBDataset = combine(YUYVDataset,
56 RGBDataset);
Sanghoon Leedec32a92018-06-29 10:52:57 +010057
Sanghoon Leec7b82f12018-07-06 13:27:27 +010058const auto ColorConvert_YUVPlanar_to_RGBDataset = combine(framework::dataset::make("FormatType", { Format::IYUV, Format::NV12, Format::NV21 }),
59 RGBDataset);
Sanghoon Leedec32a92018-06-29 10:52:57 +010060
Sanghoon Leec7b82f12018-07-06 13:27:27 +010061const auto ColorConvert_RGBDataset_to_NVDataset = combine(RGBDataset,
62 framework::dataset::make("FormatType", { Format::NV12, Format::IYUV, Format::YUV444 }));
63
64const auto ColorConvert_YUYVDataset_to_NVDataset = combine(YUYVDataset,
65 framework::dataset::make("FormatType", { Format::NV12, Format::IYUV }));
66
67const auto ColorConvert_NVDataset_to_YUVDataset = combine(framework::dataset::make("FormatType", { Format::NV12, Format::NV21 }),
68 framework::dataset::make("FormatType", { Format::IYUV, Format::YUV444 }));
Sanghoon Leedec32a92018-06-29 10:52:57 +010069
Sanghoon Lee1fad27a2018-04-05 10:57:57 +010070inline void validate_configuration(const TensorShape &shape, Format src_format, Format dst_format)
71{
72 const unsigned int src_num_planes = num_planes_from_format(src_format);
Sanghoon Leedec32a92018-06-29 10:52:57 +010073 const unsigned int dst_num_planes = num_planes_from_format(dst_format);
Sanghoon Lee1fad27a2018-04-05 10:57:57 +010074
Sanghoon Leedec32a92018-06-29 10:52:57 +010075 TensorShape input = adjust_odd_shape(shape, src_format);
76 input = adjust_odd_shape(input, dst_format);
Sanghoon Lee1fad27a2018-04-05 10:57:57 +010077
78 // Create tensors
Sanghoon Leedec32a92018-06-29 10:52:57 +010079 MultiImage ref_src = create_multi_image<MultiImage>(input, src_format);
80 MultiImage ref_dst = create_multi_image<MultiImage>(input, dst_format);
Sanghoon Lee1fad27a2018-04-05 10:57:57 +010081
82 // Create and Configure function
83 NEColorConvert color_convert;
84
85 if(1U == src_num_planes)
86 {
Sanghoon Leedec32a92018-06-29 10:52:57 +010087 const Tensor *src_plane = ref_src.plane(0);
Sanghoon Lee1fad27a2018-04-05 10:57:57 +010088
Sanghoon Leedec32a92018-06-29 10:52:57 +010089 if(1U == dst_num_planes)
90 {
91 Tensor *dst_plane = ref_dst.plane(0);
92 color_convert.configure(src_plane, dst_plane);
93 }
94 else
95 {
96 color_convert.configure(src_plane, &ref_dst);
97 }
Sanghoon Lee1fad27a2018-04-05 10:57:57 +010098 }
99 else
100 {
Sanghoon Leedec32a92018-06-29 10:52:57 +0100101 if(1U == dst_num_planes)
102 {
103 Tensor *dst_plane = ref_dst.plane(0);
104 color_convert.configure(&ref_src, dst_plane);
105 }
106 else
107 {
108 color_convert.configure(&ref_src, &ref_dst);
109 }
110 }
111
112 for(unsigned int plane_idx = 0; plane_idx < src_num_planes; ++plane_idx)
113 {
114 const Tensor *src_plane = ref_src.plane(plane_idx);
115
116 ARM_COMPUTE_EXPECT(src_plane->info()->is_resizable(), framework::LogLevel::ERRORS);
117 }
118 for(unsigned int plane_idx = 0; plane_idx < dst_num_planes; ++plane_idx)
119 {
120 const Tensor *dst_plane = ref_dst.plane(plane_idx);
121
122 ARM_COMPUTE_EXPECT(dst_plane->info()->is_resizable(), framework::LogLevel::ERRORS);
Sanghoon Lee1fad27a2018-04-05 10:57:57 +0100123 }
124}
125} // namespace
126
127TEST_SUITE(NEON)
128TEST_SUITE(ColorConvert)
129
Sanghoon Leedec32a92018-06-29 10:52:57 +0100130template <typename T>
131using NEColorConvertFixture = ColorConvertValidationFixture<MultiImage, Tensor, Accessor, NEColorConvert, T>;
132
Sanghoon Lee1fad27a2018-04-05 10:57:57 +0100133TEST_SUITE(Configuration)
Sanghoon Leec7b82f12018-07-06 13:27:27 +0100134DATA_TEST_CASE(RGBA, framework::DatasetMode::ALL, combine(concat(datasets::Small2DShapes(), datasets::Large2DShapes()), ColorConvert_RGBA_to_RGB),
Sanghoon Lee1fad27a2018-04-05 10:57:57 +0100135 shape, src_format, dst_format)
136{
137 validate_configuration(shape, src_format, dst_format);
138}
139
Sanghoon Leec7b82f12018-07-06 13:27:27 +0100140DATA_TEST_CASE(RGB, framework::DatasetMode::ALL, combine(concat(datasets::Small2DShapes(), datasets::Large2DShapes()), ColorConvert_RGB_to_RGBA),
Sanghoon Lee1fad27a2018-04-05 10:57:57 +0100141 shape, src_format, dst_format)
142{
143 validate_configuration(shape, src_format, dst_format);
144}
145
Sanghoon Leec7b82f12018-07-06 13:27:27 +0100146DATA_TEST_CASE(YUV, framework::DatasetMode::ALL, combine(concat(datasets::Small2DShapes(), datasets::Large2DShapes()), ColorConvert_YUYVDataset_to_RGBDataset),
Sanghoon Lee1fad27a2018-04-05 10:57:57 +0100147 shape, src_format, dst_format)
148{
149 validate_configuration(shape, src_format, dst_format);
150}
151
Sanghoon Leec7b82f12018-07-06 13:27:27 +0100152DATA_TEST_CASE(YUVPlanar, framework::DatasetMode::ALL, combine(concat(datasets::Small2DShapes(), datasets::Large2DShapes()), ColorConvert_YUVPlanar_to_RGBDataset),
Sanghoon Lee1fad27a2018-04-05 10:57:57 +0100153 shape, src_format, dst_format)
154{
155 validate_configuration(shape, src_format, dst_format);
156}
Sanghoon Lee1fad27a2018-04-05 10:57:57 +0100157
Sanghoon Leec7b82f12018-07-06 13:27:27 +0100158DATA_TEST_CASE(NV, framework::DatasetMode::ALL, combine(concat(datasets::Small2DShapes(), datasets::Large2DShapes()), ColorConvert_RGBDataset_to_NVDataset),
Sanghoon Leedec32a92018-06-29 10:52:57 +0100159 shape, src_format, dst_format)
160{
161 validate_configuration(shape, src_format, dst_format);
162}
163
Sanghoon Leec7b82f12018-07-06 13:27:27 +0100164DATA_TEST_CASE(YUYVtoNV, framework::DatasetMode::ALL, combine(concat(datasets::Small2DShapes(), datasets::Large2DShapes()), ColorConvert_YUYVDataset_to_NVDataset),
Sanghoon Leedec32a92018-06-29 10:52:57 +0100165 shape, src_format, dst_format)
166{
167 validate_configuration(shape, src_format, dst_format);
168}
169
Sanghoon Leec7b82f12018-07-06 13:27:27 +0100170DATA_TEST_CASE(NVtoYUV, framework::DatasetMode::ALL, combine(concat(datasets::Small2DShapes(), datasets::Large2DShapes()), ColorConvert_NVDataset_to_YUVDataset),
Sanghoon Leedec32a92018-06-29 10:52:57 +0100171 shape, src_format, dst_format)
172{
173 validate_configuration(shape, src_format, dst_format);
174}
175TEST_SUITE_END()
Sanghoon Lee1fad27a2018-04-05 10:57:57 +0100176
177TEST_SUITE(RGBA)
Sanghoon Leec7b82f12018-07-06 13:27:27 +0100178FIXTURE_DATA_TEST_CASE(RunSmall, NEColorConvertFixture<uint8_t>, framework::DatasetMode::PRECOMMIT, combine(datasets::Small2DShapes(), ColorConvert_RGBA_to_RGB))
Sanghoon Lee1fad27a2018-04-05 10:57:57 +0100179{
180 // Validate output
Sanghoon Leedec32a92018-06-29 10:52:57 +0100181 for(unsigned int plane_idx = 0; plane_idx < _dst_num_planes; ++plane_idx)
182 {
183 validate(Accessor(*_target.plane(plane_idx)), _reference[plane_idx]);
184 }
Sanghoon Lee1fad27a2018-04-05 10:57:57 +0100185}
Sanghoon Leedec32a92018-06-29 10:52:57 +0100186
Sanghoon Leec7b82f12018-07-06 13:27:27 +0100187FIXTURE_DATA_TEST_CASE(RunLarge, NEColorConvertFixture<uint8_t>, framework::DatasetMode::NIGHTLY, combine(datasets::Large2DShapes(), 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(Accessor(*_target.plane(plane_idx)), _reference[plane_idx]);
193 }
Sanghoon Lee1fad27a2018-04-05 10:57:57 +0100194}
195TEST_SUITE_END()
196
197TEST_SUITE(RGB)
Sanghoon Leec7b82f12018-07-06 13:27:27 +0100198FIXTURE_DATA_TEST_CASE(RunSmall, NEColorConvertFixture<uint8_t>, framework::DatasetMode::PRECOMMIT, combine(datasets::Small2DShapes(), ColorConvert_RGB_to_RGBA))
Sanghoon Lee1fad27a2018-04-05 10:57:57 +0100199{
200 // Validate output
Sanghoon Leedec32a92018-06-29 10:52:57 +0100201 for(unsigned int plane_idx = 0; plane_idx < _dst_num_planes; ++plane_idx)
202 {
203 validate(Accessor(*_target.plane(plane_idx)), _reference[plane_idx]);
204 }
Sanghoon Lee1fad27a2018-04-05 10:57:57 +0100205}
Sanghoon Leec7b82f12018-07-06 13:27:27 +0100206FIXTURE_DATA_TEST_CASE(RunLarge, NEColorConvertFixture<uint8_t>, framework::DatasetMode::NIGHTLY, combine(datasets::Large2DShapes(), ColorConvert_RGB_to_RGBA))
207{
208 // Validate output
209 for(unsigned int plane_idx = 0; plane_idx < _dst_num_planes; ++plane_idx)
210 {
211 validate(Accessor(*_target.plane(plane_idx)), _reference[plane_idx]);
212 }
213}
214TEST_SUITE_END()
215
216TEST_SUITE(YUV)
217FIXTURE_DATA_TEST_CASE(RunSmall, NEColorConvertFixture<uint8_t>, framework::DatasetMode::PRECOMMIT, combine(datasets::Small2DShapes(), ColorConvert_YUYVDataset_to_RGBDataset))
218{
219 // Validate output
220 for(unsigned int plane_idx = 0; plane_idx < _dst_num_planes; ++plane_idx)
221 {
222 validate(Accessor(*_target.plane(plane_idx)), _reference[plane_idx]);
223 }
224}
225FIXTURE_DATA_TEST_CASE(RunLarge, NEColorConvertFixture<uint8_t>, framework::DatasetMode::NIGHTLY, combine(datasets::Large2DShapes(), ColorConvert_YUYVDataset_to_RGBDataset))
226{
227 // Validate output
228 for(unsigned int plane_idx = 0; plane_idx < _dst_num_planes; ++plane_idx)
229 {
230 validate(Accessor(*_target.plane(plane_idx)), _reference[plane_idx]);
231 }
232}
233TEST_SUITE_END()
234
235TEST_SUITE(YUVPlanar)
236FIXTURE_DATA_TEST_CASE(RunSmall, NEColorConvertFixture<uint8_t>, framework::DatasetMode::PRECOMMIT, combine(datasets::Small2DShapes(), ColorConvert_YUVPlanar_to_RGBDataset))
237{
238 // Validate output
239 for(unsigned int plane_idx = 0; plane_idx < _dst_num_planes; ++plane_idx)
240 {
241 validate(Accessor(*_target.plane(plane_idx)), _reference[plane_idx]);
242 }
243}
244FIXTURE_DATA_TEST_CASE(RunLarge, NEColorConvertFixture<uint8_t>, framework::DatasetMode::NIGHTLY, combine(datasets::Large2DShapes(), ColorConvert_YUVPlanar_to_RGBDataset))
Sanghoon Lee1fad27a2018-04-05 10:57:57 +0100245{
246 // Validate output
Sanghoon Leedec32a92018-06-29 10:52:57 +0100247 for(unsigned int plane_idx = 0; plane_idx < _dst_num_planes; ++plane_idx)
248 {
249 validate(Accessor(*_target.plane(plane_idx)), _reference[plane_idx]);
250 }
251}
252TEST_SUITE_END()
253
254TEST_SUITE(NV)
Sanghoon Leec7b82f12018-07-06 13:27:27 +0100255FIXTURE_DATA_TEST_CASE(RunSmall, NEColorConvertFixture<uint8_t>, framework::DatasetMode::PRECOMMIT, combine(datasets::Small2DShapes(), ColorConvert_RGBDataset_to_NVDataset))
Sanghoon Leedec32a92018-06-29 10:52:57 +0100256{
257 // Validate output
258 for(unsigned int plane_idx = 0; plane_idx < _dst_num_planes; ++plane_idx)
259 {
260 validate(Accessor(*_target.plane(plane_idx)), _reference[plane_idx], tolerance_nv);
261 }
262}
263
Sanghoon Leec7b82f12018-07-06 13:27:27 +0100264FIXTURE_DATA_TEST_CASE(RunLarge, NEColorConvertFixture<uint8_t>, framework::DatasetMode::NIGHTLY, combine(datasets::Large2DShapes(), ColorConvert_RGBDataset_to_NVDataset))
Sanghoon Leedec32a92018-06-29 10:52:57 +0100265{
266 // Validate output
267 for(unsigned int plane_idx = 0; plane_idx < _dst_num_planes; ++plane_idx)
268 {
269 validate(Accessor(*_target.plane(plane_idx)), _reference[plane_idx], tolerance_nv);
270 }
271}
272TEST_SUITE_END()
273
Sanghoon Leec7b82f12018-07-06 13:27:27 +0100274TEST_SUITE(YUYVtoNV)
275FIXTURE_DATA_TEST_CASE(RunSmall, NEColorConvertFixture<uint8_t>, framework::DatasetMode::PRECOMMIT, combine(datasets::Small2DShapes(), ColorConvert_YUYVDataset_to_NVDataset))
Sanghoon Leedec32a92018-06-29 10:52:57 +0100276{
277 // Validate output
278 for(unsigned int plane_idx = 0; plane_idx < _dst_num_planes; ++plane_idx)
279 {
280 validate(Accessor(*_target.plane(plane_idx)), _reference[plane_idx]);
281 }
282}
283
Sanghoon Leec7b82f12018-07-06 13:27:27 +0100284FIXTURE_DATA_TEST_CASE(RunLarge, NEColorConvertFixture<uint8_t>, framework::DatasetMode::NIGHTLY, combine(datasets::Large2DShapes(), ColorConvert_YUYVDataset_to_NVDataset))
Sanghoon Leedec32a92018-06-29 10:52:57 +0100285{
286 // Validate output
287 for(unsigned int plane_idx = 0; plane_idx < _dst_num_planes; ++plane_idx)
288 {
289 validate(Accessor(*_target.plane(plane_idx)), _reference[plane_idx]);
290 }
291}
292TEST_SUITE_END()
293
294TEST_SUITE(NVtoYUV)
Sanghoon Leec7b82f12018-07-06 13:27:27 +0100295FIXTURE_DATA_TEST_CASE(RunSmall, NEColorConvertFixture<uint8_t>, framework::DatasetMode::PRECOMMIT, combine(datasets::Small2DShapes(), ColorConvert_NVDataset_to_YUVDataset))
Sanghoon Leedec32a92018-06-29 10:52:57 +0100296{
297 // Validate output
298 for(unsigned int plane_idx = 0; plane_idx < _dst_num_planes; ++plane_idx)
299 {
300 validate(Accessor(*_target.plane(plane_idx)), _reference[plane_idx]);
301 }
302}
Sanghoon Leec7b82f12018-07-06 13:27:27 +0100303FIXTURE_DATA_TEST_CASE(RunLarge, NEColorConvertFixture<uint8_t>, framework::DatasetMode::NIGHTLY, combine(datasets::Large2DShapes(), ColorConvert_NVDataset_to_YUVDataset))
Sanghoon Leedec32a92018-06-29 10:52:57 +0100304{
305 // Validate output
306 for(unsigned int plane_idx = 0; plane_idx < _dst_num_planes; ++plane_idx)
307 {
308 validate(Accessor(*_target.plane(plane_idx)), _reference[plane_idx]);
309 }
Sanghoon Lee1fad27a2018-04-05 10:57:57 +0100310}
311TEST_SUITE_END()
312
313TEST_SUITE_END()
314TEST_SUITE_END()
315} // namespace validation
316} // namespace test
317} // namespace arm_compute