gps路径压缩算法

公司的gps点位特别多,导致数据存储以及查询都会造成一定的压力.
所以我们需要使用gps路径压缩算法
我调研了两种: k-means 和 Douglas-Peucker

k-means 压缩的底层原理是:
在这里插入图片描述

自定义簇的数量,假设是100个,那么就会计算所有gps点,把最相近的点,放在一个簇里,以此类推,计算出100个簇,然后每个簇计算出一个中心点,100簇的中心点也就是我们这段gps的压缩路径.
Douglas-Peucker 压缩的底层原理是:

我们首先 来看下这张图 *为折现点 直线为gps普通路径点

好 我们先假设全部的点都为普通点
第一步 我们会把整段路径的开始点和结束点设置为折线点
第二步 我们会找出这段路径当中离开始点和结束点距离最远的点.
第三步 拿这个最远的点和我们设置的距离阀值判断,如果超过了,则把这个点设置为折线点,没有超过,这段轨迹的计算停止.
第四步 会通过上一步计算好的折现点,划分为两个路径,然后这两个路径也是像上面的步骤一样,去计算最远的点,以此类推,直到没有点超过距离阀值即可
第五步 把所有的折现点结合起来,就是压缩后的路径

k-means 和 Douglas-Peucker 对比
k-means 只注重于gps大概在什么位置,但是具体的形状是不注重的,
性能较慢.但是因为簇是自定义的所以想节约多少点,都是可控的.
Douglas-Peucker 因为都是通过最远的点来计算,所以整体路径的形状一般会保持的很好,整体的计算性能较好,但由于距离阀值是固定的,而上传gps的点位是不固定的,所以压缩力度不可控

我们比较在意计算性能,Douglas-Peucker相比k-means也比较成熟点,所以选择了Douglas-Peucker

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/2778.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

libssl.so.10: cannot open shared object file: No such file or directory

在Ubuntu20上使用python调用一个公司自己开发的第三方库,运行时出现了如标题的问题。表示缺少该so文件。 网上有两种方法: 1.使用apy-install 来直接安装libssl1.0.0。(简单但对我无效,低版本Ubuntu可尝试) 2.从open…

适合普通人的黄金投资品种有哪些?

黄金一直以来都是投资者眼中的避险资产,无论是经济波动还是通货膨胀,它总能保持其独特的价值。对于普通人而言,投资黄金似乎是一件遥不可及的事情,但其实只要选对品种,普通投资者也可以轻松参与其中。在当前市场上&…

初学python记录:力扣2385. 感染二叉树需要的总时间

题目: 给你一棵二叉树的根节点 root ,二叉树中节点的值 互不相同 。另给你一个整数 start 。在第 0 分钟,感染 将会从值为 start 的节点开始爆发。 每分钟,如果节点满足以下全部条件,就会被感染: 节点此…

[GXYCTF2019]BabyUpload-BUUTF

题&#xff1a; 步骤&#xff08;先上传木马&#xff0c;在上传.htaccess&#xff09; 准备工作 他过滤了<? ,ph等 准备&#xff1a;一句话木马&#xff0c;.htaccess文件 .htaccess SetHandler application/x-httpd-php //解析为php文件 muma1.jpg<script languag…

【文件IO】 文件系统的操作 | 文件类型 | File的构造和方法 | 字节流 | 字符流 | InputStream | OutStream

文章目录 [toc] 文件IO一、文件的概念文件系统文件路径&#xff1a;文件类型 二、文件操作1.文件系统的操作&#xff1a;File的构造和方法创建文件删除文件等线程结束后删除文件列出目录内容创建目录重命名 2.文件内容的操作&#xff1a;1.字节流&#xff1a;对应二进制文件Inp…

数睿通2.0版本升级:探索数据血缘的奥秘

引言 数睿通 2.0 迎来了 4 月份的更新&#xff0c;该版本更新了许多用户期望的数据血缘模块&#xff0c;把原来外链跳转 neo4j 页面改为自研页面&#xff0c;方便后期的二次开发完善&#xff0c;此外&#xff0c;新版本摒弃了 neo4j 的血缘数据存储方案&#xff0c;一来是因为…

哪些软件可以监控电脑屏幕?值得推荐的六款电脑屏幕监控软件

在当今科技日新月异的时代&#xff0c;电脑屏幕监控软件逐渐成为了企业和个人用户必备的工具。 这些软件可以帮助我们实时监控电脑屏幕&#xff0c;保护数据安全&#xff0c;提高工作效率。 以下是一些值得推荐的电脑屏幕监控软件及其功能和优点&#xff1a; 1&#xff0c;域智…

开源贡献代码之​探索一下Cython

