// Example of using the GeographicLib::GeodesicExact class #include #include #include #include using namespace std; using namespace GeographicLib; int main() { try { GeodesicExact geod(Constants::WGS84_a(), Constants::WGS84_f()); // Alternatively: const GeodesicExact& geod = GeodesicExact::WGS84(); { // Sample direct calculation, travelling about NE from JFK double lat1 = 40.6, lon1 = -73.8, s12 = 5.5e6, azi1 = 51; double lat2, lon2; geod.Direct(lat1, lon1, azi1, s12, lat2, lon2); cout << lat2 << " " << lon2 << "\n"; } { // Sample inverse calculation, JFK to LHR double lat1 = 40.6, lon1 = -73.8, // JFK Airport lat2 = 51.6, lon2 = -0.5; // LHR Airport double s12; geod.Inverse(lat1, lon1, lat2, lon2, s12); cout << s12 << "\n"; } } catch (const exception& e) { cerr << "Caught exception: " << e.what() << "\n"; return 1; } }