Я настраиваю небольшую программу, которая берет 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, поэтому буду благодарен за помощь или совет!