transbigdata 笔记: 官方文档示例3:车辆轨迹数据处理

1 读取数据+ 轨迹数据质量分析

这一部分和

transbigdata笔记:data_summary 轨迹数据质量/采样间隔分析-CSDN博客 的举例是一样的

import pandas as pd
import geopandas as gpd
import transbigdata as tbd


data = pd.read_csv('Downloads/TaxiData-Sample.csv', 
                   names=['VehicleNum', 'Time', 'Lng', 'Lat', 'OpenStatus', 'Speed'])
data

data['Time'] = pd.to_datetime(data['Time'])
data

tbd.data_summary(data,
                 col=['VehicleNum','Time'],
                show_sample_duration=True)

2 清除冗余点

这一个函数的详细用法可见:transbigdata笔记:数据预处理-CSDN博客

data=tbd.traj_clean_redundant(data,col=['VehicleNum','Time','Lng','Lat'])
data

3 清理不在研究区域的记录

transbigdata 笔记:官方文档案例1(出租车GPS数据处理)-CSDN博客 和这边的是一样的

sz = gpd.read_file('Downloads/sz.json')
sz.plot();

data=tbd.clean_outofshape(data,sz,col=['Lng','Lat'],accuracy=500)
data

4 清理研究区域内的轨迹漂移

transbigdata笔记:清理研究区域内的轨迹漂移-CSDN博客

data=tbd.traj_clean_drift(data,
                         col=['VehicleNum','Time','Lng','Lat'])
data

5 轨迹停止点和行程提取

transbigdata笔记:轨迹停止点和行程提取-CSDN博客

stay,move=tbd.traj_stay_move(data,
                            params,
                            col=['VehicleNum','Time','Lng','Lat'])
stay

停留状态开始时间、对应栅格编号、停留状态结束时间、轨迹所在位置、持续时间


move

 开始栅格、开始位置、结束位置、结束栅格

6 轨迹切片

transbigdata笔记:轨迹切片-CSDN博客

stay_points=tbd.traj_slice(data,
                          stay,
                          traj_col=['VehicleNum','Time'],
                          slice_col=['VehicleNum','stime', 'etime', 'stayid'])
stay_points

move_points=tbd.traj_slice(data,
                          move,
                          traj_col=['VehicleNum','Time'],
                          slice_col=['VehicleNum','stime', 'etime', 'moveid'])
move_points

7 轨迹密集化 

transbigdata 笔记: 轨迹密集化/稀疏化 & 轨迹平滑-CSDN博客

move_points_d2=tbd.traj_densify(move_points,
                              col=['moveid','Time','Lng','Lat'],
                              timegap=29)

每timegap秒有一个记录,用pandas的interpolate(method为index)实现

原来采样频率不是timegap的倍数,怎么办呢

move_points_d[move_points_d['moveid']==0.0].head(30)

通过结果(包括源码)可以发现,从move_points的最早的时刻开始,每timegap时刻就会有一条记录,和原先的记录一并存在【换句话说,至多每隔timegap秒都有一个轨迹点】

8 轨迹 稀疏化

transbigdata 笔记: 轨迹密集化/稀疏化 & 轨迹平滑-CSDN博客

move_points_s=tbd.traj_sparsify(move_points,
                               col=['moveid','Time','Lng','Lat'],
                               timegap=30,
                               method='subsample')

如果method是subsample,那么选取[t,t+subsample)这个时间段内第一次出现的记录,丢弃其他记录,如果某一个[t,t+subsample)时间段内没有数据,不用补值

如果method是interpolate的,那么就是从最开始的位置开始,每subsample秒 用pandas的interpolate方法插一个值,舍弃所有不在整subsample秒的原始记录

9 轨迹平滑

transbigdata 笔记: 轨迹密集化/稀疏化 & 轨迹平滑-CSDN博客

move_points_smooth=tbd.traj_smooth(move_points,
                                col=['VehicleNum','Time','Lng','Lat'],
                                process_noise_std=0.1,
                                measurement_noise_std=0.1)

  • 9
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
这段代码的作用是将输入的二维矩阵 `data` 沿着行方向进行一次小波变换,并返回变换后的矩阵 `trans_data`。 - `function [ trans_data ] = row_trans( data )`:定义了一个名为 `row_trans` 的函数,该函数有一个输入参数 `data`,表示需要进行小波变换的二维矩阵,返回值为变换后的矩阵 `trans_data`。 - `[row, col] = size(data);`:获取输入矩阵 `data` 的行数和列数,并将它们分别赋值给变量 `row` 和 `col`。 - `trans_row = row / 2;`:计算变换后矩阵的行数,即输入矩阵行数的一半,并将其赋值给变量 `trans_row`。 - `trans_data = zeros(row, col);`:初始化变换后的矩阵 `trans_data`,使其大小与输入矩阵 `data` 相同,并将其元素全部赋值为 0。 - `for i = 1 : trans_row`:循环变量 `i` 从 1 到 `trans_row` 进行遍历,表示要对前一半行进行小波变换。 - `for j = 1 : col`:循环变量 `j` 从 1 到 `col` 进行遍历,表示要对每一列进行小波变换。 - `trans_data(i, j) = (data(i * 2 - 1, j)+data(i * 2, j))/2 ;`:对输入矩阵 `data` 中的第 `i*2-1` 行和第 `i*2` 行的元素进行平均,并将结果赋值给变换后矩阵 `trans_data` 中的第 `i` 行和第 `j` 列的元素。 - `for i = trans_row + 1 : row`:循环变量 `i` 从 `trans_row + 1` 到 `row` 进行遍历,表示要对后一半行进行小波变换。 - `for j = 1 : col`:循环变量 `j` 从 1 到 `col` 进行遍历,表示要对每一列进行小波变换。 - `trans_data(i, j) = data((i - trans_row) * 2 - 1, j) - trans_data(i - trans_row, j);`:对输入矩阵 `data` 中的第 `(i - trans_row) * 2 - 1` 行和第 `j` 列的元素与变换后矩阵 `trans_data` 中的第 `i - trans_row` 行和第 `j` 列的元素进行差值运算,并将结果赋值给变换后矩阵 `trans_data` 中第 `i` 行和第 `j` 列的元素。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

UQI-LIUWJ

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值