轮廓检测占用了我在计算机视觉中的大部分时间,它需要更快。我已经通过 NEON 指令优化了其他所有内容并进行了矢量化,实际上,轮廓检测在轮廓中占主导地位。不幸的是,我不清楚如何优化它。
我正在执行经典的矩形检测过程来查找基准标记,即 cvFindContours(),然后从轮廓近似正方形。在许多标记可见的情况下(或灾难性的,当不可见标记的密集矩形网格可见时),单独调用 cvFindContours() 在 iPhone 上可能需要超过 30 毫秒。
我已经用 cvFindContours() 替换了极其昂贵的 C++ cv::FindContours()。特别是如果传递一个向量 >,C++ 版本分配和填充向量的时间比其内部 cvFindContours() 花费的时间长!
现在,我完全被 cvFindContours 中的时间所束缚,或者更具体地说,在 cvFindNextContour() 中。cvFindNextContour 中的代码是分支繁重的,并且显然不容易矢量化。它还实现了一个复杂的算法,我不相信自己在任何优化尝试中都不会出错。
我已经看过 cvBlobLib(为了消除歧义,我指的是这个:http ://code.google.com/p/cvblob/ ),看看它是否提供了可以更快地完成同样事情的替代算法。源的基本下载非常慢,因为它将轮廓记录到 std::list() 中,并且几乎所有时间都花在内存分配上。用一个预先调整为 256 个元素的 std::vector 替换该列表以消除 push_back() 上的初始副本,仍然会得到一个比 cvFindContours() 长 3 倍的函数,其中 66% 直接在 cvb::cvLabel( )。所以走这条路似乎不太可行。
有没有人对我如何优化对许多矩形的检测有任何想法。我含糊的挥手包括:
是否有任何与 cvFindContour() 等效的快速实现,理想情况下作为源代码,因为我是多平台的,在那里?
大多数轮廓不是必需的,只有“成功”的矩形有用。特别是,它们的内部轮廓就没有用了。从理论上讲,我可以根本不调用 cvFindContours,而是调用 cvStartFindContours/cvFindNextContour,测试找到的每个轮廓,如果我找到了我正在寻找的矩形,则不递归,因为子矩形保证是无用的?
我可以从经典的 FindContours()/ApproxPoly() 方法中使用完全不同的矩形检测算法吗?
有没有办法用有用的感兴趣区域“准备”cvFindContours?例如,即使使用非常激进的阈值,FAST 角点检测几乎总是会返回我的基准标记角点。有没有办法使用该点来限制检测?(不幸的是,我不确定这有多大帮助,同样在许多标记或与标记无关的密集网格线的情况下,这在我的应用程序中经常发生。)
与上述相同,由于 Blob 检测可以(如果我理解正确的话)实现为递归洪水填充,是否有任何快速矢量化实现可以用于以某种方式提取有趣的 Blob 矩形和种子轮廓检测从那里?
欢迎任何想法!