Module sphericalNvector
Spherical, N-vector-based geodesy.
  N-vector-based classes geodetic (lat-/longitude) LatLon, geocentric (ECEF) Cartesian and Nvector and functions areaOf, intersection, meanOf, nearestOn3, perimeterOf, sumOf, triangulate and trilaterate, all spherical.
  Pure Python implementation of n-vector-based spherical geodetic 
  (lat-/longitude) methods, transcoded from JavaScript originals by (C) 
  Chris Veness 2011-2016, published under the same MIT Licence**.  See 
  Vector-based geodesy and Module latlon-nvector-spherical.
  Tools for working with points and paths on (a spherical model of) the 
  earth’s surface using using n-vectors rather than the more common 
  spherical trigonometry.  N-vectors make many calculations much simpler, 
  and easier to follow, compared with the trigonometric equivalents.
  Based on Kenneth Gade’s ‘Non-singular Horizontal Position Representation’, The 
  Journal of Navigation (2010), vol 63, nr 3, pp 395-417.
  Note that the formulations below take x => 0°N,0°E, y => 
  0°N,90°E and z => 90°N while Gade uses x => 90°N, y => 0°N,90°E,
  z => 0°N,0°E.
  Also note that on a spherical earth model, an n-vector is equivalent 
  to a normalised version of an (ECEF) cartesian coordinate.
    |  | Cartesian Extended to convert geocentric, Cartesian points to Nvector and n-vector-based, spherical LatLon.
 | 
    |  | LatLon New n-vector based point on a spherical earth model.
 | 
    |  | Nvector An n-vector is a position representation using a (unit) vector 
        normal to the earth's surface.
 | 
    |  | 
        
          | ispolar(points,
        wrap=False) Check whether a polygon encloses a pole.
 |  |  | 
    |  | 
        
          | areaOf(points,
        radius=6371008.771415) Calculate the area of a (spherical) polygon or composite (with great 
      circle arcs joining consecutive points).
 |  |  | 
    |  | 
        
          | intersecant2(center,
        circle,
        point,
        bearing,
        radius=6371008.771415,
        exact=False,
        height=None,
        wrap=True) Compute the intersections of a circle and a line.
 |  |  | 
    |  | 
        
          | intersection(start1,
        end1,
        start2,
        end2,
        height=None,
        LatLon=<class 'pygeodesy.sphericalNvector.LatLon'>,
        **LatLon_kwds) Locate the intersection of two paths each defined by two points or by
      a start point and an initial bearing.
 |  |  | 
    |  | 
        
          | meanOf(points,
        height=None,
        LatLon=<class 'pygeodesy.sphericalNvector.LatLon'>,
        **LatLon_kwds) Compute the geographic mean of the supplied points.
 |  |  | 
    |  |  | 
    |  | 
        
          | nearestOn3(point,
        points,
        closed=False,
        radius=6371008.771415,
        height=None) Locate the point on a polygon (with great circle arcs joining 
      consecutive points) closest to an other point.
 |  |  | 
    |  | 
        
          | perimeterOf(points,
        closed=False,
        radius=6371008.771415) Compute the perimeter of a (spherical) polygon or composite (with 
      great circle arcs joining consecutive points).
 |  |  | 
    |  | 
        
          | sumOf(nvectors,
        Vector=<class 'pygeodesy.sphericalNvector.Nvector'>,
        h=None,
        **Vector_kwds) Return the vectorial sum of two or more n-vectors.
 |  |  | 
    |  | 
        
          | triangulate(point1,
        bearing1,
        point2,
        bearing2,
        height=None,
        LatLon=<class 'pygeodesy.sphericalNvector.LatLon'>,
        **LatLon_kwds) Locate a point given two known points and the initial bearings from 
      those points.
 |  |  | 
    |  | 
        
          | trilaterate(point1,
        distance1,
        point2,
        distance2,
        point3,
        distance3,
        radius=6371008.771415,
        height=None,
        useZ=False,
        LatLon=<class 'pygeodesy.sphericalNvector.LatLon'>,
        **LatLon_kwds) Locate a point at given distances from three other points.
 |  |  | 
    |  | __all__ = _ALL_LAZY.sphericalNvector | 
