我正在设置一个小程序来从用户那里获取 2 个地理坐标,然后计算它们之间的距离(考虑到地球的曲率)。所以我在维基百科上查阅了这里的公式。
我基本上基于此设置了我的python函数,这就是我想出的:
def geocalc(start_lat, start_long, end_lat, end_long):
start_lat = math.radians(start_lat)
start_long = math.radians(start_long)
end_lat = math.radians(end_long)
end_long = math.radians(end_long)
d_lat = start_lat - end_lat
d_long = start_long - end_long
EARTH_R = 6372.8
c = math.atan((math.sqrt( (math.cos(end_lat)*d_long)**2 +( (math.cos(start_lat)*math.sin(end_lat)) - (math.sin(start_lat)*math.cos(end_lat)*math.cos(d_long)))**2)) / ((math.sin(start_lat)*math.sin(end_lat)) + (math.cos(start_lat)*math.cos(end_lat)*math.cos(d_long))) )
return EARTH_R*c
问题是结果出来真的不准确。我是 python 新手,所以非常感谢一些帮助或建议!