博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
多目标跟踪的评价指标
阅读量:6479 次
发布时间:2019-06-23

本文共 3368 字,大约阅读时间需要 11 分钟。

多目标跟踪的评价指标

读“Evaluating Multiple Object Tracking Performance: The CLEAR MOT Metrics”笔记。


对于多目标追踪问题,我们认为一个理想的评价指标应该满足下述三点要求:

  1. 所有出现的目标都要能够及时找到

  2. 找到目标位置要尽可能可真实目标位置一致

  3. 保持追踪一致性,避免跟踪目标的跳变 each object should be assigned a unique track ID which stays constant throughout the sequence.

这三点要求给了设计MOT评价metric的启发:

  1. metrics应该能够评价tracker输出结果和真实结果location上的误差精度

  2. metrics应该要能够反映出tracker长时间持续追踪目标结构的能力,即追踪到正确的目标轨迹的能力

另外,关于metric的一般要求:

  1. metric参数(包括可调节的阈值等)要尽可能的少,才能使评估过程简单直接,实验结果可对比性较强

  2. metric要尽可能的直观,易理解,特别是要容易区分不同类型的误差

  3. metric应具有较强的适应性,对于MOT的评价指标而言要能够适应2D和3D的不同情况

  4. metric的个数要尽可能的少,尽量少的指标却具有很高的表达能力

论文根据上述的criteria提出了一种MOT问题系统、客观的评价过程。

