mirror of https://github.com/opencv/opencv.git
Open Source Computer Vision Library
https://opencv.org/
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
53 lines
1.4 KiB
53 lines
1.4 KiB
#include "perf_precomp.hpp" |
|
|
|
#include "cmath" |
|
|
|
using namespace std; |
|
using namespace cv; |
|
using namespace perf; |
|
using std::tr1::make_tuple; |
|
using std::tr1::get; |
|
|
|
typedef std::tr1::tuple<String, double, double, int> Image_RhoStep_ThetaStep_Threshold_t; |
|
typedef perf::TestBaseWithParam<Image_RhoStep_ThetaStep_Threshold_t> Image_RhoStep_ThetaStep_Threshold; |
|
|
|
PERF_TEST_P(Image_RhoStep_ThetaStep_Threshold, HoughLines, |
|
testing::Combine( |
|
testing::Values( "cv/shared/pic5.png", "stitching/a1.png" ), |
|
testing::Values( 1, 10 ), |
|
testing::Values( 0.01, 0.1 ), |
|
testing::Values( 300, 500 ) |
|
) |
|
) |
|
{ |
|
String filename = getDataPath(get<0>(GetParam())); |
|
double rhoStep = get<1>(GetParam()); |
|
double thetaStep = get<2>(GetParam()); |
|
int threshold = get<3>(GetParam()); |
|
|
|
Mat image = imread(filename, IMREAD_GRAYSCALE); |
|
if (image.empty()) |
|
FAIL() << "Unable to load source image" << filename; |
|
|
|
Canny(image, image, 0, 0); |
|
|
|
Mat lines; |
|
declare.time(40); |
|
|
|
TEST_CYCLE() HoughLines(image, lines, rhoStep, thetaStep, threshold); |
|
|
|
#ifdef WIN32 |
|
//FIXME: ugly fix to make sanity check pass on Win32, must be investigated, issue #2617 |
|
if (lines.cols == 2015) |
|
{ |
|
lines = lines(Rect(0, 0, lines.cols - 1, lines.rows)); |
|
SANITY_CHECK(lines, 800.0); |
|
} |
|
else |
|
{ |
|
SANITY_CHECK(lines); |
|
} |
|
#else |
|
SANITY_CHECK(lines); |
|
#endif |
|
}
|
|
|