Примечание: это решение работает только на короткие расстояния.
Я попытался использовать опубликованную формулу dommer для приложения и обнаружил, что она хорошо работает на больших расстояниях, но в моих данных я использовал все очень короткие расстояния, а сообщение dommer очень плохо работало. Мне нужна была скорость, и более сложные геологические вычисления работали хорошо, но были слишком медленными. Итак, в случае, если вам нужна скорость и все вычисления, которые вы делаете, короткие (возможно, <100 м или около того). Я обнаружил, что это небольшое приближение отлично работает. он предполагает, что мир плоский, поэтому не используйте его для больших расстояний, он работает, аппроксимируя расстояние одной широты и долготы на заданной широте и возвращая расстояние Пифагора в метрах.
public class FlatEarthDist {
public static double distance(double lat1, double lng1,
double lat2, double lng2){
double a = (lat1-lat2)*FlatEarthDist.distPerLat(lat1);
double b = (lng1-lng2)*FlatEarthDist.distPerLng(lat1);
return Math.sqrt(a*a+b*b);
}
private static double distPerLng(double lat){
return 0.0003121092*Math.pow(lat, 4)
+0.0101182384*Math.pow(lat, 3)
-17.2385140059*lat*lat
+5.5485277537*lat+111301.967182595;
}
private static double distPerLat(double lat){
return -0.000000487305676*Math.pow(lat, 4)
-0.0033668574*Math.pow(lat, 3)
+0.4601181791*lat*lat
-1.4558127346*lat+110579.25662316;
}
}