1 // This file is part of OpenCV project.
2 // It is subject to the license terms in the LICENSE file found in the top-level directory
3 // of this distribution and at http://opencv.org/license.html.
5 // Copyright (C) 2018-2019 Intel Corporation
8 #include "../test_precomp.hpp"
9 #include "../common/gapi_core_tests.hpp"
14 #define CORE_FLUID cv::gapi::core::fluid::kernels()
17 // FIXME: Windows accuracy problems after recent update!
18 INSTANTIATE_TEST_CASE_P(MathOpTestFluid, MathOpTest,
19 Combine(Values(ADD, SUB, DIV, MUL),
21 Values(CV_8UC3, CV_8UC1, CV_16SC1, CV_32FC1),
23 Values(cv::Size(1920, 1080),
27 Values(-1, CV_8U, CV_32F),
30 Values(cv::compile_args(CORE_FLUID))),
31 opencv_test::PrintMathOpCoreParams());
33 INSTANTIATE_TEST_CASE_P(MulSTestFluid, MulDoubleTest,
34 Combine(Values(CV_8UC1, CV_16SC1, CV_32FC1),
35 Values(cv::Size(1280, 720),
38 Values(-1), // FIXME: extend with more types
40 Values(cv::compile_args(CORE_FLUID))));
42 INSTANTIATE_TEST_CASE_P(DivCTestFluid, DivCTest,
43 Combine(Values(CV_8UC1, CV_16SC1, CV_32FC1),
44 Values(cv::Size(1280, 720),
47 Values(CV_8U, CV_32F),
49 Values(cv::compile_args(CORE_FLUID))));
51 INSTANTIATE_TEST_CASE_P(AbsDiffTestFluid, AbsDiffTest,
52 Combine(Values(CV_8UC1, CV_16UC1, CV_16SC1),
53 Values(cv::Size(1280, 720),
57 Values(cv::compile_args(CORE_FLUID))));
59 INSTANTIATE_TEST_CASE_P(AbsDiffCTestFluid, AbsDiffCTest,
60 Combine(Values(CV_8UC1, CV_16UC1, CV_16SC1),
61 Values(cv::Size(1280, 720),
65 Values(cv::compile_args(CORE_FLUID))));
67 INSTANTIATE_TEST_CASE_P(BitwiseTestFluid, BitwiseTest,
68 Combine(Values(AND, OR, XOR),
69 Values(CV_8UC3, CV_8UC1, CV_16UC1, CV_16SC1),
70 Values(cv::Size(1920, 1080),
75 Values(cv::compile_args(CORE_FLUID))),
76 opencv_test::PrintBWCoreParams());
78 INSTANTIATE_TEST_CASE_P(BitwiseNotTestFluid, NotTest,
79 Combine(Values(CV_8UC3, CV_8UC1, CV_16UC1, CV_16SC1),
80 Values(cv::Size(1920, 1080),
85 Values(cv::compile_args(CORE_FLUID))));
87 INSTANTIATE_TEST_CASE_P(MinTestFluid, MinTest,
88 Combine(Values(CV_8UC3, CV_8UC1, CV_16UC1, CV_16SC1, CV_32FC1),
89 Values(cv::Size(1920, 1080),
94 Values(cv::compile_args(CORE_FLUID))));
96 INSTANTIATE_TEST_CASE_P(MaxTestFluid, MaxTest,
97 Combine(Values(CV_8UC3, CV_8UC1, CV_16UC1, CV_16SC1, CV_32FC1),
98 Values(cv::Size(1920, 1080),
103 Values(cv::compile_args(CORE_FLUID))));
105 INSTANTIATE_TEST_CASE_P(CompareTestFluid, CmpTest,
106 Combine(Values(CMP_EQ, CMP_GE, CMP_NE, CMP_GT, CMP_LT, CMP_LE),
108 Values(CV_8UC3, CV_8UC1, CV_16SC1, CV_32FC1),
109 Values(cv::Size(1920, 1080),
114 Values(cv::compile_args(CORE_FLUID))),
115 opencv_test::PrintCmpCoreParams());
117 INSTANTIATE_TEST_CASE_P(AddWeightedTestFluid, AddWeightedTest,
118 Combine(Values(CV_8UC1, CV_16UC1, CV_16SC1),
119 Values(cv::Size(1280, 720),
122 Values(-1, CV_8U, CV_32F),
124 Values(Tolerance_FloatRel_IntAbs(1e-5, 2).to_compare_f()),
126 Values(cv::compile_args(CORE_FLUID))));
128 INSTANTIATE_TEST_CASE_P(LUTTestFluid, LUTTest,
129 Combine(Values(CV_8UC1, CV_8UC3),
131 Values(cv::Size(1920, 1080),
136 Values(cv::compile_args(CORE_FLUID))));
138 INSTANTIATE_TEST_CASE_P(ConvertToFluid, ConvertToTest,
139 Combine(Values(CV_8UC3, CV_8UC1, CV_16UC1, CV_32FC1),
140 Values(CV_8U, CV_16U, CV_32F),
141 Values(cv::Size(1920, 1080),
145 Values(cv::compile_args(CORE_FLUID))));
147 INSTANTIATE_TEST_CASE_P(Split3TestFluid, Split3Test,
148 Combine(Values(cv::Size(1280, 720),
151 Values(cv::compile_args(CORE_FLUID))));
153 INSTANTIATE_TEST_CASE_P(Split4TestFluid, Split4Test,
154 Combine(Values(cv::Size(1280, 720),
157 Values(cv::compile_args(CORE_FLUID))));
159 INSTANTIATE_TEST_CASE_P(Merge3TestFluid, Merge3Test,
160 Combine(Values(cv::Size(1920, 1080),
164 Values(cv::compile_args(CORE_FLUID))));
166 INSTANTIATE_TEST_CASE_P(Merge4TestFluid, Merge4Test,
167 Combine(Values(cv::Size(1920, 1080),
171 Values(cv::compile_args(CORE_FLUID))));
173 INSTANTIATE_TEST_CASE_P(SelectTestFluid, SelectTest,
174 Combine(Values(CV_8UC3, CV_8UC1, CV_16UC1, CV_16SC1),
175 Values(cv::Size(1920, 1080),
180 Values(cv::compile_args(CORE_FLUID))));
182 INSTANTIATE_TEST_CASE_P(Polar2CartFluid, Polar2CartTest,
183 Combine(Values(cv::Size(1280, 720),
187 Values(cv::compile_args(CORE_FLUID))));
189 INSTANTIATE_TEST_CASE_P(Cart2PolarFluid, Cart2PolarTest,
190 Combine(Values(cv::Size(1280, 720),
194 Values(cv::compile_args(CORE_FLUID))));
196 INSTANTIATE_TEST_CASE_P(PhaseFluid, PhaseTest,
197 Combine(Values(CV_32F, CV_32FC3),
198 Values(cv::Size(1280, 720),
202 Values(cv::compile_args(CORE_FLUID))));
204 INSTANTIATE_TEST_CASE_P(SqrtFluid, SqrtTest,
205 Combine(Values(CV_32F, CV_32FC3),
206 Values(cv::Size(1280, 720),
209 Values(cv::compile_args(CORE_FLUID))));
211 INSTANTIATE_TEST_CASE_P(ThresholdTestFluid, ThresholdTest,
212 Combine(Values(CV_8UC3, CV_8UC1, CV_16UC1, CV_16SC1),
213 Values(cv::Size(1920, 1080),
217 Values(cv::THRESH_BINARY, cv::THRESH_BINARY_INV,
219 cv::THRESH_TOZERO, cv::THRESH_TOZERO_INV),
221 Values(cv::compile_args(CORE_FLUID))));
223 INSTANTIATE_TEST_CASE_P(InRangeTestFluid, InRangeTest,
224 Combine(Values(CV_8UC3, CV_8UC1, CV_16UC1, CV_16SC1, CV_32FC1),
225 Values(cv::Size(1920, 1080),
230 Values(cv::compile_args(CORE_FLUID))));
232 INSTANTIATE_TEST_CASE_P(
233 ResizeTestFluid, ResizeTest,
234 Combine(Values(AbsExact().to_compare_f()),
235 Values(CV_8UC3/*CV_8UC1, CV_16UC1, CV_16SC1*/),
236 Values(/*cv::INTER_NEAREST,*/ cv::INTER_LINEAR/*, cv::INTER_AREA*/),
237 Values(cv::Size(1280, 720),
242 Values(cv::Size(1280, 720),
247 Values(cv::compile_args(CORE_FLUID))));
249 //----------------------------------------------------------------------
250 // FIXME: Clean-up test configurations which are enabled already
252 INSTANTIATE_TEST_CASE_P(MathOpTestCPU, MathOpTest,
253 Combine(Values(ADD, DIV, MUL),
255 Values(CV_8UC1, CV_16SC1, CV_32FC1),
256 Values(cv::Size(1280, 720),
259 Values(-1, CV_8U, CV_32F),
260 /*init output matrices or not*/ testing::Bool(),
262 opencv_test::PrintMathOpCoreParams());
264 INSTANTIATE_TEST_CASE_P(SubTestCPU, MathOpTest,
267 Values(CV_8UC1, CV_16SC1 , CV_32FC1),
268 Values(cv::Size(1280, 720),
271 Values(-1, CV_8U, CV_32F),
272 /*init output matrices or not*/ testing::Bool(),
274 opencv_test::PrintMathOpCoreParams());
276 INSTANTIATE_TEST_CASE_P(MulSTestCPU, MulSTest,
277 Combine(Values(CV_8UC1, CV_16SC1, CV_32FC1),
278 Values(cv::Size(1280, 720),
281 /*init output matrices or not*/ testing::Bool()));
283 INSTANTIATE_TEST_CASE_P(DivCTestCPU, DivCTest,
284 Combine(Values(CV_8UC1, CV_16SC1, CV_32FC1),
285 Values(cv::Size(1280, 720),
288 Values(CV_8U, CV_32F),
289 /*init output matrices or not*/ testing::Bool()));
291 INSTANTIATE_TEST_CASE_P(MeanTestCPU, MeanTest,
292 Combine(Values(CV_8UC1, CV_16UC1, CV_16SC1),
293 Values(cv::Size(1280, 720),
296 /*init output matrices or not*/ testing::Bool()));
298 INSTANTIATE_TEST_CASE_P(SelectTestCPU, SelectTest,
299 Combine(Values(CV_8UC1, CV_16UC1, CV_16SC1),
300 Values(cv::Size(1280, 720),
303 /*init output matrices or not*/ testing::Bool()));
305 INSTANTIATE_TEST_CASE_P(Polar2CartCPU, Polar2CartTest,
306 Combine(Values(cv::Size(1280, 720),
309 /*init output matrices or not*/ testing::Bool()));
311 INSTANTIATE_TEST_CASE_P(Cart2PolarCPU, Cart2PolarTest,
312 Combine(Values(cv::Size(1280, 720),
315 /*init output matrices or not*/ testing::Bool()));
317 INSTANTIATE_TEST_CASE_P(CompareTestCPU, CmpTest,
318 Combine(Values(CMP_EQ, CMP_GE, CMP_NE, CMP_GT, CMP_LT, CMP_LE),
320 Values(CV_8UC1, CV_16SC1, CV_32FC1),
321 Values(cv::Size(1280, 720),
324 /*init output matrices or not*/ testing::Bool()),
325 opencv_test::PrintCmpCoreParams());
327 INSTANTIATE_TEST_CASE_P(BitwiseTestCPU, BitwiseTest,
328 Combine(Values(AND, OR, XOR),
329 Values(CV_8UC1, CV_16UC1, CV_16SC1),
330 Values(cv::Size(1280, 720),
333 /*init output matrices or not*/ testing::Bool()),
334 opencv_test::PrintBWCoreParams());
336 INSTANTIATE_TEST_CASE_P(BitwiseNotTestCPU, NotTest,
337 Combine(Values(CV_8UC1, CV_16UC1, CV_16SC1),
338 Values(cv::Size(1280, 720),
341 /*init output matrices or not*/ testing::Bool()));
343 INSTANTIATE_TEST_CASE_P(MinTestCPU, MinTest,
344 Combine(Values(CV_8UC1, CV_16UC1, CV_16SC1),
345 Values(cv::Size(1280, 720),
348 /*init output matrices or not*/ testing::Bool()));
350 INSTANTIATE_TEST_CASE_P(MaxTestCPU, MaxTest,
351 Combine(Values(CV_8UC1, CV_16UC1, CV_16SC1),
352 Values(cv::Size(1280, 720),
355 /*init output matrices or not*/ testing::Bool()));
357 INSTANTIATE_TEST_CASE_P(SumTestCPU, SumTest,
358 Combine(Values(CV_8UC1, CV_16UC1, CV_16SC1),
359 Values(cv::Size(1280, 720),
362 /*init output matrices or not*/ testing::Bool())
366 INSTANTIATE_TEST_CASE_P(AbsDiffTestCPU, AbsDiffTest,
367 Combine(Values(CV_8UC1, CV_16UC1, CV_16SC1),
368 Values(cv::Size(1280, 720),
371 /*init output matrices or not*/ testing::Bool()));
373 INSTANTIATE_TEST_CASE_P(AbsDiffCTestCPU, AbsDiffCTest,
374 Combine(Values(CV_8UC1, CV_16UC1, CV_16SC1),
375 Values(cv::Size(1280, 720),
378 /*init output matrices or not*/ testing::Bool()));
380 INSTANTIATE_TEST_CASE_P(AddWeightedTestCPU, AddWeightedTest,
381 Combine(Values(CV_8UC1, CV_16UC1, CV_16SC1),
382 Values(cv::Size(1280, 720),
385 Values(-1, CV_8U, CV_32F),
386 /*init output matrices or not*/ testing::Bool()));
388 INSTANTIATE_TEST_CASE_P(NormTestCPU, NormTest,
389 Combine(Values(NORM_INF, NORM_L1, NORM_L2),
390 Values(CV_8UC1, CV_16UC1, CV_16SC1),
391 Values(cv::Size(1280, 720),
393 cv::Size(128, 128))),
395 opencv_test::PrintNormCoreParams());
397 INSTANTIATE_TEST_CASE_P(IntegralTestCPU, IntegralTest,
398 Combine(Values(CV_8UC1, CV_16UC1, CV_16SC1),
399 Values(cv::Size(1280, 720),
401 cv::Size(128, 128))));
403 INSTANTIATE_TEST_CASE_P(ThresholdTestCPU, ThresholdTest,
404 Combine(Values(CV_8UC1, CV_16UC1, CV_16SC1),
405 Values(cv::Size(1280, 720),
408 Values(cv::THRESH_BINARY, cv::THRESH_BINARY_INV, cv::THRESH_TRUNC, cv::THRESH_TOZERO, cv::THRESH_TOZERO_INV),
409 /*init output matrices or not*/ testing::Bool()));
411 INSTANTIATE_TEST_CASE_P(ThresholdTestCPU, ThresholdOTTest,
412 Combine(Values(CV_8UC1),
413 Values(cv::Size(1280, 720),
416 Values(cv::THRESH_OTSU, cv::THRESH_TRIANGLE),
417 /*init output matrices or not*/ testing::Bool()));
420 INSTANTIATE_TEST_CASE_P(InRangeTestCPU, InRangeTest,
421 Combine(Values(CV_8UC1, CV_16UC1, CV_16SC1),
422 Values(cv::Size(1280, 720),
425 /*init output matrices or not*/ testing::Bool()));
427 INSTANTIATE_TEST_CASE_P(Split3TestCPU, Split3Test,
428 (Values(cv::Size(1280, 720),
430 cv::Size(128, 128))));
432 INSTANTIATE_TEST_CASE_P(Split4TestCPU, Split4Test,
433 (Values(cv::Size(1280, 720),
435 cv::Size(128, 128))));
437 INSTANTIATE_TEST_CASE_P(Merge3TestCPU, Merge3Test,
438 (Values(cv::Size(1280, 720),
440 cv::Size(128, 128))));
442 INSTANTIATE_TEST_CASE_P(Merge4TestCPU, Merge4Test,
443 (Values(cv::Size(1280, 720),
445 cv::Size(128, 128))));
447 INSTANTIATE_TEST_CASE_P(RemapTestCPU, RemapTest,
448 Combine(Values(CV_8UC1, CV_16UC1, CV_16SC1),
449 Values(cv::Size(1280, 720),
452 /*init output matrices or not*/ testing::Bool()));
454 INSTANTIATE_TEST_CASE_P(FlipTestCPU, FlipTest,
455 Combine(Values(CV_8UC1, CV_16UC1, CV_16SC1),
457 Values(cv::Size(1280, 720),
460 /*init output matrices or not*/ testing::Bool()));
462 INSTANTIATE_TEST_CASE_P(CropTestCPU, CropTest,
463 Combine(Values(CV_8UC1, CV_16UC1, CV_16SC1),
464 Values(cv::Rect(10, 8, 20, 35), cv::Rect(4, 10, 37, 50)),
465 Values(cv::Size(1280, 720),
468 /*init output matrices or not*/ testing::Bool()));
470 INSTANTIATE_TEST_CASE_P(LUTTestCPU, LUTTest,
471 Combine(Values(CV_8UC1, CV_8UC3),
473 Values(cv::Size(1280, 720),
476 /*init output matrices or not*/ testing::Bool()));
478 INSTANTIATE_TEST_CASE_P(LUTTestCustomCPU, LUTTest,
479 Combine(Values(CV_8UC3),
481 Values(cv::Size(1280, 720),
484 /*init output matrices or not*/ testing::Bool()));
486 INSTANTIATE_TEST_CASE_P(ConvertToCPU, ConvertToTest,
487 Combine(Values(CV_8UC3, CV_8UC1, CV_16UC1, CV_32FC1),
488 Values(CV_8U, CV_16U, CV_32F),
489 Values(cv::Size(1280, 720),
491 cv::Size(128, 128))));
493 INSTANTIATE_TEST_CASE_P(ConcatHorTestCPU, ConcatHorTest,
494 Combine(Values(CV_8UC1, CV_16UC1, CV_16SC1),
495 Values(cv::Size(1280, 720),
497 cv::Size(128, 128))));
498 INSTANTIATE_TEST_CASE_P(ConcatVertTestCPU, ConcatVertTest,
499 Combine(Values(CV_8UC1, CV_16UC1, CV_16SC1),
500 Values(cv::Size(1280, 720),
502 cv::Size(128, 128))));
504 //----------------------------------------------------------------------