1 | PARAM_TEST_CASE(ImgprocTestBase, MatType,
|
2 | int,
|
3 | int,
|
4 | bool)
|
5 | {
|
6 | int type, borderType, blockSize;
|
7 | bool useRoi;
|
8 |
|
9 | Mat src, dst_whole, src_roi, dst_roi;
|
10 | ocl::oclMat gsrc_whole, gsrc_roi, gdst_whole, gdst_roi;
|
11 |
|
12 | virtual void SetUp()
|
13 | {
|
14 | type = GET_PARAM(0);
|
15 | blockSize = GET_PARAM(1);
|
16 | borderType = GET_PARAM(2);
|
17 | useRoi = GET_PARAM(3);
|
18 | }
|
19 |
|
20 | void random_roi()
|
21 | {
|
22 | Size roiSize = randomSize(1, MAX_VALUE);
|
23 | Border srcBorder = randomBorder(0, useRoi ? MAX_VALUE : 0);
|
24 | randomSubMat(src, src_roi, roiSize, srcBorder, type, 5, 256);
|
25 |
|
26 | Border dstBorder = randomBorder(0, useRoi ? MAX_VALUE : 0);
|
27 | randomSubMat(dst_whole, dst_roi, roiSize, dstBorder, type, 5, 16);
|
28 |
|
29 | generateOclMat(gsrc_whole, gsrc_roi, src, roiSize, srcBorder);
|
30 | generateOclMat(gdst_whole, gdst_roi, dst_whole, roiSize, dstBorder);
|
31 | }
|
32 |
|
33 | void Near(double threshold = 0.0)
|
34 | {
|
35 | Mat whole, roi;
|
36 | gdst_whole.download(whole);
|
37 | gdst_roi.download(roi);
|
38 |
|
39 | EXPECT_MAT_NEAR(dst_whole, whole, threshold);
|
40 | EXPECT_MAT_NEAR(dst_roi, roi, threshold);
|
41 | }
|
42 | };
|
43 |
|
44 | typedef ImgprocTestBase CornerMinEigenVal;
|
45 |
|
46 | OCL_TEST_P(CornerMinEigenVal, Mat)
|
47 | {
|
48 | for (int j = 0; j < LOOP_TIMES; j++)
|
49 | {
|
50 | random_roi();
|
51 |
|
52 | int apertureSize = 3;
|
53 |
|
54 | cornerMinEigenVal(src_roi, dst_roi, blockSize, apertureSize, borderType);
|
55 | ocl::cornerMinEigenVal(gsrc_roi, gdst_roi, blockSize, apertureSize, borderType);
|
56 |
|
57 | Near(1.0);
|
58 | }
|
59 | }
|
60 |
|
61 | INSTANTIATE_TEST_CASE_P(Imgproc, CornerMinEigenVal, Combine(
|
62 | Values(CV_8UC1, CV_32FC1),
|
63 | Values(3, 5, 7),
|
64 | Values((int)BORDER_REFLECT, (int)BORDER_CONSTANT, (int)BORDER_REPLICATE),
|
65 | Bool()));
|