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.
108 lines
3.3 KiB
108 lines
3.3 KiB
2 years ago
|
/**
|
||
|
@file generalizedHoughTransform.cpp
|
||
|
@author Markus Heck
|
||
|
@brief Detects an object, given by a template, in an image using GeneralizedHoughBallard and GeneralizedHoughGuil.
|
||
|
*/
|
||
|
|
||
|
#include "opencv2/highgui.hpp"
|
||
|
#include "opencv2/imgproc.hpp"
|
||
|
|
||
|
using namespace cv;
|
||
|
using namespace std;
|
||
|
|
||
|
int main() {
|
||
2 years ago
|
//! [generalized-hough-transform-load-and-setup]
|
||
2 years ago
|
// load source image and grayscale template
|
||
2 years ago
|
Mat image = imread("images/generalized_hough_mini_image.jpg");
|
||
2 years ago
|
Mat templ = imread("images/generalized_hough_mini_template.jpg", IMREAD_GRAYSCALE);
|
||
2 years ago
|
|
||
2 years ago
|
// create grayscale image
|
||
2 years ago
|
Mat grayImage;
|
||
|
cvtColor(image, grayImage, COLOR_RGB2GRAY);
|
||
|
|
||
|
// create variable for location, scale and rotation of detected templates
|
||
|
vector<Vec4f> positionBallard, positionGuil;
|
||
|
|
||
|
// template width and height
|
||
|
int w = templ.cols;
|
||
|
int h = templ.rows;
|
||
2 years ago
|
//! [generalized-hough-transform-load-and-setup]
|
||
2 years ago
|
|
||
2 years ago
|
|
||
|
//! [generalized-hough-transform-setup-parameters]
|
||
2 years ago
|
// create ballard and set options
|
||
|
Ptr<GeneralizedHoughBallard> ballard = createGeneralizedHoughBallard();
|
||
|
ballard->setMinDist(10);
|
||
|
ballard->setLevels(360);
|
||
|
ballard->setDp(2);
|
||
|
ballard->setMaxBufferSize(1000);
|
||
|
ballard->setVotesThreshold(40);
|
||
|
|
||
|
ballard->setCannyLowThresh(30);
|
||
|
ballard->setCannyHighThresh(110);
|
||
|
ballard->setTemplate(templ);
|
||
|
|
||
|
|
||
|
// create guil and set options
|
||
|
Ptr<GeneralizedHoughGuil> guil = createGeneralizedHoughGuil();
|
||
|
guil->setMinDist(10);
|
||
|
guil->setLevels(360);
|
||
|
guil->setDp(3);
|
||
|
guil->setMaxBufferSize(1000);
|
||
|
|
||
|
guil->setMinAngle(0);
|
||
|
guil->setMaxAngle(360);
|
||
|
guil->setAngleStep(1);
|
||
|
guil->setAngleThresh(1500);
|
||
|
|
||
|
guil->setMinScale(0.5);
|
||
|
guil->setMaxScale(2.0);
|
||
|
guil->setScaleStep(0.05);
|
||
|
guil->setScaleThresh(50);
|
||
|
|
||
|
guil->setPosThresh(10);
|
||
|
|
||
|
guil->setCannyLowThresh(30);
|
||
|
guil->setCannyHighThresh(110);
|
||
|
|
||
|
guil->setTemplate(templ);
|
||
2 years ago
|
//! [generalized-hough-transform-setup-parameters]
|
||
2 years ago
|
|
||
|
|
||
2 years ago
|
//! [generalized-hough-transform-run]
|
||
2 years ago
|
// execute ballard detection
|
||
|
ballard->detect(grayImage, positionBallard);
|
||
|
// execute guil detection
|
||
|
guil->detect(grayImage, positionGuil);
|
||
2 years ago
|
//! [generalized-hough-transform-run]
|
||
2 years ago
|
|
||
|
|
||
2 years ago
|
//! [generalized-hough-transform-draw-results]
|
||
2 years ago
|
// draw ballard
|
||
|
for (vector<Vec4f>::iterator iter = positionBallard.begin(); iter != positionBallard.end(); ++iter) {
|
||
|
RotatedRect rRect = RotatedRect(Point2f((*iter)[0], (*iter)[1]),
|
||
|
Size2f(w * (*iter)[2], h * (*iter)[2]),
|
||
|
(*iter)[3]);
|
||
|
Point2f vertices[4];
|
||
|
rRect.points(vertices);
|
||
|
for (int i = 0; i < 4; i++)
|
||
|
line(image, vertices[i], vertices[(i + 1) % 4], Scalar(255, 0, 0), 6);
|
||
|
}
|
||
|
|
||
|
// draw guil
|
||
|
for (vector<Vec4f>::iterator iter = positionGuil.begin(); iter != positionGuil.end(); ++iter) {
|
||
|
RotatedRect rRect = RotatedRect(Point2f((*iter)[0], (*iter)[1]),
|
||
|
Size2f(w * (*iter)[2], h * (*iter)[2]),
|
||
|
(*iter)[3]);
|
||
|
Point2f vertices[4];
|
||
|
rRect.points(vertices);
|
||
|
for (int i = 0; i < 4; i++)
|
||
|
line(image, vertices[i], vertices[(i + 1) % 4], Scalar(0, 255, 0), 2);
|
||
|
}
|
||
|
|
||
|
imshow("result_img", image);
|
||
|
waitKey();
|
||
2 years ago
|
//! [generalized-hough-transform-draw-results]
|
||
|
|
||
2 years ago
|
return EXIT_SUCCESS;
|
||
|
}
|