用java组件纠偏出租车gps采集点

2024-02-25 10:18

本文主要是介绍用java组件纠偏出租车gps采集点,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

用Java组件对出租车GPS采集点进行纠偏

随着技术发展,如今对出租车的运营管理也非常精准,运营公司后台通过实时接收出租车的位置信息,对出租车进行运营调度及安全管理。在位置信息数据的处理方面就离不开gis数据基础处理功能与空间分析功能。本文对位置数据的前期预处理做一个详细的讲解。

  • 数据准备:

    1. 原始上海出租车位置信息数据Taxi_105作为示例,依次为出租车id,采集时间,经度,纬度,速度,方向角,是否载客,如图一

      这里写图片描述

    2. 点数据集模板,用于存储点对象

      这里写图片描述

    3. 上海区域的网络数据集BuildNetwork,用于纠偏gps点坐标。

  • Java组件包:

    基础包com.supermap.data.jar,导航模块包com.supermap.analyst.navigation.jar

  • 处理步骤:

    1. 按行读取位置信息数据

      InputStreamReader read = new InputStreamReader(new FileInputStream(file), encoding);// 考虑到编码格式
      BufferedReader bufferedReader = new BufferedReader(read);
      String lineTxt = null;
      while ((lineTxt = bufferedReader.readLine()) != null)
      {makeRecord(lineTxt);
      }
      
    2. gps坐标信息转为点对象记录,由于gps采集坐标系是wgs84,与路网数据的坐标系是一致的,故不需做投影转换,gps时间戳字段必须转换为时间整型才可进行路网纠偏。

      	private void makeRecord(String lineTxt) throws ParseException{String[] strArray = lineTxt.split(",");// 筛选速度不正常的记录if (Double.valueOf(strArray[4].trim()).doubleValue() > 0.0 && Double.valueOf(strArray[4].trim()).doubleValue() < 100.0){Map values = new HashMap();long time = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").parse(strArray[1]).getTime();values.put("TaxiID", strArray[0].trim());values.put("TimeInfo", time / 1000);values.put("Speed", strArray[4].trim());values.put("Direction", strArray[5].trim());values.put("HasPassenger", strArray[6].trim());GeoPoint point = new GeoPoint(Double.valueOf(strArray[2].trim()).doubleValue(), Double.valueOf(strArray[3].trim()).doubleValue());boolean add = mRecordset.addNew(point, values);point.dispose();values.clear();System.out.println("添加:" + add);}}
      
    3. 用网络数据BuildNetwork构建导航模型文件ssc,注"道路等级"为必填字段,且为整型,且值不为空

      这里写图片描述

    4. 加载导航模型及分析环境:

      		String filePathBJ = "data/NavigationModelAll.ssc";PathAnalyst analyst = new PathAnalyst();// 3.加载文件模型SSCDataEnvironment environment = new SSCDataEnvironment();boolean bConnect = environment.connectData(filePathBJ, netWork);// 4.设置ssc分析环境boolean bEnviron = analyst.setSSCEnvironment(environment);
      
    5. 设置gps点预处理参数:

      		MapMatchParameter parameter = new MapMatchParameter();// GPS预处理参数设置parameter.setDatasetVector(gpsPoint);parameter.setTime("TimeInfo");// 时间戳,必设字段// 5.GPS预处理,只能是单个数据集纠偏,如一个出租车的数据DatasetVector[] point = analyst.prepareData(parameter, "prepareGPSPoint");
      
    6. 预处理数据转gps对象:

      		Map<Integer, Feature> allFeatures = datasetVector.getAllFeatures();GPSData[] gpsDatas = new GPSData[allFeatures.size()];int i = 0;for (Feature f : allFeatures.values()){GPSData gpsData = new GPSData();gpsData.setPoint(f.getGeometry().getInnerPoint());gpsData.setTimeValue((int) f.getInt64(timeinfo));gpsDatas[i] = gpsData;i++;}
      
    7. gps纠偏,找出最优点

      		Point2Ds result_t = analyst.traceRectify(data, 3);// 轨迹纠偏
      
  • 结果展示:

    1. 纠偏前原始点位置

      这里写图片描述

    2. 纠偏后gps点落在路网上

      这里写图片描述

  • 纠偏后的gps坐标点可以正常叠加到地图上,也可以用其做轨迹构建或用于实时路况的计算等等分析。

  • 完成工程下载链接RectifyGPSPoint.rar

这篇关于用java组件纠偏出租车gps采集点的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

springboot集成easypoi导出word换行处理过程

《springboot集成easypoi导出word换行处理过程》SpringBoot集成Easypoi导出Word时,换行符n失效显示为空格,解决方法包括生成段落或替换模板中n为回车,同时需确... 目录项目场景问题描述解决方案第一种:生成段落的方式第二种:替换模板的情况,换行符替换成回车总结项目场景s

SpringBoot集成redisson实现延时队列教程

《SpringBoot集成redisson实现延时队列教程》文章介绍了使用Redisson实现延迟队列的完整步骤,包括依赖导入、Redis配置、工具类封装、业务枚举定义、执行器实现、Bean创建、消费... 目录1、先给项目导入Redisson依赖2、配置redis3、创建 RedissonConfig 配

SpringBoot中@Value注入静态变量方式

《SpringBoot中@Value注入静态变量方式》SpringBoot中静态变量无法直接用@Value注入,需通过setter方法,@Value(${})从属性文件获取值,@Value(#{})用... 目录项目场景解决方案注解说明1、@Value("${}")使用示例2、@Value("#{}"php

SpringBoot分段处理List集合多线程批量插入数据方式

《SpringBoot分段处理List集合多线程批量插入数据方式》文章介绍如何处理大数据量List批量插入数据库的优化方案:通过拆分List并分配独立线程处理,结合Spring线程池与异步方法提升效率... 目录项目场景解决方案1.实体类2.Mapper3.spring容器注入线程池bejsan对象4.创建

线上Java OOM问题定位与解决方案超详细解析

《线上JavaOOM问题定位与解决方案超详细解析》OOM是JVM抛出的错误,表示内存分配失败,:本文主要介绍线上JavaOOM问题定位与解决方案的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一、OOM问题核心认知1.1 OOM定义与技术定位1.2 OOM常见类型及技术特征二、OOM问题定位工具

基于 Cursor 开发 Spring Boot 项目详细攻略

《基于Cursor开发SpringBoot项目详细攻略》Cursor是集成GPT4、Claude3.5等LLM的VSCode类AI编程工具,支持SpringBoot项目开发全流程,涵盖环境配... 目录cursor是什么?基于 Cursor 开发 Spring Boot 项目完整指南1. 环境准备2. 创建

Spring Security简介、使用与最佳实践

《SpringSecurity简介、使用与最佳实践》SpringSecurity是一个能够为基于Spring的企业应用系统提供声明式的安全访问控制解决方案的安全框架,本文给大家介绍SpringSec... 目录一、如何理解 Spring Security?—— 核心思想二、如何在 Java 项目中使用?——

SpringBoot+RustFS 实现文件切片极速上传的实例代码

《SpringBoot+RustFS实现文件切片极速上传的实例代码》本文介绍利用SpringBoot和RustFS构建高性能文件切片上传系统,实现大文件秒传、断点续传和分片上传等功能,具有一定的参考... 目录一、为什么选择 RustFS + SpringBoot?二、环境准备与部署2.1 安装 RustF

springboot中使用okhttp3的小结

《springboot中使用okhttp3的小结》OkHttp3是一个JavaHTTP客户端,可以处理各种请求类型,比如GET、POST、PUT等,并且支持高效的HTTP连接池、请求和响应缓存、以及异... 在 Spring Boot 项目中使用 OkHttp3 进行 HTTP 请求是一个高效且流行的方式。

java.sql.SQLTransientConnectionException连接超时异常原因及解决方案

《java.sql.SQLTransientConnectionException连接超时异常原因及解决方案》:本文主要介绍java.sql.SQLTransientConnectionExcep... 目录一、引言二、异常信息分析三、可能的原因3.1 连接池配置不合理3.2 数据库负载过高3.3 连接泄漏