当前位置: 首页 > news >正文

数据关联_3.7

目标

  • 利用匈牙利算法对目标框和检测框进行关联

在这里我们对检测框和跟踪框进行匹配,整个流程是遍历检测框和跟踪框,并进行匹配,匹配成功的将其保留,未成功的将其删除。

def associate_detections_to_trackers(detections, trackers, iou_threshold=0.3):"""将检测框bbox与卡尔曼滤波器的跟踪框进行关联匹配:param detections:检测框:param trackers:跟踪框,即跟踪目标:param iou_threshold:IOU阈值:return:跟踪成功目标的矩阵:matchs新增目标的矩阵:unmatched_detections跟踪失败即离开画面的目标矩阵:unmatched_trackers"""# 跟踪目标数量为0,直接构造结果if (len(trackers) == 0) or (len(detections) == 0):return np.empty((0, 2), dtype=int), np.arange(len(detections)), np.empty((0, 5), dtype=int)# iou 不支持数组计算。逐个计算两两间的交并比,调用 linear_assignment 进行匹配iou_matrix = np.zeros((len(detections), len(trackers)), dtype=np.float32)# 遍历目标检测的bbox集合,每个检测框的标识为dfor d, det in enumerate(detections):# 遍历跟踪框(卡尔曼滤波器预测)bbox集合,每个跟踪框标识为tfor t, trk in enumerate(trackers):iou_matrix[d, t] = iou(det, trk)# 通过匈牙利算法将跟踪框和检测框以[[d,t]...]的二维矩阵的形式存储在match_indices中result = linear_sum_assignment(-iou_matrix)matched_indices = np.array(list(zip(*result)))# 记录未匹配的检测框及跟踪框# 未匹配的检测框放入unmatched_detections中,表示有新的目标进入画面,要新增跟踪器跟踪目标unmatched_detections = []for d, det in enumerate(detections):if d not in matched_indices[:, 0]:unmatched_detections.append(d)# 未匹配的跟踪框放入unmatched_trackers中,表示目标离开之前的画面,应删除对应的跟踪器unmatched_trackers = []for t, trk in enumerate(trackers):if t not in matched_indices[:, 1]:unmatched_trackers.append(t)# 将匹配成功的跟踪框放入matches中matches = []for m in matched_indices:# 过滤掉IOU低的匹配,将其放入到unmatched_detections和unmatched_trackersif iou_matrix[m[0], m[1]] < iou_threshold:unmatched_detections.append(m[0])unmatched_trackers.append(m[1])# 满足条件的以[[d,t]...]的形式放入matches中else:matches.append(m.reshape(1, 2))# 初始化matches,以np.array的形式返回if len(matches) == 0:matches = np.empty((0, 2), dtype=int)else:matches = np.concatenate(matches, axis=0)return matches, np.array(unmatched_detections), np.array(unmatched_trackers)

http://www.lryc.cn/news/325408.html

相关文章:

  • 总结虚函数表机制——c++多态底层原理
  • Contos7 安装 Maven
  • 对适配器模式的理解
  • 纯前端调用本机原生Office实现Web在线编辑Word/Excel/PPT,支持私有化部署
  • 双指针的详细教程
  • 【Review+预测】测试架构演进的曲折之路
  • 2015年认证杯SPSSPRO杯数学建模D题(第二阶段)城市公共自行车全过程文档及程序
  • 视频汇聚平台EasyCVR启用图形验证码之后调用login接口的操作方法
  • 【数据结构】非线性结构——二叉树
  • 数据分析POWER BI之power query
  • 【c语言】详解操作符(上)
  • VR全景展示:传统制造业如何保持竞争优势?
  • 2.7、创建列表(List)
  • solr functionquery函数查询自定义函数实现
  • 如何将 Parallels虚拟机 安装或者迁移到 移动硬盘 or U盘?
  • 大型网站集群管理负载均衡
  • JAVA使用POI实现Excel单元格合并-02
  • 深入了解 Linux 中的 MTD 设备:/dev/mtd* 与 /dev/mtdblock*
  • 2、Spring CLI安装
  • 数据库备份工具(实现数据定时覆盖)
  • 测试环境搭建整套大数据系统(十二:挂载磁盘到hadoop环境)
  • Spring事务核心:声明式事务注解式事务
  • AcWing 1015. 摘花生
  • Dalle-3、Sora、Stable Diffusion 3 掀起AIGC新浪潮
  • Unity 视频组件 VideoPlayer
  • RSTP环路避免实验(华为)
  • Arduino IDE工程代码多文件编程和中文设置
  • 【微服务】Eureka(服务注册,服务发现)
  • windows上ssh设置代理,直接访问公司内网
  • C++ union用法