探索一下Cython 本篇文章将会围绕最近给Apache提的一个feature为背景&#xff0c;展开讲讲Cython遇到的问题&#xff0c;以及尝试自己从0写一个库出来&#xff0c;代码也已经放星球了&#xff0c;感兴趣的同学可以去下载学习。 0.背景 最近在给apache arrow提的一个feature因为…

裸机开发调试

裸机开发的基本特点 没有操作系统(Linux) 不使用带有系统调用的标准C库 大量使用物理内存地址进行数据操作 如果要用到库函数,需要自己去实现 将编译和链接分步骤完成,实现对可执行程序的指定链接,并指定链接地址 Linux操作系统一般支持可执行文件格式elf,在裸机环境…

以生命健康为中心的物联网旅居养老运营平台

随着科技的飞速发展和人口老龄化的日益加剧&#xff0c;养老问题逐渐成为社会关注的焦点。传统的养老模式已经难以满足现代老年人的多元化需求&#xff0c;因此&#xff0c;构建一个以生命健康为中心的物联网旅居养老运营平台显得尤为重要。 以生命健康为中心的物联网旅居养老运…

线上旧衣回收小程序,隐藏的蓝海回收市场

随着生活水平的提高&#xff0c;人们对衣服的要求逐渐增加&#xff0c;衣服的更新也越来越快&#xff0c;成为了一个消耗品&#xff0c;这时旧衣服便成为了一个新的商业发展模式。旧衣回收门槛低、投入少&#xff0c;适合普通人进行创业&#xff0c;因此&#xff0c;旧衣回收行…

LeetCode 42. 接雨水 - PHP

给定 n 个非负整数表示每个宽度为 1 的柱子的高度图&#xff0c;计算按此排列的柱子&#xff0c;下雨之后能接多少雨水。 左右两边是漏的&#xff0c;就是第一个柱子和最后一个柱子不接雨水。 暴力递归 class Solution {/*** param Integer[] $height* return Integer*/functi…

office的文件(word、excel、ppt)图标变白

之前用过WPS&#xff0c;后来卸载了&#xff0c;之后图标就变成白的了&#xff0c;但是word、Excel、PPT等都可以正常使用&#xff0c;说明不是打开方式的问题&#xff0c;然后就找问题所在。 看b站视频得知有可能是卸载wps之后&#xff0c;注册表里的图标路径仍然是之前的WPS…

[python3] 读取一个正在更新的日志文件

要读取一个正在更新的日志文件&#xff08;即实时写入的日志文件&#xff09;&#xff0c;你可以使用 Python 的 open() 函数打开文件&#xff0c;并使用 tail -F 或 f.seek(0, os.SEEK_END) 的技巧来实现实时读取。下面是两种方法的示例&#xff1a; 使用 tail -F 的方法&…

webpack的简单使用

webpack的简单使用 项目初始化 npm init npm install --save-dev webpack npm install --save-dev webpack-cli –save表示非全局下载&#xff1b;–global表示全局下载 &#xff08;不同项目可能需要不同的依赖版本&#xff0c;故用–save更好&#xff09; -dev表示开发环境…

推荐收藏的五款上网行为管理软件

在选择上网行为监控软件的时候需要考虑这几个因素&#xff1a;市场占有率、价格、是否试用、服务商实力等&#xff0c;以下介绍的这几个软件就是从这几个方面出发&#xff0c;为大家总结的优秀软件。 安企神&#xff1a; 国内企业级信息安全解决方案提供商&#xff0c;其上网行…

MAC用户福利:一站式电商客服工具下载地址大全揭秘!

列举和比较拼多多商家版,阿里卖家MAC版本&#xff0c;京麦工作台&#xff0c;聊天宝MAC版&#xff0c;千牛MAC版&#xff0c;抖店MAC版各种适用于MAC系统的电商客服工具&#xff0c;提供平台MAC版本的下载地址&#xff0c;帮助用户提高客服效率、改善客户体验&#xff0c;从而提…

大数据第六天

这里写目录标题 问题解决问题查询插入(时间慢)练习sql数据清理 问题 FAILED: ParseException line 1:16 mismatched input ‘input’ expecting INPATH near ‘local’ in load statement MismatchedTokenException(24!155) 加载数据的时候出现了这个错误&#xff0c;我们解释…

【spring】springProperty 使用

springProperty 是一个在 Spring 框架中使用的SpEL&#xff08;Spring Expression Language&#xff09;表达式&#xff0c;它允许你在应用程序的配置中引用 Spring 应用程序上下文中的属性值。这个表达式通常用于从 Spring 的 Environment 对象中获取配置属性的值&#xff0c;…

(36)4.20 数据结构(线性表)初始化,输入,删除,查找

#include<stdio.h> #include<stdlib.h> #include<errno.h> #define InitSize 10 #define Max_Size 10 //1.顺序表上基本操作的实现//顺序表的初始化 typedef struct { int* data; //指示动态分配数组指针 int MaxSize;//顺序表的最大容量 int …