霍夫线检测原理:
笛卡尔坐标的点 <=> 极坐标的曲线
所谓极坐标平面化是指, 将ρ-θ的关系像x-y那样在平面内展开。
公式推导: x-y坐标中的点(x0, y0), 代入极坐标ρ-θ中得
ρ,θ就是一对hough空间的变量表示。若将ρ,θ看成直角坐标空间,一个点(x0, y0)就是一个关于ρ,θ的正弦曲线。同样,直线上的其他点(Xn,Yn)也会构成一组关于ρ,θ的正弦曲线,这样势必存在一个关于ρ,θ相交(即垂直点(r,θ))。于是乎, 一条直线能够通过在极坐标下寻找交于一点的曲线数量来检测,如果越多曲线交于一点,就意味着这个交点表示的直线由更多的点组成。我们可以通过设置直线上点的阈值来定义多少条曲线交于一点我们才认为检测到了一条直线。
template<typename T>
int myRound(T value)
{
return (int)(value + (value >= 0 ? 0.5 : -0.5));
}
/*
函数名:doHoughLinesStandard
函数功能:标准霍夫直线检测的源码
函数参数:
src-->输入的二值图像 lines-->输出的线的坐标(r,θ)
rho-->极坐标r的步长 theta-->极坐标θ的步长
threshold-->交点个数阈值 linesMax-->线条数的最大值
备注:
关于极坐标的维度方面,标准的维度空间范围:θ∈[-π/2,π/2],r∈[-D,D],D=(w^2+h^2)^(1/2).可以参见《数字图像处理第三版p755》
这里所映射的极坐标维度范围:θ∈[0,181],有效为[1,180],r∈[0,(2D+1)+1],有效为[1,(2D+1)],D=(w + h).
*/
void doHoughLinesStandard(Mat &src, vector<Vec2f>&lines,float rho, float theta, int threshold,int linesMax)
{
float irho = 1 / rho;
const int width = src.cols;
const int height = src.rows;
int