如何将坐标从霍夫变换(rho,theta)转换回图像(x,y)?

Hao*_*est 6 opencv hough-transform

我有一个通过在 Opencv 中调用霍夫变换函数产生的线向量,需要将它们转换回图像坐标。我从Opencv的官方文档中找到了这段示例代码,但我不明白。请问有人解释一下吗?

for( size_t i = 0; i < lines->size(); i++ )
{
    float rho = lines->at(i)[0]; //[0] is rho
    float theta = lines->at(i)[1]; //[1] is theta
    double a = cos(theta), b = sin(theta);
    double x0 = a*rho, y0 = b*rho;
    cv::Point pt1(cvRound(x0 + 1000*(-b)),
              cvRound(y0 + 1000*(a)));
    cv::Point pt2(cvRound(x0 - 1000*(-b)),
              cvRound(y0 - 1000*(a)));
    line( *mat, pt1, pt2, Scalar(255,0,0), 1, 8 );
}
Run Code Online (Sandbox Code Playgroud)

1000在做这条线是什么?

pt1(cvRound(x0 + 1000*(-b)), cvRound(y0 + 1000*(a)))
Run Code Online (Sandbox Code Playgroud)

此外,为什么 pt2 有负 y 线?例如,如果我的第一行是 (rho, theta) 格式的 (0,0),则 pt2 将是 (0, -1000)。

谢谢,

Utk*_*nha 4

这就是法线的数学原理。看看这篇文章 -将线从法线截距转换为斜率截距形式,它会通过数学计算。