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"
10 #include <opencv2/gapi/cpu/core.hpp>
14 #define CORE_CPU [] () { return cv::compile_args(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),
160 INSTANTIATE_TEST_CASE_P(BitwiseTestCPU, BitwiseTest,
161 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1),
162 Values(cv::Size(1280, 720),
167 Values(AND, OR, XOR)));
169 INSTANTIATE_TEST_CASE_P(BitwiseNotTestCPU, NotTest,
170 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
171 Values(cv::Size(1280, 720),
177 INSTANTIATE_TEST_CASE_P(MinTestCPU, MinTest,
178 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
179 Values(cv::Size(1280, 720),
185 INSTANTIATE_TEST_CASE_P(MaxTestCPU, MaxTest,
186 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
187 Values(cv::Size(1280, 720),
193 INSTANTIATE_TEST_CASE_P(SumTestCPU, SumTest,
194 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
195 Values(cv::Size(1280, 720),
201 Values(AbsToleranceScalar(1e-5).to_compare_obj())));
203 INSTANTIATE_TEST_CASE_P(AbsDiffTestCPU, AbsDiffTest,
204 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
205 Values(cv::Size(1280, 720),
211 INSTANTIATE_TEST_CASE_P(AbsDiffCTestCPU, AbsDiffCTest,
212 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
213 Values(cv::Size(1280, 720),
219 INSTANTIATE_TEST_CASE_P(AddWeightedTestCPU, AddWeightedTest,
220 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
221 Values(cv::Size(1280, 720),
224 Values( -1, CV_8U, CV_16U, CV_32F ),
226 Values(Tolerance_FloatRel_IntAbs(1e-6, 1).to_compare_obj())));
228 INSTANTIATE_TEST_CASE_P(NormTestCPU, NormTest,
229 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
230 Values(cv::Size(1280, 720),
235 Values(AbsToleranceScalar(1e-5).to_compare_obj()),
236 Values(NORM_INF, NORM_L1, NORM_L2)));
238 INSTANTIATE_TEST_CASE_P(IntegralTestCPU, IntegralTest,
239 Combine(Values( CV_8UC1, CV_16UC1, CV_16SC1, CV_32FC1 ),
240 Values(cv::Size(1280, 720),
246 INSTANTIATE_TEST_CASE_P(ThresholdTestCPU, ThresholdTest,
247 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
248 Values(cv::Size(1280, 720),
253 Values(cv::THRESH_BINARY, cv::THRESH_BINARY_INV, cv::THRESH_TRUNC,
254 cv::THRESH_TOZERO, cv::THRESH_TOZERO_INV)));
256 INSTANTIATE_TEST_CASE_P(ThresholdTestCPU, ThresholdOTTest,
257 Combine(Values(CV_8UC1),
258 Values(cv::Size(1280, 720),
263 Values(cv::THRESH_OTSU, cv::THRESH_TRIANGLE)));
266 INSTANTIATE_TEST_CASE_P(InRangeTestCPU, InRangeTest,
267 Combine(Values(CV_8UC1, CV_16UC1, CV_16SC1, CV_32FC1),
268 Values(cv::Size(1280, 720),
274 INSTANTIATE_TEST_CASE_P(Split3TestCPU, Split3Test,
275 Combine(Values(CV_8UC3),
276 Values(cv::Size(1280, 720),
282 INSTANTIATE_TEST_CASE_P(Split4TestCPU, Split4Test,
283 Combine(Values(CV_8UC4),
284 Values(cv::Size(1280, 720),
290 INSTANTIATE_TEST_CASE_P(ResizeTestCPU, ResizeTest,
291 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
292 Values(cv::Size(1280, 720),
297 Values(AbsSimilarPoints(2, 0.05).to_compare_obj()),
298 Values(cv::INTER_NEAREST, cv::INTER_LINEAR, cv::INTER_AREA),
299 Values(cv::Size(64,64),
302 INSTANTIATE_TEST_CASE_P(ResizePTestCPU, ResizePTest,
303 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
304 Values(cv::Size(1280, 720),
309 Values(AbsSimilarPoints(2, 0.05).to_compare_obj()),
310 Values(cv::INTER_LINEAR),
311 Values(cv::Size(64,64),
314 INSTANTIATE_TEST_CASE_P(ResizeTestCPU, ResizeTestFxFy,
315 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
316 Values(cv::Size(1280, 720),
321 Values(AbsSimilarPoints(2, 0.05).to_compare_obj()),
322 Values(cv::INTER_NEAREST, cv::INTER_LINEAR, cv::INTER_AREA),
326 INSTANTIATE_TEST_CASE_P(Merge3TestCPU, Merge3Test,
327 Combine(Values(CV_8UC1),
328 Values(cv::Size(1280, 720),
334 INSTANTIATE_TEST_CASE_P(Merge4TestCPU, Merge4Test,
335 Combine(Values(CV_8UC1),
336 Values(cv::Size(1280, 720),
342 INSTANTIATE_TEST_CASE_P(RemapTestCPU, RemapTest,
343 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
344 Values(cv::Size(1280, 720),
350 INSTANTIATE_TEST_CASE_P(FlipTestCPU, FlipTest,
351 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
352 Values(cv::Size(1280, 720),
359 INSTANTIATE_TEST_CASE_P(CropTestCPU, CropTest,
360 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
361 Values(cv::Size(1280, 720),
366 Values(cv::Rect(10, 8, 20, 35), cv::Rect(4, 10, 37, 50))));
368 INSTANTIATE_TEST_CASE_P(LUTTestCPU, LUTTest,
369 Combine(Values(CV_8UC1, CV_8UC3),
370 Values(cv::Size(1280, 720),
376 INSTANTIATE_TEST_CASE_P(LUTTestCustomCPU, LUTTest,
377 Combine(Values(CV_8UC3),
378 Values(cv::Size(1280, 720),
384 INSTANTIATE_TEST_CASE_P(ConvertToCPU, ConvertToTest,
385 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
386 Values(cv::Size(1280, 720),
389 Values(CV_8U, CV_16U, CV_16S, CV_32F),
391 Values(AbsExact().to_compare_obj()),
392 Values(2.5, 1.0, -1.0),
393 Values(250.0, 0.0, -128.0)));
395 INSTANTIATE_TEST_CASE_P(ConcatHorTestCPU, ConcatHorTest,
396 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
397 Values(cv::Size(1280, 720),
403 INSTANTIATE_TEST_CASE_P(ConcatVertTestCPU, ConcatVertTest,
404 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
405 Values(cv::Size(1280, 720),
411 INSTANTIATE_TEST_CASE_P(ConcatVertVecTestCPU, ConcatVertVecTest,
412 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
413 Values(cv::Size(1280, 720),
419 INSTANTIATE_TEST_CASE_P(ConcatHorVecTestCPU, ConcatHorVecTest,
420 Combine(Values( CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1 ),
421 Values(cv::Size(1280, 720),
427 INSTANTIATE_TEST_CASE_P(NormalizeTestCPU, NormalizeTest,
428 Combine(Values(CV_8UC1, CV_8UC3, CV_16UC1, CV_16SC1, CV_32FC1),
429 Values(cv::Size(1280, 720),
433 Values(AbsExact().to_compare_obj()),
435 Values(1.0, 120.0, 255.0),
436 Values(NORM_MINMAX, NORM_INF, NORM_L1, NORM_L2),
437 Values(-1, CV_8U, CV_16U, CV_16S, CV_32F)));
439 INSTANTIATE_TEST_CASE_P(BackendOutputAllocationTestCPU, BackendOutputAllocationTest,
440 Combine(Values(CV_8UC3, CV_16SC2, CV_32FC1),
441 Values(cv::Size(50, 50)),
445 INSTANTIATE_TEST_CASE_P(BackendOutputAllocationLargeSizeWithCorrectSubmatrixTestCPU,
446 BackendOutputAllocationLargeSizeWithCorrectSubmatrixTest,
447 Combine(Values(CV_8UC3, CV_16SC2, CV_32FC1),
448 Values(cv::Size(50, 50)),
452 INSTANTIATE_TEST_CASE_P(ReInitOutTestCPU, ReInitOutTest,
453 Combine(Values(CV_8UC3, CV_16SC4, CV_32FC1),
454 Values(cv::Size(640, 480)),
457 Values(cv::Size(640, 400),
458 cv::Size(10, 480))));