Python路面平整度检测车辆数据——速度修正

全文链接:http://tecdat.cn/?p=31268

原文出处:拓端数据部落公众号

分析师:Bohao Zhan

目前主流的轻量化路面平整度检测技术方案为:使用车载加速度传感器采集车辆在路面上行驶时的竖向振动数据,并按照每100米计算竖向振动数据统计指标:均方根值RMS,并建立RMS与路面平整度指标:IRI之间的回归模型。检测前需要将车辆行驶至标准路段(即已知IRI真值的路段)上来回行驶对传感器进行标定,完成标定后驾驶车辆前往待检测路段进行平整度检测。

目前该技术方案的难点在于,对于同一IRI值的路面,若驾驶同一车辆以不同的行驶速度驶过,测得的振动数据统计指标也会不同,即车辆行驶速度是影响检测结果的主要因素之一。在标定工作中,车辆会被要求已恒定速度行驶进行标定,而实际测量时,车辆的速度往往会随道路交通状况、路况、天气等因素无法维持恒定的速度,导致车辆在检测过程中时的车辆行驶速度时快时慢,严重影响检测结果精度。因此,对检测数据结果进行速度修正(即将车辆某一检测速度下的测量值转换成当量速度下的测量值),是一件急迫且必需的事情。

解决方案

任务目标

基于不同车速下的平整度检测车辆振动数据结果,探究车速与检测结果之间的关系,根据此关系进行速度修正,将不同车速下的检测结果转换成当量速度下的检测结果。

使用到的工具 / 语言

Matlab、Python、Mysql、Navicat。

数据 获取

平整度检测车辆每天会在上海外环高速固定某一路段上进行检测,检测数据(包括振动加速度数据、GPS定位数据、图像数据等)会定时上传至数据库内,需要从数据库中将检测数据批量下载至本地进行分析,其中,需要下载的数据表包括acc表、gps表、stake_info表。

Python路面平整度检测车辆数据——速度修正_第1张图片

图1 MySQL数据库中数据

Python路面平整度检测车辆数据——速度修正_第2张图片

(a)

Python路面平整度检测车辆数据——速度修正_第3张图片

(b)

图2 从数据库抓取数据Python脚本(部分)

编写python脚本从数据库中抓取指定时间的数据,脚本中包括部分mysql语句用于筛选数据。使用表关联命令将acc与gps表以时间为key关联起来,并保存至本地。共从数据库中抓取57天检测数据用于后续分析。

数据清洗

将57天车辆轨迹散点(红)画于图中,同时标注待检测路段桩号点(蓝),发现检测车辆并不是完全按照预定路线进行检测,有诸多路段是多检路段,将影响后续计算结果。将相邻桩号点连接形成若干个线段。对于车辆每一个轨迹散点,找到离该点最近的桩号线段,并计算该点到桩号线段的距离,设定阈值,将阈值外的轨迹散点剔除,保留阈值范围内轨迹散点(蓝)。

Python路面平整度检测车辆数据——速度修正_第4张图片
图3 检测车辆轨迹散点与桩号点

(横坐标:经度,纵坐标:纬度)

此外,还包括的数据预处理包括加速度数据去均值与车辆轨迹散点桩号重计算。对车辆每一个轨迹散点的桩号进行修正。

数据处理与分析

对于每一天的车辆轨迹数据,按照上述方法进行数据清洗,从桩号起点至桩号终点,每100米划分小路段并编号,选出该路段范围内的加速度数据并计算统计指标RMS。计算第k天数据后将结果表格与第k+1天结果表格按照小路段编号进行关联。得到各小路段在不同天下车辆的检测数据,且每一天的车辆行驶速度均是不同的,也就得到了对于同一路段(即相同IRI值路面),不同车辆行驶速度下的振动数据统计指标。将两者散点画于图中,不同路段部分结果如下所示。

Python路面平整度检测车辆数据——速度修正_第5张图片

Python路面平整度检测车辆数据——速度修正_第6张图片

Python路面平整度检测车辆数据——速度修正_第7张图片

(c)

图4 速度与RMS散点图

(横坐标:速度(km/h)、纵坐标:RMS)

建立模型

从每一路段速度与RMS散点图中可看出二者之间存在较强的线性关系,建立两者之间线性模型,所有路段散点图与线性拟合结果如下图所示。从图中可看出不同IRI值路面,检测车辆速度与检测结果统计指标RMS均存在较强的线性关系,对于不同的IRI值路面,其表现出线性的斜率不同。从下图中可看出所有直线的截距虽然主要集中于0~0.1范围内,但仍表现较为分散。按照常理,对于不同IRI值路面,当测量速度为0时,此时车辆振动仅由车辆发动机提供,因此表现出的统计指标RMS应当为同一值。分析原因,认为由于外环道路等级为高速公路,故数据中低速样本较少所致。

Python路面平整度检测车辆数据——速度修正_第8张图片

图5 速度-RMS散点图与拟合直线

(横坐标:速度(km/h)、纵坐标:RMS)

模型优化

统计每一条直线截距值,画出其分布直方图(图6),发现截距在0.05至0.1区间内频率最高,取频率最高值0.07作为所有直线的共同截距,重新对各条路段数据进行线性拟合,拟合结果如图7所示。

Python路面平整度检测车辆数据——速度修正_第9张图片

图6 拟合直线截距分布直方图

Python路面平整度检测车辆数据——速度修正_第10张图片

图7 改进后的拟合结果

得出平整度检测车辆检测结果速度修正方案,对于每一条路段在不同车辆速度下的振动数据统计指标RMS,减去同一截距0.07。取当量速度为70km/h,按照各路段线性拟合直线斜率将不同速度下的检测结果修正至70km/h速度下的检测值。

关于作者

Python路面平整度检测车辆数据——速度修正_第11张图片

在此对Bohao Zhan对本文所作的贡献表示诚挚感谢,他在同济大学完成了控制工程硕士学位,擅长数据采集、数据分析。


Python路面平整度检测车辆数据——速度修正_第12张图片
最受欢迎的见解

1.[](http://tecdat.cn/r%e8%af%ad%e...)R语言多元Logistic逻辑回归 应用案例

2.[](http://tecdat.cn/r%e8%af%ad%e...)面板平滑转移回归(PSTR)分析案例实现

3.[](http://tecdat.cn/r%e8%af%ad%e...)matlab中的偏最小二乘回归(PLSR)和主成分回归(PCR)

4.[](http://tecdat.cn/r%e8%af%ad%e...)R语言泊松Poisson回归模型分析案例

5.[](http://tecdat.cn/r%e8%af%ad%e...)R语言混合效应逻辑回归Logistic模型分析肺癌

6.[](http://tecdat.cn/r%e8%af%ad%e...)r语言中对LASSO回归,Ridge岭回归和Elastic Net模型实现

7.[](http://tecdat.cn/r-%e8%af%ad%...)R语言逻辑回归、Naive Bayes贝叶斯、决策树、随机森林算法预测心脏病

8.[](http://tecdat.cn/r%e8%af%ad%e...)python用线性回归预测股票价格

9.[](http://tecdat.cn/r%e8%af%ad%e...)R语言用逻辑回归、决策树和随机森林对信贷数据集进行分类预测

你可能感兴趣的:(数据挖掘深度学习机器学习算法)