geodesy.lamberts_ellipsoidal_distance

Attributes

AXIS_A

AXIS_B

EQUATORIAL_RADIUS

Functions

lamberts_ellipsoidal_distance(→ float)

Calculate the shortest distance along the surface of an ellipsoid between

Module Contents

geodesy.lamberts_ellipsoidal_distance.lamberts_ellipsoidal_distance(lat1: float, lon1: float, lat2: float, lon2: float) float

Calculate the shortest distance along the surface of an ellipsoid between two points on the surface of earth given longitudes and latitudes https://en.wikipedia.org/wiki/Geographical_distance#Lambert’s_formula_for_long_lines

NOTE: This algorithm uses geodesy/haversine_distance.py to compute central angle,

sigma

Representing the earth as an ellipsoid allows us to approximate distances between points on the surface much better than a sphere. Ellipsoidal formulas treat the Earth as an oblate ellipsoid which means accounting for the flattening that happens at the North and South poles. Lambert’s formulae provide accuracy on the order of 10 meteres over thousands of kilometeres. Other methods can provide millimeter-level accuracy but this is a simpler method to calculate long range distances without increasing computational intensity.

Args:

lat1, lon1: latitude and longitude of coordinate 1 lat2, lon2: latitude and longitude of coordinate 2

Returns:

geographical distance between two points in metres

>>> from collections import namedtuple
>>> point_2d = namedtuple("point_2d", "lat lon")
>>> SAN_FRANCISCO = point_2d(37.774856, -122.424227)
>>> YOSEMITE = point_2d(37.864742, -119.537521)
>>> NEW_YORK = point_2d(40.713019, -74.012647)
>>> VENICE = point_2d(45.443012, 12.313071)
>>> f"{lamberts_ellipsoidal_distance(*SAN_FRANCISCO, *YOSEMITE):0,.0f} meters"
'254,351 meters'
>>> f"{lamberts_ellipsoidal_distance(*SAN_FRANCISCO, *NEW_YORK):0,.0f} meters"
'4,138,992 meters'
>>> f"{lamberts_ellipsoidal_distance(*SAN_FRANCISCO, *VENICE):0,.0f} meters"
'9,737,326 meters'
geodesy.lamberts_ellipsoidal_distance.AXIS_A = 6378137.0
geodesy.lamberts_ellipsoidal_distance.AXIS_B = 6356752.314245
geodesy.lamberts_ellipsoidal_distance.EQUATORIAL_RADIUS = 6378137