opencv 基于图像处理的直线跟踪器

bqucvtff  于 2022-12-13  发布在  其他
关注(0)|答案(2)|浏览(175)

我开始在一个线跟踪器项目上工作,但它要求我使用图像处理技术。我有一些想法要考虑,但我希望一些输入,因为有一些疑问,我想澄清。这是我解决这个问题的方法:我首先读取图像,然后应用阈值来检测对象(线)。我进行颜色过滤,然后进行边缘检测。在此之后,我开始进行图像分类,以检测所有的线,然后外推这些线,以仅输出/检测平行线(类似于车道检测算法)。通过这些平行线,我可以计算中心,以保持我的车辆居中,并计算转弯的Angular 。
我不知道路径中的Angular ,所以系统必须能够旋转任何Angular ,这就是为什么我将计算Angular 。我已经包括了一个带转弯的线的图片,这是我将处理的转弯类型。我已经设法实现了几乎所有的东西。我的主要问题是在Angular 的变化,基本上是转弯。在我检测到平行线后,我怎样才能让我的系统知道什么时候该转弯呢?2这个问题可能有点令人困惑,但基本上只要Angular 接近于零,车辆就会向前行驶。3但当车辆接近转弯时,它可能会检测到两组平行线。也许我可以定义检测到的线的长度,这将定义车辆是否必须前进?
如有任何意见,我们将不胜感激。

h43kikqp

h43kikqp1#

如果有两条线(每条路径的中心线):

y1 = m1 * x + b1
y2 = m2 * x + b2

当你选择一个x,使得y1和y2相等时,它们相交(如果它们不平行,那么m1!= m2)

m1 * x + b1 = m2 * x + b2

(do一堆代数)

x  = (b2 - b1) / (m1 - m2)
(y should be the same for both line formulas)

当你接近这一点时,换线。
注意:这不会处理完全垂直的直线,因为它们有无限大的斜率,没有y轴截距--关于这一点,请参见parametric form of lines。每行有两个方程:

x = f1(t1)
y = f2(t1)

x = f3(t2)
y = f4(t2)

设置f1(t1) == f3(t2)f2(t1) == f4(t2)以查找非平行线的交点。然后将t1插入第一个线条公式以查找(x, y)

gmxoilav

gmxoilav2#

基本上,answerLou Franco解释了你如何得到每条路径的两条中心线的交点,然后那个交点就是开始转弯的好点。
我想添加一个关于如何计算路径中心线的建议。
根据我的经验,当处理从图像中提取的线的浮点表示时,这些线实际上从来不平行,它们通常只是在图像之外的一个点相交(可能很远)。
下面的C++函数bisector_of_lines的灵感来自CGAL源代码中的bisector_of_linesC2方法。
直线表示为a*x+b*y+c=0,下面的函数构造两条直线pq的平分线。
line p is pa*x+pb*y+pc=0
line q is qa*x+qb*y+qc=0
平分线的abc是函数的最后三个参数:abc中的一个或多个。
在一般情况下,平分线的方向是两条直线的归一化方向之和,并通过pq的交点。如果pq平行,则平分线定义为与p方向相同的直线。并且与pq的距离相同(请参阅CGAL::Line_2<Kernel> CGAL::bisector的官方CGAL文档)。

void
bisector_of_lines(const double &pa, const double &pb, const double &pc,
            const double &qa, const double &qb, const double &qc,
            double &a, double &b, double &c)
{
  // We normalize the equations of the 2 lines, and we then add them.
  double n1 = sqrt(pa*pa + pb*pb);
  double n2 = sqrt(qa*qa + qb*qb);
  a = n2 * pa + n1 * qa;
  b = n2 * pb + n1 * qb;
  c = n2 * pc + n1 * qc;

  // Care must be taken for the case when this produces a degenerate line.
  if (a == 0 && b == 0) {// maybe it is best to replace == with https://stackoverflow.com/questions/19837576/comparing-floating-point-number-to-zero
    a = n2 * pa - n1 * qa;
    b = n2 * pb - n1 * qb;
    c = n2 * pc - n1 * qc;
  }
}

相关问题