| 
  | ispolar (points,
        wrap=False)
   |  |  Check whether a polygon encloses a pole. 
    Arguments:
        points- The polygon points (LatLon[]).wrap- Wrap and unroll longitudes (bool).Returns:Trueif the polygon encloses a pole,Falseotherwise.Raises:
        PointsError- Insufficient number ofpointsTypeError- Somepointsare notLatLonor 
        don't havebearingTo2,initialBearingToandfinalBearingTomethods. | 
 
| 
  | areaOf (points,
        radius=6371008.771415)
   |  |  Calculate the area of a (spherical) polygon or composite (with great 
  circle arcs joining consecutive points). 
    Arguments:
        points- The polygon points or clips (LatLon[], BooleanFHP or BooleanGH).radius- Mean earth radius (meter) orNone.Returns:Polygon area (metersquared , same units asradius, orradiansifradiusisNone).Raises: | 
 
| 
  | intersecant2 (center,
        circle,
        point,
        bearing,
        radius=6371008.771415,
        exact=False,
        height=None,
        wrap=True)
   |  |  Compute the intersections of a circle and a line. 
    Arguments:
        center- Center of the circle (LatLon).circle- Radius of the circle (meter, same units asradius) or a point on the circle (LatLon).point- A point in- or outside the circle (LatLon).bearing- Bearing at thepoint(compassdegrees360) or a second point on the line (LatLon).radius- Mean earth radius (meter, conventionally).exact- IfTrueuse the exact rhumb methods for 
          azimuth, destination and distance, ifFalseuse the 
          basic rhumb methods (bool) or ifNoneuse the great circle methods.height- Optional height for the intersection points (meter, 
          conventionally) orNone.wrap- Wrap and unroll longitudes (bool).Returns:2-Tuple of the intersection points (representing a chord), each 
          an instance of this class.  For a tangent line, each point 
          isthis very instance.Raises:
        IntersectionError- The circle and line do not intersect.TypeError- Ifcenterorpointnot LatLon orcircleorbearinginvalid.ValueError- Invalidcircle,bearing,radius,exactorheight. | 
 
| 
  | intersection (start1,
        end1,
        start2,
        end2,
        height=None,
        LatLon=<class 'pygeodesy.sphericalNvector.LatLon'>,
        **LatLon_kwds)
   |  |  Locate the intersection of two paths each defined by two points or by 
  a start point and an initial bearing. 
    Arguments:
        start1- Start point of the first path (LatLon).end1- End point of the first path (LatLon) or the initial bearing at the first 
          start point (compassdegrees360).start2- Start point of the second path (LatLon).end2- End point of the second path (LatLon) or the initial bearing at the second 
          start point (compassdegrees360).height- Optional height at the intersection point, overriding the mean 
          height (meter).LatLon- Optional class to return the intersection point (LatLon).LatLon_kwds- Optional, additionalLatLonkeyword 
          arguments, ignored ifLatLon is None.Returns:The intersection point (LatLon) or 3-tuple 
          (degrees90,degrees180, height) ifLatLonisNoneorNoneif no unique intersection exists.Raises:
        TypeError- Ifstart*orend*is not LatLon.ValueError- Intersection is ambiguous or infinite or the paths are parallel, 
        coincident or null.       Example:
         
>>> p = LatLon(51.8853, 0.2545)
>>> q = LatLon(49.0034, 2.5735)
>>> i = intersection(p, 108.55, q, 32.44)   | 
 
| 
  | meanOf (points,
        height=None,
        LatLon=<class 'pygeodesy.sphericalNvector.LatLon'>,
        **LatLon_kwds)
   |  |  Compute the geographic mean of the supplied points. 
    Arguments:
        points- Array of points to be averaged (LatLon[]).height- Optional height, overriding the mean height (meter).LatLon- Optional class to return the mean point (LatLon).LatLon_kwds- Optional, additionalLatLonkeyword 
          arguments, ignored ifLatLon is None.Returns:Point at geographic mean and mean height 
          (LatLon).Raises:
        PointsError- Insufficient number ofpoints.TypeError- Somepointsare notLatLon. | 
 
| 
  | nearestOn2 (point,
        points,
        **closed_radius_height)
   |  |  DEPRECATED, use method sphericalNvector.nearestOn3. 
    Returns:... 2-Tuple (closest, distance)of theclosestpoint (LatLon) on the polygon and thedistancebetween theclosestand the 
          givenpoint...Decorators: | 
 
