在 DLIB 中通过霍夫变换结果进行过滤

Filtering through Hough transform results in DLIB

我正在尝试使用 DLIB 中的霍夫变换,但只能显示一行。 DLIB 文档中的示例仅使用了一个强项:

point p = max_point(mat(himg));

我怎样才能显示所有强(超过特定阈值或 N 票最多)的行?

我试图遍历所有已经找到的点并屏蔽每个点,但是 dlib::max_point 一直在寻找相同的点,尽管它已经被清零了:

for(int i = 0; i < nPoints; ++i){
    dlib::point p = dlib::max_point(dlib::mat(hImg));
    maxPoints.push_back(p);
    std::cout << "Turning point " << p.x() << ", " << p.y() << " = " << hImg[p.x()][p.y()] << std::endl;

    hImg[p.x()][p.y()] = 0;

    std::pair<dlib::point, dlib::point> line = ht.get_line(p);

    dlib::draw_line(temp, line.first+5, line.second+5, dlib::rgb_pixel(255,255,0));
}

在第一次循环迭代后产生相同的值:

Turning point 595, 584 = 78540
Turning point 595, 584 = 0
Turning point 595, 584 = 0

在 DLIB 中是否有 "correct" 方法通过 hough space 进行过滤?

更新: 正如 Davis King 指出的那样,我交换了坐标 (row, col) 与 (x, y) 解决了眼前的问题,但核心问题仍然存在。 我的想法 space 看起来像这样:

可以看出,有许多局部最大值,但一切都被中间的巨大斑点所支配。我最初的想法是每个模糊区域都可以减少到一个最主要的点

我正在考虑对超过特定阈值的每个点进行聚类,但是循环遍历整个图像以找到这些点并将找到的点提供给聚类算法的效率非常低,因此必须有一种更聪明的方法,也许是可以抑制图像本身的内边缘(小物体,如不规则的杂乱)?

您交换了行和列。 hImg[p.x()][p.y()] = 0;倒过来,应该是hImg[p.y()][p.x()] = 0;