from:http://blog.csdn.net/zhuqiuhui/article/details/53180395
1. 求兩個經緯點的方位角,P0(latA, lonA), P1(latB, lonB)(很多博客寫的不是很好,這里總結一下)
def getDegree(latA, lonA, latB, lonB):
"""
Args:
point p1(latA, lonA)
point p2(latB, lonB)
Returns:
bearing between the two GPS points,
default: the basis of heading direction is north
"""
radLatA = radians(latA)
radLonA = radians(lonA)
radLatB = radians(latB)
radLonB = radians(lonB)
dLon = radLonB - radLonA
y = sin(dLon) * cos(radLatB)
x = cos(radLatA) * sin(radLatB) - sin(radLatA) * cos(radLatB) * cos(dLon)
brng = degrees(atan2(y, x))
brng = (brng + 360) % 360
return brng
2. 求兩個經緯點的距離函數:P0(latA, lonA), P1(latB, lonB)
def haversine(a, b): # 經度1,緯度1,經度2,緯度2 (十進制度數)
"""
Calculate the great circle distance between two points
on the earth (specified in decimal degrees)
"""
lat1 = a[0][0]
lon1 = a[1][0]
lat2 = b[0][0]
lon2 = b[1][0]
# 將十進制度數轉化為弧度
lon1, lat1, lon2, lat2 = map(radians, [lon1, lat1, lon2, lat2])
# haversine公式
dlon = lon2 - lon1
dlat = lat2 - lat1
a = sin(dlat/2)**2 + cos(lat1) * cos(lat2) * sin(dlon/2)**2
c = 2 * asin(sqrt(a))
r = 6371 # 地球平均半徑,單位為公里
return c * r * 1000
