Neo4j:找到两个纬度/经度之间的中间点

昨天我写了一篇博客文章,展示了如何使用Cypher查找两个纬度/经度之间的中点,这是第一次尝试填补丢失位置的方法,但我意识到我可以做得更好。

正如我在上一篇文章中提到的,当我找到一个缺少经纬度坐标的停靠点时,通常可以在附近找到两个停靠点,以便对该停靠点的位置进行三角剖分。

我也有火车路线,该路线指示从一个停靠点到另一个停靠点所花费的秒数,这使我可以指示出无位置停靠点是否比另一个停靠点更靠近一个停靠点。

例如,考虑在b没有位置的情况下停靠a,b和c。 如果停靠点之间有以下距离:

(a)-[:NEXT {time: 60}]->(b)-[:NEXT {time: 240}]->(c)

它告诉我们,点“ b”实际上是从“ a”到“ c”的距离的0.2,而不是中点。

有一个公式可以用来说明这一点:

a = sin((1−f)⋅δ) / sin δ
b = sin(f⋅δ) / sin δ
x = a ⋅ cos φ1 ⋅ cos λ1 + b ⋅ cos φ2 ⋅ cos λ2
y = a ⋅ cos φ1 ⋅ sin λ1 + b ⋅ cos φ2 ⋅ sin λ2
z = a ⋅ sin φ1 + b ⋅ sin φ2
φi = atan2(z, √x² + y²)
λi = atan2(y, x)δ is the angular distance d/R between the two points.
φ = latitude
λ = longitude

翻译成Cypher(带有强制性的希腊符号)后,它看起来像这样,以找到从一个点到另一个点的方式的点0.2

with {latitude: 51.4931963543, longitude: -0.0475185810} AS p1, {latitude: 51.47908, longitude: -0.05393950 } AS p2WITH p1, p2, distance(point(p1), point(p2)) / 6371000 AS δ, 0.2 AS f
WITH p1, p2, δ, sin((1-f) * δ) / sin(δ) AS a,sin(f * δ) / sin(δ) AS b
WITH radians(p1.latitude) AS φ1, radians(p1.longitude) AS λ1,radians(p2.latitude) AS φ2, radians(p2.longitude) AS λ2,a, b
WITH a * cos(φ1) * cos(λ1) + b * cos(φ2) * cos(λ2) AS x,a * cos(φ1) * sin(λ1) + b * cos(φ2) * sin(λ2) AS y,a * sin(φ1) + b * sin(φ2) AS z
RETURN degrees(atan2(z, sqrt(x^2 + y^2))) AS φi,degrees(atan2(y,x)) AS λi
╒═════════════════╤════════════════════╕
│φi               │λi                  │
╞═════════════════╪════════════════════╡
│51.49037311149128│-0.04880308288561931│
└─────────────────┴────────────────────┘

一个快速的健全性检查,插入0.5而不是0.2可以找到我能够根据昨天的帖子进行健全性检查的中点:

╒═════════════════╤═════════════════════╕
│φi               │λi                   │
╞═════════════════╪═════════════════════╡
│51.48613822097523│-0.050729537454086385│
└─────────────────┴─────────────────────┘

目前为止就这样了!

翻译自: https://www.javacodegeeks.com/2016/11/neo4j-find-intermediate-point-two-latlongs.html

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

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

相关文章

Linux系统更新最新版R语言方法

Linux系统更新最新版R语言方法 第一:卸载之前的版本 sudo apt remove r-base-core第二:在 /etc/apt/sources中添加源 sudo vi /etc/apt/sources对于不同系统添加不同的源具体如下: #(19.04) deb https://cloud.r-project.org/bin/linux/…

Kali Linux下安装VMware

1.Kali Linux安装VMware Workstation 10.0 首先去官网下载VMware Workstation 10.0;下载地址: https://my.vmware.com/web/vmware/details?downloadGroupWKST-1006-LX&productId362&rPId8483 然后cd到下载目录,输入: su…

3月12号

上午复习了昨天的内容,学习了有序列表、无序列表、自定义列表、特殊字符标签. 下午学习了表格、表单、文本域、html新增标签、input新增的type属性值、多媒体标签、多媒体video. 这些知识都比较简单,我在来学校上课之前就已经非常熟悉了...... 最后发一张…

day10T1改错记

题面 有两个串\(A\)和\(B\),长度分别为\(n\)和\(m\),只含Z,P,S,B四个大写字母,定义\(B\)在第\(p\)位(\(0 \le p \le n - m\))匹配\(A\)为对\(B\)的每个位置\(B_i\),在\(A_{\max (0, p i - k)}\)到\(A_{min(n - 1, p i k)}\)中都…

架构层和建模域逻辑

在讨论用于建模域逻辑(例如事务脚本,表模块,域模型)的PoEAA模式时,我注意到人们对域模型模式是最好的印象(尽管印象不对)。 因此,他们开始将其应用于所有内容。 不配领域模型模式 让…

