OpenCV already comes with a function to perform hough transforms. It lets you choose between different variants of the transform: the standard hough transform, the probabilistic hough transform and the multi-scale hough transform. Here I'll get into the technical details of getting the command, cvHoughLines2
, to work. The command expects and returns parameters in a certain format.
The cvHoughLines2 command goes like this:
CvSeq* cvHoughLines2(CvArr* image, void* line_storage, int method, double rho, double theta, int threshold, double param1=0, double param2=0);
We'll go into each parameter in detail.
image is the image you want to do the hough transform on. This has to be an 8-bit single channel binary image. Though you can supply a grayscale image, it will be treated as a binary image (non-zero pixels are used).
line_storage is the place where this function stores its result. This can be either a CvMemoryStorage structure or a matrix with N rows. More on this parameter later.
method is either CV_HOUGH_STANDARD, CV_HOUGH_PROBABILISTIC, or CV_HOUGH_MULTI_SCALE. And you can guess they're for the standard hough transform, the probabilistic hough transform and the multi-scale hough transform.
rho and theta set the desired accuracy of the transform. rho is in pixels and theta is in radians. The smaller the value, the better the transform will be... but it'll also take more time. Usually, values 1 and 0.01 should be sufficient.
threshold determines which lines are returned. Each line has a particular number of "votes". This parameter sets the minimum number of "votes" in order to qualify as a potential line. You might want to read about The Hough Transform for more information on this.
param1 and param2 are used by the different transforms.
Getting results out of this command depends on the line_storage parameter. You have two options: supply a CVMat matrix or supply a CvMemoryStorage stucture.
This one is straight forward. You give it a matrix, and the function will populate this matrix with its results. For different method values, this matrix must have different formats:
CV_32FC2
). It stores the p and θ valuesCV_32FC4
). It stores the two end points of the line segments ( (x,y) twice).
The function will set the number of rows of the matrix to the number of lines detected. Also, it will return a NULL. If you provide a memory storage, the function will return a CvSeq* sequence. Using this sequence, you can access the various parameter of the detected lines:
float* currentLine = (float*) cvGetSeqElem(line_seq , index);
currentLine[0]
and currentLine[1]
(both float)currentLine[0]
and currentLine[1]
(both CvPoint
)This should be enough to get you started with using the cvHoughLines2
command!