【自动驾驶】【车辆轨迹与驾驶行为分析】【汇入行为】

2023-10-25 10:40

本文主要是介绍【自动驾驶】【车辆轨迹与驾驶行为分析】【汇入行为】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

B站搜索“轨迹说”,有相应的汇入行为挖掘教程视频
个人网址:www.vehicletrajectorymining.com

1. 文章引用

有关汇入行为的分析,基本都能在如下这篇文章中找到,相应的Python源代码也公开在Github上,感兴趣的小伙伴可以自行去下载。

@article{Yang Li, 2023"https://arxiv.org/abs/2303.11531"title={A reproducible approach to merging behavior analysis based on High Definition Map}, author={Yang Li and Yang Liu and Daiheng Ni and Ang Ji and Linbo Li and Yajie Zou},year={2023},eprint={2303.11531},archivePrefix={arXiv},primaryClass={cs.RO}
}

2. 代码项目框架

整个项目由Python编写,大致的目录如下所示:

A reproducible approach to merging behavior analysis based on High Definition Map/
|__ asset: analysis results
|    |__ acceptedGaps
|    |__ backgroundPicture
|    |__ consecutiveLaneChange
|    |__ JSDivergence
|    |__ preliminaryAnalysis
|    |__ safetyAnalysis
|    |__ table
|    |__ trafficFlowSpeed
|__ conf: experiment configurations
|    |__ lanelet2map
|__ drone-dataset-tools-master: dataset
|__ src: merging trajectories extraction, indicators calculation, results visulization
|    |__ extraction
|    |__ figure
|    |    |__accepetedGapAnalysis
|    |    |__consecutiveLanechangeAnalysis
|    |    |__preliminaryAnalysis
|    |    |__safetyAnalysis
|    |    |__similarityAnalysis
|    |    |__trafficFlowSpeedDensity
|    |__ table
|__ utils: utility functions
|__ requirements.txt: required packages

3. 分析内容

3.1 汇入区域的lanelet2高精地图的应用

以下是exiD数据集汇入地点2的高精地图示例,我们可以拿一辆车的轨迹举个例子:

  • 位置B:车辆由on-ramp驶进加速车道;
  • 位置D:车辆左侧的车道线,由实线变为虚线,车辆此后可以进行汇入;
  • 位置F:车辆的中心点压在虚线初,此时车辆半身已进入主线车道;

按照交通法规,车辆应该区域2和区域3汇入主线,但其实还有很多车辆由区域1汇入主线(压着实线)。上面的三个关键点位,我们可以根据车辆每一帧的laneletID来识别,从而统一标准。倘若我们不结合高精地图,仅仅只依靠轨迹数据来判别这三个点位还是挺难实现的。

在这里插入图片描述

3.2 指标构建

我们可以基于上述三个点位定义一些标准化的指标,我这边提及的是“标准化”这个词,因为只有在这些点位统一的基础上所构建的各种指标,才更能客观地横向或者是纵向进行对比分析。我们可以定义如下指标:

微观指标包含:

1. 汇入速度:平均或者是某一帧;
2. 汇入时长:位置D到位置F,或者位置D到位置F;
3. 汇入距离:位置D到位置F,或者位置D到位置F;
4. 汇入距离比:汇入距离除以加速车道总长度;
5. 汇入纵向轨迹:可以根据高精地图中的lateralcenteroffset字段求得;
6. 汇入纵向速度:可以根据高精地图中的lateralcenteroffset字段求得(拟合,再求导);
7. 汇入纵向加速度:可以根据高精地图中的lateralcenteroffset字段求得(拟合,再求导);;
8. 汇入安全性:衡量某一帧,还是衡量一个duration,比如有:TTC, TET, TIT, DRAC, PET等指标。

宏观指标包含:

 1. 交通流量;2. 交通密度;3. 空均车速;
3.3 周边车辆匹配

在exiD数据集中,各车每一帧都会至多包含八辆车,主要就是前车,后车以及并行车辆:

 1. lead vehicle2. left lead vehicle3. right lead vehicle4. rear vehicle5. left rear vehicle6. right rear vehicle7. leftalongside vehicle8. rightalongside vehicle

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

3.4 场景细分

在一整个汇入过程中,汇入车辆可能同时存在着前后车,也有可能只存在前车,也有可能只存在后车,也有可能原本在位置D的后车变为了在位置F的前车,因而,我们大致可以讲汇入场景细分为8种。

  1. 我们这样的划分是否合理?现有的研究是否有考虑这样的划分?
  2. 不同场景下的各种指标是否存在显著差异?如何去衡量?
  3. 哪种场景更可能伴随着高风险呢?
  4. 后续怎么去细化?
    在这里插入图片描述
    针对每一个微观或者是宏观的指标,都可以进行深入地分析,感兴趣的小伙伴可以开辟不同的分支开发。
3.5 一些结果