一步步通过命令行cl.exe编译Windows程序

Windows系统下有强大的IDE工具VS,VC6.0等,隐藏了很多编译和链接的细节。事实上,VS是通过调用cl.exe进行源代码编译。接着调用link.exe进行目标文件的链接等操作。有时候,如果出现编译或者链接错误,我们也可以通过命令行…

将数据流链接到加密转换的流CryptoStream 类

1.命名空间:System.Security.Cryptography 程序集:mscorlib(在 mscorlib.dll 中)----------------------------------------------------继承层次结构-System.Object----- System.MarshalByRefObject--------- System.IO.Stream-------------System.Secu…

Spring Batch:多种格式输出编写器

作为Spring Batch的坚定倡导者,我一直在谈论Spring Batch的概念,它为开发人员提供了一个框架,使他们可以专注于解决业务需求。 这样,它使开发人员不必花费过多的时间来解决所有技术问题以支持该解决方案。 为了说明我的意思&…

《七哥说道》第五章:入职惨做苦力,画饼一望无际

【转载请注明】: 原文出处:https://www.cnblogs.com/jstarseven/p/10521426.html 作者:jstarseven 码字挺辛苦的..... “你是住在回龙观东大街附近吗,那先不急下班,一会我开车顺带你回去吧!” 第二家公司的…

通过源码将git升级到最新版

因为go-get下载hugo失败,需要升级git到最新版本。 下载最新git代码 wget -O git-master.zip https://github.com/git/git/archive/master.zip编译 unzip git-master.zip cd git-masteryum install openssl-devel curl-devel expat-devel perl-ExtUtils-MakeMaker …

win10只有edge浏览器能上网的解决方法

问题描述:电脑就只有edge浏览器和自带的邮件可以上网,但是QQ Chrome,360浏览器都无法上网; 解决方法:打开命令提示符(管理员),执行netsh winsock reset,重启系统就好了。…

CTF dotNet逆向分析

题目来源http://ctf.idf.cn/index.php?ggame&marticle&aindex&id36 .NET逆向第一题 嗯,看名字就应该明白了,快去下载吧! http://pan.baidu.com/s/1bnvVbp9 下载后是一个DotNetCrackMe1.exe文件。 分析 逆向分析的基础问题&…

xaas_从XaaS到Java EE – 2012年哪款该死的云最适合我?

xaas您是否曾经想过要使Java EE正常运行需要什么? 是的 多年。 从托管我自己的主机开始,转到一些托管产品 ,最后偶然发现了PaaS运动。 老实说,我并没有太认真。 我只是想把我的东西放到某个地方,而不在乎解决方案。 在…

day3----python变量与常量

一、python变量: 1、概述:(1)程序可操作的存储空间的名称;(2)程序运行期间可以改变的数据(3)每个变量都有特定的类型 2、作用:将不同类型的数据存储到内存中 …

垃圾收集中的代际差异

去年,我一直在帮助新兴公司Instana创建一个Java代理,该代理可跟踪Java应用程序中的执行情况。 收集并结合此执行数据以生成用户请求以及系统所有者半球内服务之间的最终通信的跟踪。 这样,可以可视化非结构化通信,从而显着简化了由…

简单解释 MapReduce 算法

一个有趣的例子 你想数出一摞牌中有多少张黑桃。直观方式是一张一张检查并且数出有多少张是黑桃? MapReduce方法则是: 给在座的所有玩家中分配这摞牌 让每个玩家数自己手中的牌有几张是黑桃,然后把这个数目汇报给你 你把所有玩家告诉你的数…

appium + python 搭建

appium python 1、安装jdk地址:https://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html配置:系统变量新建JAVA_HOME,输入jdk安装路径,如:C:\Program Files\Java\jdk1.8.0_201。系统变量新建CLAS…

ubuntu 12.04 /sbin/ldconfig.real: /usr/local/lib/*.so.8 不是符号连接 解决办法

最近在ubuntu12.04下使用sudo apt-get install安装软件的时候最后总会报这种错误。建立硬连接即可解决: sudo ln -sf /usr/local/lib/libprotobuf.so.8.0.0 /usr/local/lib/libprotobuf.so.8 截图上传没成功,麻烦。 在弄一次。

Linux GCC常用命令

1简介 2简单编译 2.1预处理 2.2编译为汇编代码(Compilation) 2.3汇编(Assembly) 2.4连接(Linking) 3多个程序文件的编译 4检错 5库文件连接 5.1编译成可执行文件 5.2链接 5.3强制链接时使用静态链接库 1简介 GCC 的意思也只是 GNU C Compiler 而已。经过了这么多年的发展&#…

JDK 9 @不建议使用的注释增强功能

在帖子中, Deprecated可能会是什么样子? ,我当时使用JEP 277 (“增强的弃用”)的描述来指导创建增强的自定义Deprecated注释。 但是,自从发布该文章以来,JEP 277进行了重大更改。该文章总结了J…