基于地理位置的即时跟踪分析

项目任务:一个最近的项目中,需要处理地理空间数据。给出(任务)是 gps 追踪 25,000 个左右位置点,需要根据给定的经纬度,重复定位距离最短的点。

解决方案:

1. 翻查(已经实现的)计算已知经纬度两点间距离的代码片段。代码可以在 John D.  Cook 写的这篇code available in the public domain中找得到。

2. 只要写一段 Python 函数,返回与输入坐标距离最短的点索引(25,000 点数组中的索引)即可

代码是:

def closest_distance(lat,lon,data):

d = 100000.0

best = -1

r = data.index #数据索引最大值?

#根据输入的lat和lon,查找其在data数据中的索引位置对应的经度和纬度,传递为两个变量作为输出

for i in r:

lati = data.ix[i,'Lat']

loni = data.ix[i,'Lon']

#distance_on_unit_sphere是John D. Cook's书中的函数

md = distance_on_unit_sphere(lat, lon, lati, loni)#计算两组数之间的地理距离

if d > md#如果计算的距离在允许范围内

best = i#将数据的索引反馈到i通道输出

d= md#将计算的距离发送给d通道作为输出

return best

#输出best通道的产物-----即计算距离在数据中的索引

遍历(迭代)trkpts数组,将迄今为止(距离给定坐标位置)的距离最短的点索引值,保存到本地变量best中。

来自 <http://www.oschina.net/translate/python_is_not_c>

问题:代码写起来快,但执行起来却很慢。

Computing the distance between two locations on Earth from coordinates

结合地理坐标计算两个位置之间的距离

具体代码:代码写起来快,但执行起来却很慢。

import math

def distance_on_unit_sphere(lat1, long1, lat2, long2):

# Convert latitude and longitude to  转化经纬度为球面坐标

degrees_to_radians = math.pi/180.0   计算一个固定值

# phi = 90 - latitude

phi1 = (90.0 - lat1)*degrees_to_radians  #计算两个动态角度

phi2 = (90.0 - lat2)*degrees_to_radians

# theta = longitude

theta1 = long1*degrees_to_radians

theta2 = long2*degrees_to_radians

# Compute spherical distance from spherical coordinates.

# For two locations in spherical coordinates (1, theta, phi) and (1, theta', phi') 

# cosine( arc length ) = sin phi sin phi' cos(theta-theta') + cos phi cos phi'

# distance = rho * arc length cos = (math.sin(phi1)*math.sin(phi2)*math.cos(theta1 - theta2) +

math.cos(phi1)*math.cos(phi2))

arc = math.acos( cos )

# Remember to multiply arc by the radius of the earth

# in your favorite set of units to get length.

return arc

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,254评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,875评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,682评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,896评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,015评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,152评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,208评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,962评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,388评论 1 304
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,700评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,867评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,551评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,186评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,901评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,142评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,689评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,757评论 2 351

推荐阅读更多精彩内容

  • #1996 AHSME ##1996 AHSME Problems/Problem 1 The addition ...
    abigtreenj阅读 1,392评论 0 0
  • /** * 地图位置计算工具(将GPS坐标转换成百度地图坐标) * 参考文档:http://bbs.lbsyu...
    nick2046阅读 2,696评论 0 1
  • 今天,在一篇报道中发现,“一直特立独行的猫”微博、公众号都很火的那位------80后女作家赵星,原来是老乡,兴...
    清风淡雅11阅读 239评论 0 0
  • http://www.jianshu.com/p/a290ffb302d6?utm_campaign=haruki...
    懂茶帝老宋阅读 191评论 0 0