1 #include "perf_precomp.hpp"
\r
5 using namespace perf;
\r
6 using namespace testing;
\r
7 using std::tr1::make_tuple;
\r
10 enum{HALF_SIZE=0, UPSIDE_DOWN, REFLECTION_X, REFLECTION_BOTH};
\r
12 CV_ENUM(BorderMode, BORDER_CONSTANT, BORDER_REPLICATE);
\r
13 CV_ENUM(InterType, INTER_NEAREST, INTER_LINEAR);
\r
14 CV_ENUM(RemapMode, HALF_SIZE, UPSIDE_DOWN, REFLECTION_X, REFLECTION_BOTH);
\r
16 typedef TestBaseWithParam< tr1::tuple<Size, InterType, BorderMode> > TestWarpAffine;
\r
17 typedef TestBaseWithParam< tr1::tuple<Size, InterType, BorderMode> > TestWarpPerspective;
\r
18 typedef TestBaseWithParam< tr1::tuple<MatType, Size, InterType, BorderMode, RemapMode> > TestRemap;
\r
20 void update_map(const Mat& src, Mat& map_x, Mat& map_y, const int remapMode );
\r
22 PERF_TEST_P( TestWarpAffine, WarpAffine,
\r
24 Values( szVGA, sz720p, sz1080p ),
\r
25 ValuesIn( InterType::all() ),
\r
26 ValuesIn( BorderMode::all() )
\r
31 int borderMode, interType;
\r
32 sz = get<0>(GetParam());
\r
33 borderMode = get<1>(GetParam());
\r
34 interType = get<2>(GetParam());
\r
36 Mat src, img = imread(getDataPath("cv/shared/fruits.jpg"));
\r
37 cvtColor(img, src, COLOR_BGR2RGBA, 4);
\r
38 Mat warpMat = getRotationMatrix2D(Point2f(src.cols/2.f, src.rows/2.f), 30., 2.2);
\r
39 Mat dst(sz, CV_8UC4);
\r
41 declare.in(src).out(dst);
\r
43 TEST_CYCLE() warpAffine( src, dst, warpMat, sz, interType, borderMode, Scalar::all(150) );
\r
49 PERF_TEST_P( TestWarpPerspective, WarpPerspective,
\r
51 Values( szVGA, sz720p, sz1080p ),
\r
52 ValuesIn( InterType::all() ),
\r
53 ValuesIn( BorderMode::all() )
\r
58 int borderMode, interType;
\r
59 sz = get<0>(GetParam());
\r
60 borderMode = get<1>(GetParam());
\r
61 interType = get<2>(GetParam());
\r
64 Mat src, img = imread(getDataPath("cv/shared/fruits.jpg"));
\r
65 cvtColor(img, src, COLOR_BGR2RGBA, 4);
\r
66 Mat rotMat = getRotationMatrix2D(Point2f(src.cols/2.f, src.rows/2.f), 30., 2.2);
\r
67 Mat warpMat(3, 3, CV_64FC1);
\r
68 for(int r=0; r<2; r++)
\r
69 for(int c=0; c<3; c++)
\r
70 warpMat.at<double>(r, c) = rotMat.at<double>(r, c);
\r
71 warpMat.at<double>(2, 0) = .3/sz.width;
\r
72 warpMat.at<double>(2, 1) = .3/sz.height;
\r
73 warpMat.at<double>(2, 2) = 1;
\r
74 Mat dst(sz, CV_8UC4);
\r
76 declare.in(src).out(dst);
\r
78 TEST_CYCLE() warpPerspective( src, dst, warpMat, sz, interType, borderMode, Scalar::all(150) );
\r
83 PERF_TEST_P( TestRemap, remap,
\r
85 Values( TYPICAL_MAT_TYPES ),
\r
86 Values( szVGA, sz720p, sz1080p ),
\r
87 ValuesIn( InterType::all() ),
\r
88 ValuesIn( BorderMode::all() ),
\r
89 ValuesIn( RemapMode::all() )
\r
93 int type = get<0>(GetParam());
\r
94 Size size = get<1>(GetParam());
\r
95 int interpolationType = get<2>(GetParam());
\r
96 int borderMode = get<3>(GetParam());
\r
97 int remapMode = get<4>(GetParam());
\r
98 unsigned int height = size.height;
\r
99 unsigned int width = size.width;
\r
100 Mat source(height, width, type);
\r
102 Mat map_x(height, width, CV_32F);
\r
103 Mat map_y(height, width, CV_32F);
\r
105 declare.in(source, WARMUP_RNG);
\r
107 update_map(source, map_x, map_y, remapMode);
\r
111 remap(source, destination, map_x, map_y, interpolationType, borderMode);
\r
114 SANITY_CHECK(destination, 1);
\r
117 void update_map(const Mat& src, Mat& map_x, Mat& map_y, const int remapMode )
\r
119 for( int j = 0; j < src.rows; j++ )
\r
121 for( int i = 0; i < src.cols; i++ )
\r
123 switch( remapMode )
\r
126 if( i > src.cols*0.25 && i < src.cols*0.75 && j > src.rows*0.25 && j < src.rows*0.75 )
\r
128 map_x.at<float>(j,i) = 2*( i - src.cols*0.25 ) + 0.5 ;
\r
129 map_y.at<float>(j,i) = 2*( j - src.rows*0.25 ) + 0.5 ;
\r
133 map_x.at<float>(j,i) = 0 ;
\r
134 map_y.at<float>(j,i) = 0 ;
\r
138 map_x.at<float>(j,i) = i ;
\r
139 map_y.at<float>(j,i) = src.rows - j ;
\r
142 map_x.at<float>(j,i) = src.cols - i ;
\r
143 map_y.at<float>(j,i) = j ;
\r
145 case REFLECTION_BOTH:
\r
146 map_x.at<float>(j,i) = src.cols - i ;
\r
147 map_y.at<float>(j,i) = src.rows - j ;
\r
154 PERF_TEST(Transform, getPerspectiveTransform)
\r
156 unsigned int size = 8;
\r
157 Mat source(1, size/2, CV_32FC2);
\r
158 Mat destination(1, size/2, CV_32FC2);
\r
159 Mat transformCoefficient;
\r
161 declare.in(source, destination, WARMUP_RNG);
\r
165 transformCoefficient = getPerspectiveTransform(source, destination);
\r