假设对于每一帧的图像中有目标1027162-20161008113852004-1013708382.png,tracker在该帧输出的假设为1027162-20161008113852348-856487391.png,那么评价过程包含以下步骤:

  1. 建立目标和假设间的最优一一对应关系,称之为correspondence

  2. 对所有的correspondence,计算位置偏移误差(the error in the object's position estimation)

  3. 累积结构误差(object configuration error)

    a. 计算漏检数,objects for which no hypothesis was output
    b. 计算虚警数,hypothesis for which no real objects exists
    c. 跟踪目标发生跳变的次数,the number of occurrences where the tracking hypothesis for an object changed compared to previous frames

接下来仔细分析该过程的具体实现:

  • 如何确定一一对应关系(valid correspondences)

    最朴素的想法就是在目标和假设间,采取最近邻的方法,将相互距离最小的假设匹配给对应的目标。但是这存在一个问题,对于人而言,存不存在对应关系是有一个距离限制的,如果假设1027162-20161008113852817-888976975.png和目标1027162-20161008113853426-358432848.png的距离满足1027162-20161008113854098-1817396794.png但是1027162-20161008113854614-610335400.png,1027162-20161008113855223-1995719095.png是某个距离阈值,那我们也应该视假设1027162-20161008113855817-1472295540.png和目标1027162-20161008113856254-713458749.png不存在对应关系,这时候目标1027162-20161008113856817-338631786.png应该是一个漏检目标。
    如下图

enter description here
valid correspondence.jpg
其中
1027162-20161008113858395-1600775488.png时刻都是有效的对应,而
1027162-20161008113858692-2125872145.png时刻显然并不认为是有效匹配。
在实际应用中,距离可以采用欧氏距离计算,而阈值T可以设置为假设和目标最少重叠(overlap)时两者中心的距离。

  • 如何刻画追踪一致性

    追踪一致性能力就是指追踪器使追踪假设和对应目标长时间保持对应关系不变的能力。

一种方式是首先寻找目标和假设间的一个最优对应1027162-20161008113859192-2009326953.png,或者是出现频率最大的对应,然后将其余出现的所有和这个对应不同的对应视为错误匹配,如下图,我们将出现频率最大的对应视为正确的对应关系,然后case1下出现2次错误对应,case2条件下出现4次错误对应。

enter description here
match errors.jpg
然后这种方式有时候并不符合常理,我们关注的应该是对应发生转变的那一帧,而不是由对应跳变帧带来的其余帧对应的变化。所以论文中给的方法是仅仅统计对应出现跳变的次数。这样的话,上图中case1和case2均仅出现一次跳变。假设直到时刻
1027162-20161008113900926-770183414.png的目标-假设对应关系表示为
1027162-20161008113902067-39250261.png,若在
1027162-20161008113902489-1801631693.png时刻出现假设
1027162-20161008113902817-1547608206.png使得
1027162-20161008113903410-520307370.png不再
1027162-20161008113904192-1482698348.png中,则可以计做一次错误,在
1027162-20161008113904707-1761138289.png时刻的目标-假设映射表
1027162-20161008113905207-808759410.png中将
1027162-20161008113905754-549651715.png取代
1027162-20161008113906067-1600123946.png。这里说直至
1027162-20161008113906364-765739966.png时刻的目标-假设映射表而不是
1027162-20161008113906692-1915268754.png时刻的映射表是因为有时correspondence出现丢失时,之前的对应关系应该得到保留。
为了降低错误率,减少对应发生跳变的次数,可以在同一目标存在多个valid correspondence时,选择已经存在的correspondence,如下图,在直至
1027162-20161008113907051-1640741211.png时刻的目标-假设mapping中存在
1027162-20161008113907473-962020570.png,在
1027162-20161008113907801-1844167531.png时刻出现两个有效的correspondence,
1027162-20161008113908176-826479358.png,而且这时候的距离
1027162-20161008113908567-858934034.png,但这时候我们选择
1027162-20161008113909817-445589246.png.

enter description here
correct reinitialization.jpg

  • 具体过程

    1. 1027162-20161008113910957-1143104761.png帧,考虑1027162-20161008113911457-177400265.png映射中的每一个对应1027162-20161008113911848-1088598381.png,验证其是否依然有效

    2. 对于那些上一步没有找到对应假设的目标,在新的假设集中寻找最佳匹配,这个时候所谓的最佳匹配时让总的目标-假设距离最小,比如两个待匹配的目标1027162-20161008113912098-1941544901.png,1027162-20161008113912379-1159579240.png都是其有效对应,如何匹配两个对映集就要求总体的距离和最小,这时候可以使用Munkres' algorithm,这个过程就可以统计匹配发生跳变的次数:如果出现新的1027162-20161008113912801-2001641607.png不在1027162-20161008113913051-174164732.png中,那么在1027162-20161008113913754-1779004678.png中将新的1027162-20161008113914223-688328108.png取代1027162-20161008113914551-1904805935.png以前的对应1027162-20161008113915551-705176086.png,使用1027162-20161008113916176-1615976808.png记录1027162-20161008113916942-2021913042.png时刻出现这种跳变的次数。

    3. 经过之前两步,可以找到所有的correspondence,所有的correspondence个数记为1027162-20161008113917629-996306347.png,计算每一个correspondence计算目标和假设建的距离1027162-20161008113917989-266592495.png

    4. 剩下的未找到correspondence的目标和假设个数分别记为1027162-20161008113918817-1041248925.png1027162-20161008113923051-1342385361.png。并使用1027162-20161008113923989-574911042.png表示1027162-20161008113924817-979326810.png时刻真正目标的个数。

    5. 从第一帧开始逐帧计算上述变量。对于第1帧初始的1027162-20161008113925504-1840263574.png而言,1027162-20161008113926020-232091064.png是空的,也就意味着第1帧找到的所有匹配都是正确的,没有发生conflict。

      最终的两个统计量为:

  • MOPT The multiple object tracking precision 也就是假设与对应目标的平均偏差

1027162-20161008113926473-987905524.png
  • MPTA The multiple object tracking accuracy

1027162-20161008113926832-213574764.png

其中

a. 1027162-20161008113927364-1600179057.png计算的是tracking过程总体的漏检率
b. 1027162-20161008113927832-878295924.png计算的是tracking过程总体的误检,也就是虚警率。
c. 1027162-20161008113928676-219862499.png表示tracking中所有目标发生跳变的机率。

显然,MOTP和MOTA两个指标同时很高,那么tracker的性能就越好

Note:这里在计算MOTP和MOTA时,都是计算的整个tracking过程的平均值,而不是每一帧的结果,这是因为单帧计算这些变量然后再计算平均往往会导致和直观上不同的结果。比如下图

enter description here
computing error ratios.jpg
这是一个8帧的数据,前4帧中四个目标都被漏检,从第5帧开始只有
1027162-20161008113929942-225639407.pngvisible,且开始被检测到。这样如果逐帧计算漏检率,在前四帧如果计算漏检率就都是100%,那么总体漏检率为
1027162-20161008113930332-171436714.png,而如果统计所有的错误次数然后计算平均,即按照上面过程中计算方法,漏检率为
1027162-20161008113930817-1459030413.png

之后论文在CLEARs workshops上使用提出的两个metric评价了不同的track system,发现the proposed metrics indeed reflect the strengths and weaknesses of the various used systems in an intuitive and meaningful way, allow for easy comparsion of overall performance, and are applicable to a variety of scenarios.


  1. J.Munkres, Algorithms for the assignment and transportation problems, Journal of Society of Industrial and Applied Mathematics, vol.5 no.1, pp.32-38,1957

转载于:https://www.cnblogs.com/YiXiaoZhou/p/5937980.html

你可能感兴趣的文章
python 测试驱动开发的简单例子
查看>>
Aes 加密简单例子
查看>>
AE 线编辑
查看>>
软件设计之UML—UML的构成[上]
查看>>
[SPLEB]CodeSmith原理剖析(1)
查看>>
如何使用AdMob中介界面?
查看>>
分享一个shell脚本:通过Jumper机器来创建Jumper和target机器账号
查看>>
UITableViewCell分割线不是左对齐的问题
查看>>
CentOS7 编译安装PHP7
查看>>
MySQL常见错误代码及代码说明
查看>>
Cglib动态代理基础使用
查看>>
技术人员,为什么会苦逼
查看>>
使用126邮箱发送邮件的python脚本
查看>>
Maven
查看>>
缓存系统在游戏业务中的特异性
查看>>
Ngrok搭建自己的内网穿透
查看>>
redis的基本数据类型
查看>>
.NET 同步与异步之锁(Lock、Monitor)(七)
查看>>
前端大牛们都学过哪些?
查看>>
在iOS当中发送电子邮件和短信
查看>>