| 
  | nearestOn3 (point,
        points,
        closed=False,
        radius=6371008.771415,
        height=None)
   |  |  Locate the point on a polygon (with great circle arcs joining 
  consecutive points) closest to an other point. If the given point is within the extent of any great circle arc, the 
  closest point is on that arc.  Otherwise, the closest is the nearest of 
  the arc's end points. 
    Arguments:
        point- The other, reference point (LatLon).points- The polygon points (LatLon[]).closed- Optionally, close the polygon (bool).radius- Mean earth radius (meter) orNone.height- Optional height, overriding the mean height for a point within 
          the arc (meter).Returns:A NearestOn3Tuple(closest, distance, 
          angle)of theclosestpoint (LatLon) on the polygon, thedistanceand theanglebetween theclosestand the givenpoint.  
          Thedistanceis inmeter, same units asradiusor inradiansifradiusisNone, theangleis in compassdegrees360.Raises:
        PointsError- Insufficient number ofpoints.TypeError- SomepointsorpointnotLatLon. | 
 
| 
  | perimeterOf (points,
        closed=False,
        radius=6371008.771415)
   |  |  Compute the perimeter of a (spherical) polygon or composite (with 
  great circle arcs joining consecutive points). 
    Arguments:
        points- The polygon points (LatLon[]).closed- Optionally, close the polygon (bool).radius- Mean earth radius (meter) orNone.Returns:Polygon perimeter (meter, same units asradiusorradiansifradiusisNone).Raises:
        PointsError- Insufficient number ofpoints.TypeError- Somepointsare not LatLon.ValueError- Invalidradiusorclosed=Falsewithpointsa 
        composite. | 
 
| 
  | sumOf (nvectors,
        Vector=<class 'pygeodesy.sphericalNvector.Nvector'>,
        h=None,
        **Vector_kwds)
   |  |  Return the vectorial sum of two or more n-vectors. 
    Arguments:
        nvectors- Vectors to be added (Nvector[]).Vector- Optional class for the vectorial sum (Nvector).h- Optional height, overriding the mean height (meter).Vector_kwds- Optional, additionalVectorkeyword 
          arguments.Returns:Vectorial sum (Vector).Raises: | 
 
| 
  | triangulate (point1,
        bearing1,
        point2,
        bearing2,
        height=None,
        LatLon=<class 'pygeodesy.sphericalNvector.LatLon'>,
        **LatLon_kwds)
   |  |  Locate a point given two known points and the initial bearings from 
  those points. 
    Arguments:
        point1- First reference point (LatLon).bearing1- Bearing at the first point (compassdegrees360).point2- Second reference point (LatLon).bearing2- Bearing at the second point (compassdegrees360).height- Optional height at the triangulated point, overriding the mean 
          height (meter).LatLon- Optional class to return the triangulated point (LatLon).LatLon_kwds- Optional, additionalLatLonkeyword 
          arguments, ignored ifLatLon is None.Returns:Triangulated point (LatLon).Raises:
        TypeError- Ifpoint1orpoint2is not 
        LatLon.Valuerror- Points coincide.       Example:
         
>>> p = LatLon("47°18.228'N","002°34.326'W")  
>>> q = LatLon("47°18.664'N","002°31.717'W")  
>>> t = triangulate(p, 7, q, 295)   | 
 
| 
  | trilaterate (point1,
        distance1,
        point2,
        distance2,
        point3,
        distance3,
        radius=6371008.771415,
        height=None,
        useZ=False,
        LatLon=<class 'pygeodesy.sphericalNvector.LatLon'>,
        **LatLon_kwds)
   |  |  Locate a point at given distances from three other points. 
    Arguments:
        point1- First point (LatLon).distance1- Distance to the first point (meter, same units asradius).point2- Second point (LatLon).distance2- Distance to the second point (meter, same units asradius).point3- Third point (LatLon).distance3- Distance to the third point (meter, same units asradius).radius- Mean earth radius (meter).height- Optional height at the trilaterated point, overriding the IDW 
          height (meter, same units asradius).useZ- Include Z component iff non-NaN, non-zero (bool).LatLon- Optional class to return the trilateratedLatLon_kwds- Optional, additionalLatLonkeyword 
          arguments, ignored ifLatLon is None.Returns:Trilaterated point (LatLon).Raises:
        IntersectionError- No intersection, trilateration failed.TypeError- Invalidpoint1,point2orpoint3.ValueError- Coincidentpointsor invaliddistance1,distance2,distance3orradius. |