这里放几张原图,感兴趣的小伙伴可以去看原文。

  • 我们将某个地点中不同类型车辆在位置F处的位置,撒到汇入区域的地图上可以获得下图:
    在这里插入图片描述

  • 随机挑选的八条汇入轨迹,其所对应的lanelet2高精地图的latcenteroffset的变化值,跳变的时刻也就是位置F处:
    在这里插入图片描述

  • 不同地点,不同类型车辆的汇入速度,距离,距离比,时长,纵向最大速度,纵向最大加速度的Boxplot图。

在这里插入图片描述

  • 不同地点,不同距离阈值,不同汇入模式下,汇入距离变量的JS散度值热力图。
    在这里插入图片描述

4. 小结

撰写文章属实不易,麻烦大家多多点赞收藏。

感兴趣的小伙伴,可以去阅读原文,这篇博客算是一个引子吧,供大家参考。

原文传递,https://arxiv.org/abs/2303.11531
B站搜索“轨迹说”,有相应的汇入行为挖掘教程视频
个人网址:www.vehicletrajectorymining.com

有任何问题,欢迎私信。

这篇关于【自动驾驶】【车辆轨迹与驾驶行为分析】【汇入行为】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/281999

相关文章

Olingo分析和实践之EDM 辅助序列化器详解(最佳实践)

《Olingo分析和实践之EDM辅助序列化器详解(最佳实践)》EDM辅助序列化器是ApacheOlingoOData框架中无需完整EDM模型的智能序列化工具,通过运行时类型推断实现灵活数据转换,适用... 目录概念与定义什么是 EDM 辅助序列化器?核心概念设计目标核心特点1. EDM 信息可选2. 智能类

Olingo分析和实践之OData框架核心组件初始化(关键步骤)

《Olingo分析和实践之OData框架核心组件初始化(关键步骤)》ODataSpringBootService通过初始化OData实例和服务元数据,构建框架核心能力与数据模型结构,实现序列化、URI... 目录概述第一步:OData实例创建1.1 OData.newInstance() 详细分析1.1.1

Olingo分析和实践之ODataImpl详细分析(重要方法详解)

《Olingo分析和实践之ODataImpl详细分析(重要方法详解)》ODataImpl.java是ApacheOlingoOData框架的核心工厂类,负责创建序列化器、反序列化器和处理器等组件,... 目录概述主要职责类结构与继承关系核心功能分析1. 序列化器管理2. 反序列化器管理3. 处理器管理重要方

SpringBoot中六种批量更新Mysql的方式效率对比分析

《SpringBoot中六种批量更新Mysql的方式效率对比分析》文章比较了MySQL大数据量批量更新的多种方法,指出REPLACEINTO和ONDUPLICATEKEY效率最高但存在数据风险,MyB... 目录效率比较测试结构数据库初始化测试数据批量修改方案第一种 for第二种 case when第三种

解决1093 - You can‘t specify target table报错问题及原因分析

《解决1093-Youcan‘tspecifytargettable报错问题及原因分析》MySQL1093错误因UPDATE/DELETE语句的FROM子句直接引用目标表或嵌套子查询导致,... 目录报js错原因分析具体原因解决办法方法一:使用临时表方法二:使用JOIN方法三:使用EXISTS示例总结报错原

MySQL中的LENGTH()函数用法详解与实例分析

《MySQL中的LENGTH()函数用法详解与实例分析》MySQLLENGTH()函数用于计算字符串的字节长度,区别于CHAR_LENGTH()的字符长度,适用于多字节字符集(如UTF-8)的数据验证... 目录1. LENGTH()函数的基本语法2. LENGTH()函数的返回值2.1 示例1:计算字符串

Android kotlin中 Channel 和 Flow 的区别和选择使用场景分析

《Androidkotlin中Channel和Flow的区别和选择使用场景分析》Kotlin协程中,Flow是冷数据流,按需触发,适合响应式数据处理;Channel是热数据流,持续发送,支持... 目录一、基本概念界定FlowChannel二、核心特性对比数据生产触发条件生产与消费的关系背压处理机制生命周期

SpringBoot+Docker+Graylog 如何让错误自动报警

《SpringBoot+Docker+Graylog如何让错误自动报警》SpringBoot默认使用SLF4J与Logback,支持多日志级别和配置方式,可输出到控制台、文件及远程服务器,集成ELK... 目录01 Spring Boot 默认日志框架解析02 Spring Boot 日志级别详解03 Sp

怎样通过分析GC日志来定位Java进程的内存问题

《怎样通过分析GC日志来定位Java进程的内存问题》:本文主要介绍怎样通过分析GC日志来定位Java进程的内存问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、GC 日志基础配置1. 启用详细 GC 日志2. 不同收集器的日志格式二、关键指标与分析维度1.

MySQL中的表连接原理分析

《MySQL中的表连接原理分析》:本文主要介绍MySQL中的表连接原理分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、环境3、表连接原理【1】驱动表和被驱动表【2】内连接【3】外连接【4编程】嵌套循环连接【5】join buffer4、总结1、背景