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-2020 Intel Corporation
8 #include "../test_precomp.hpp"
9 #include "../common/gapi_core_tests.hpp"
10 #include <opencv2/gapi/cpu/core.hpp>
14 #define CORE_CPU [] () { return cv::compile_args(cv::gapi::use_only{cv::gapi::core::cpu::kernels()}); }
15 } // anonymous namespace
20 // FIXME: Wut? See MulTestCPU/MathOpTest below (duplicate?)
21 INSTANTIATE_TEST_CASE_P(AddTestCPU, MathOpTest,
22 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
23 Values(cv::Size(1280, 720),
26 Values( -1, CV_8U, CV_16U, CV_32F ),
33 INSTANTIATE_TEST_CASE_P(MulTestCPU, MathOpTest,
34 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
35 Values(cv::Size(1280, 720),
38 Values( -1, CV_8U, CV_16U, CV_32F ),
42 Values(1.0, 0.5, 2.0),
45 INSTANTIATE_TEST_CASE_P(SubTestCPU, MathOpTest,
46 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
47 Values(cv::Size(1280, 720),
50 Values( -1, CV_8U, CV_16U, CV_32F ),
57 INSTANTIATE_TEST_CASE_P(DivTestCPU, MathOpTest,
58 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
59 Values(cv::Size(1280, 720),
62 Values( -1, CV_8U, CV_16U, CV_32F ),
66 Values (1.0, 0.5, 2.0),
69 INSTANTIATE_TEST_CASE_P(MulTestCPU, MulDoubleTest,
70 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
71 Values(cv::Size(1280, 720),
74 Values( -1, CV_8U, CV_16U, CV_32F ),
77 INSTANTIATE_TEST_CASE_P(DivTestCPU, DivTest,
78 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
79 Values(cv::Size(1280, 720),
82 Values( -1, CV_8U, CV_16U, CV_32F ),
85 INSTANTIATE_TEST_CASE_P(DivCTestCPU, DivCTest,
86 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
87 Values(cv::Size(1280, 720),
90 Values( -1, CV_8U, CV_16U, CV_32F ),
93 INSTANTIATE_TEST_CASE_P(MeanTestCPU, MeanTest,
94 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
95 Values(cv::Size(1280, 720),
101 INSTANTIATE_TEST_CASE_P(MaskTestCPU, MaskTest,
102 Combine(Values(CV_8UC1, CV_16UC1, CV_16SC1),
103 Values(cv::Size(1280, 720),
109 INSTANTIATE_TEST_CASE_P(SelectTestCPU, SelectTest,
110 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
111 Values(cv::Size(1280, 720),
117 INSTANTIATE_TEST_CASE_P(Polar2CartCPU, Polar2CartTest,
118 Combine(Values(CV_32FC1),
119 Values(cv::Size(1280, 720),
125 INSTANTIATE_TEST_CASE_P(Cart2PolarCPU, Cart2PolarTest,
126 Combine(Values(CV_32FC1),
127 Values(cv::Size(1280, 720),
133 INSTANTIATE_TEST_CASE_P(PhaseCPU, PhaseTest,
134 Combine(Values(CV_32F, CV_32FC3),
135 Values(cv::Size(1280, 720),
140 /* angle_in_degrees */ testing::Bool()));
142 INSTANTIATE_TEST_CASE_P(SqrtCPU, SqrtTest,
143 Combine(Values(CV_32F, CV_32FC3),
144 Values(cv::Size(1280, 720),
150 INSTANTIATE_TEST_CASE_P(CompareTestCPU, CmpTest,
151 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
152 Values(cv::Size(1280, 720),
157 Values(CMP_EQ, CMP_GE, CMP_NE, CMP_GT, CMP_LT, CMP_LE),
159 Values(AbsExact().to_compare_obj())));
161 INSTANTIATE_TEST_CASE_P(BitwiseTestCPU, BitwiseTest,
162 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1),
163 Values(cv::Size(1280, 720),
168 Values(AND, OR, XOR),
171 INSTANTIATE_TEST_CASE_P(BitwiseNotTestCPU, NotTest,
172 Combine(Values(CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1),
173 Values(cv::Size(1280, 720),
179 INSTANTIATE_TEST_CASE_P(MinTestCPU, MinTest,
180 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
181 Values(cv::Size(1280, 720),
187 INSTANTIATE_TEST_CASE_P(MaxTestCPU, MaxTest,
188 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
189 Values(cv::Size(1280, 720),
195 INSTANTIATE_TEST_CASE_P(SumTestCPU, SumTest,
196 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
197 Values(cv::Size(1280, 720),
203 Values(AbsToleranceScalar(1e-5).to_compare_obj())));
205 INSTANTIATE_TEST_CASE_P(CountNonZeroTestCPU, CountNonZeroTest,
206 Combine(Values( CV_8UC1, CV_16UC1, CV_16SC1, CV_32FC1 ),
207 Values(cv::Size(1280, 720),
212 Values(AbsToleranceScalar(1e-5).to_compare_obj())));
214 INSTANTIATE_TEST_CASE_P(AbsDiffTestCPU, AbsDiffTest,
215 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
216 Values(cv::Size(1280, 720),
222 INSTANTIATE_TEST_CASE_P(AbsDiffCTestCPU, AbsDiffCTest,
223 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
224 Values(cv::Size(1280, 720),
230 INSTANTIATE_TEST_CASE_P(AddWeightedTestCPU, AddWeightedTest,
231 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
232 Values(cv::Size(1280, 720),
235 Values( -1, CV_8U, CV_16U, CV_32F ),
237 Values(Tolerance_FloatRel_IntAbs(1e-6, 1).to_compare_obj())));
239 INSTANTIATE_TEST_CASE_P(NormTestCPU, NormTest,
240 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
241 Values(cv::Size(1280, 720),
246 Values(AbsToleranceScalar(1e-5).to_compare_obj()),
247 Values(NORM_INF, NORM_L1, NORM_L2)));
249 INSTANTIATE_TEST_CASE_P(IntegralTestCPU, IntegralTest,
250 Combine(Values( CV_8UC1, CV_16UC1, CV_16SC1, CV_32FC1 ),
251 Values(cv::Size(1280, 720),
257 INSTANTIATE_TEST_CASE_P(ThresholdTestCPU, ThresholdTest,
258 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
259 Values(cv::Size(1280, 720),
264 Values(cv::THRESH_BINARY, cv::THRESH_BINARY_INV, cv::THRESH_TRUNC,
265 cv::THRESH_TOZERO, cv::THRESH_TOZERO_INV),
266 Values(cv::Scalar(0, 0, 0, 0),
267 cv::Scalar(100, 100, 100, 100),
268 cv::Scalar(255, 255, 255, 255))));
270 INSTANTIATE_TEST_CASE_P(ThresholdTestCPU, ThresholdOTTest,
271 Combine(Values(CV_8UC1),
272 Values(cv::Size(1280, 720),
277 Values(cv::THRESH_OTSU, cv::THRESH_TRIANGLE)));
280 INSTANTIATE_TEST_CASE_P(InRangeTestCPU, InRangeTest,
281 Combine(Values(CV_8UC1, CV_16UC1, CV_16SC1, CV_32FC1),
282 Values(cv::Size(1280, 720),
288 INSTANTIATE_TEST_CASE_P(Split3TestCPU, Split3Test,
289 Combine(Values(CV_8UC3),
290 Values(cv::Size(1280, 720),
296 INSTANTIATE_TEST_CASE_P(Split4TestCPU, Split4Test,
297 Combine(Values(CV_8UC4),
298 Values(cv::Size(1280, 720),
304 INSTANTIATE_TEST_CASE_P(ResizeTestCPU, ResizeTest,
305 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
306 Values(cv::Size(1280, 720),
311 Values(AbsSimilarPoints(2, 0.05).to_compare_obj()),
312 Values(cv::INTER_NEAREST, cv::INTER_LINEAR, cv::INTER_AREA),
313 Values(cv::Size(64,64),
316 INSTANTIATE_TEST_CASE_P(ResizePTestCPU, ResizePTest,
317 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
318 Values(cv::Size(1280, 720),
323 Values(AbsSimilarPoints(2, 0.05).to_compare_obj()),
324 Values(cv::INTER_LINEAR),
325 Values(cv::Size(64,64),
328 INSTANTIATE_TEST_CASE_P(ResizeTestCPU, ResizeTestFxFy,
329 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
330 Values(cv::Size(1280, 720),
335 Values(AbsSimilarPoints(2, 0.05).to_compare_obj()),
336 Values(cv::INTER_NEAREST, cv::INTER_LINEAR, cv::INTER_AREA),
340 INSTANTIATE_TEST_CASE_P(Merge3TestCPU, Merge3Test,
341 Combine(Values(CV_8UC1),
342 Values(cv::Size(1280, 720),
348 INSTANTIATE_TEST_CASE_P(Merge4TestCPU, Merge4Test,
349 Combine(Values(CV_8UC1),
350 Values(cv::Size(1280, 720),
356 INSTANTIATE_TEST_CASE_P(RemapTestCPU, RemapTest,
357 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
358 Values(cv::Size(1280, 720),
364 INSTANTIATE_TEST_CASE_P(FlipTestCPU, FlipTest,
365 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
366 Values(cv::Size(1280, 720),
373 INSTANTIATE_TEST_CASE_P(CropTestCPU, CropTest,
374 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
375 Values(cv::Size(1280, 720),
380 Values(cv::Rect(10, 8, 20, 35), cv::Rect(4, 10, 37, 50))));
382 INSTANTIATE_TEST_CASE_P(CopyTestCPU, CopyTest,
383 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
384 Values(cv::Size(1280, 720),
390 INSTANTIATE_TEST_CASE_P(LUTTestCPU, LUTTest,
391 Combine(Values(CV_8UC1, CV_8UC3),
392 Values(cv::Size(1280, 720),
398 INSTANTIATE_TEST_CASE_P(LUTTestCustomCPU, LUTTest,
399 Combine(Values(CV_8UC3),
400 Values(cv::Size(1280, 720),
406 INSTANTIATE_TEST_CASE_P(ConvertToCPU, ConvertToTest,
407 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
408 Values(cv::Size(1280, 720),
411 Values(CV_8U, CV_16U, CV_16S, CV_32F),
413 Values(AbsExact().to_compare_obj()),
414 Values(2.5, 1.0, -1.0),
415 Values(250.0, 0.0, -128.0)));
417 INSTANTIATE_TEST_CASE_P(ConcatHorTestCPU, ConcatHorTest,
418 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
419 Values(cv::Size(1280, 720),
425 INSTANTIATE_TEST_CASE_P(ConcatVertTestCPU, ConcatVertTest,
426 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
427 Values(cv::Size(1280, 720),
433 INSTANTIATE_TEST_CASE_P(ConcatVertVecTestCPU, ConcatVertVecTest,
434 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
435 Values(cv::Size(1280, 720),
441 INSTANTIATE_TEST_CASE_P(ConcatHorVecTestCPU, ConcatHorVecTest,
442 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
443 Values(cv::Size(1280, 720),
449 INSTANTIATE_TEST_CASE_P(WarpPerspectiveTestCPU, WarpPerspectiveTest,
450 Combine(Values(CV_8UC1, CV_8UC3),
451 Values(cv::Size(1280, 720),
455 Values(AbsExact().to_compare_obj()),
458 Values(cv::INTER_LINEAR),
459 Values(cv::BORDER_CONSTANT),
460 Values(cv::Scalar())));
462 INSTANTIATE_TEST_CASE_P(WarpAffineTestCPU, WarpAffineTest,
463 Combine(Values(CV_8UC1, CV_8UC3),
464 Values(cv::Size(1280, 720),
468 Values(AbsExact().to_compare_obj()),
471 Values(cv::INTER_LINEAR),
472 Values(cv::BORDER_CONSTANT),
473 Values(cv::Scalar())));
475 INSTANTIATE_TEST_CASE_P(NormalizeTestCPU, NormalizeTest,
476 Combine(Values(CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1),
477 Values(cv::Size(1280, 720),
481 Values(AbsExact().to_compare_obj()),
483 Values(1.0, 120.0, 255.0),
484 Values(NORM_MINMAX, NORM_INF, NORM_L1, NORM_L2),
485 Values(-1, CV_8U, CV_16U, CV_16S, CV_32F)));
487 // PLEASE DO NOT PUT NEW ACCURACY TESTS BELOW THIS POINT! //////////////////////
489 INSTANTIATE_TEST_CASE_P(BackendOutputAllocationTestCPU, BackendOutputAllocationTest,
490 Combine(Values(CV_8UC3, CV_16SC2, CV_32FC1),
491 Values(cv::Size(50, 50)),
495 INSTANTIATE_TEST_CASE_P(BackendOutputAllocationLargeSizeWithCorrectSubmatrixTestCPU,
496 BackendOutputAllocationLargeSizeWithCorrectSubmatrixTest,
497 Combine(Values(CV_8UC3, CV_16SC2, CV_32FC1),
498 Values(cv::Size(50, 50)),
502 INSTANTIATE_TEST_CASE_P(ReInitOutTestCPU, ReInitOutTest,
503 Combine(Values(CV_8UC3, CV_16SC4, CV_32FC1),
504 Values(cv::Size(640, 480)),
507 Values(cv::Size(640, 400),
508 cv::Size(10, 480))));
510 INSTANTIATE_TEST_CASE_P(ParseTestCPU, ParseSSDBLTest,
511 Combine(Values(CV_8UC1, CV_8UC3, CV_32FC1),
512 Values(cv::Size(1920, 1080)),
515 Values(0.3f, 0.5f, 0.7f),
518 INSTANTIATE_TEST_CASE_P(ParseTestCPU, ParseSSDTest,
519 Combine(Values(CV_8UC1, CV_8UC3, CV_32FC1),
520 Values(cv::Size(1920, 1080)),
523 Values(0.3f, 0.5f, 0.7f),
527 INSTANTIATE_TEST_CASE_P(ParseTestCPU, ParseYoloTest,
528 Combine(Values(CV_8UC1, CV_8UC3, CV_32FC1),
529 Values(cv::Size(1920, 1080)),
532 Values(0.3f, 0.5f, 0.7f),
536 INSTANTIATE_TEST_CASE_P(SizeTestCPU, SizeTest,
537 Combine(Values(CV_8UC1, CV_8UC3, CV_32FC1),
538 Values(cv::Size(32, 32),
543 INSTANTIATE_TEST_CASE_P(SizeRTestCPU, SizeRTest,
544 Combine(Values(CV_8UC1, CV_8UC3, CV_32FC1),
545 Values(cv::Size(32, 32),