Coverage for pygeodesy/frechet.py : 96%
 
         
         
    Hot-keys on this page
r m x p toggle line displays
j k next/prev highlighted chunk
0 (zero) top of page
1 (one) first highlighted chunk
| 
 # -*- coding: utf-8 -*- 
 L{FrechetCosineAndoyerLambert}, L{FrechetCosineForsytheAndoyerLambert}, L{FrechetCosineLaw}, L{FrechetDistanceTo}< L{FrechetEquirectangular}, L{FrechetEuclidean}, L{FrechetFlatLocal}, L{FrechetFlatPolar}, L{FrechetHaversine}, L{FrechetHubeny}, L{FrechetKarney}, L{FrechetThomas} and L{FrechetVincentys} to compute I{discrete} U{Fréchet <https://WikiPedia.org/wiki/Frechet_distance>} distances between two sets of C{LatLon}, C{NumPy}, C{tuples} or other types of points. 
 Only L{FrechetDistanceTo} -iff used with L{ellipsoidalKarney.LatLon} points- and L{FrechetKarney} requires installation of I{Charles Karney's} U{geographiclib<https://PyPI.org/project/geographiclib>}. 
 Typical usage is as follows. First, create a C{Frechet} calculator from one set of C{LatLon} points. 
 C{f = FrechetXyz(points1, ...)} 
 Get the I{discrete} Fréchet distance to another set of C{LatLon} points by 
 C{t6 = f.discrete(points2)} 
 Or, use function C{frechet_} with a proper C{distance} function passed as keyword arguments as follows 
 C{t6 = frechet_(points1, points2, ..., distance=...)}. 
 In both cases, the returned result C{t6} is a L{Frechet6Tuple}. 
 For C{(lat, lon, ...)} points in a C{NumPy} array or plain C{tuples}, wrap the points in a L{Numpy2LatLon} respectively L{Tuple2LatLon} instance, more details in the documentation thereof. 
 For other points, create a L{Frechet} sub-class with the appropriate C{distance} method overloading L{Frechet.distance} as in this example. 
 >>> from pygeodesy import Frechet, hypot_ >>> >>> class F3D(Frechet): >>> """Custom Frechet example. >>> """ >>> def distance(self, p1, p2): >>> return hypot_(p1.x - p2.x, p1.y - p2.y, p1.z - p2.z) >>> >>> f3D = F3D(xyz1, ..., units="...") >>> t6 = f3D.discrete(xyz2) 
 Transcribed from the original U{Computing Discrete Fréchet Distance <https://www.kr.TUWien.ac.AT/staff/eiter/et-archive/cdtr9464.pdf>} by Eiter, T. and Mannila, H., 1994, April 25, Technical Report CD-TR 94/64, Information Systems Department/Christian Doppler Laboratory for Expert Systems, Technical University Vienna, Austria. 
 This L{Frechet.discrete} implementation optionally generates intermediate points for each point set separately. For example, using keyword argument C{fraction=0.5} adds one additional point halfway between each pair of points. Or using C{fraction=0.1} interpolates nine additional points between each points pair. 
 The L{Frechet6Tuple} attributes C{fi1} and/or C{fi2} will be I{fractional} indices of type C{float} if keyword argument C{fraction} is used. Otherwise, C{fi1} and/or C{fi2} are simply type C{int} indices into the respective points set. 
 For example, C{fractional} index value 2.5 means an intermediate point halfway between points[2] and points[3]. Use function L{fractional} to obtain the intermediate point for a I{fractional} index in the corresponding set of points. 
 The C{Fréchet} distance was introduced in 1906 by U{Maurice Fréchet <https://WikiPedia.org/wiki/Maurice_Rene_Frechet>}, see U{reference [6]<https://www.kr.TUWien.ac.AT/staff/eiter/et-archive/cdtr9464.pdf>}. It is a measure of similarity between curves that takes into account the location and ordering of the points. Therefore, it is often a better metric than the well-known C{Hausdorff} distance, see the L{hausdorff} module. ''' 
 property_doc_, property_RO, _xinstanceof _IsnotError, _Meter, PointsError, _Radians, _Radians2 cosineLaw_, euclidean_, flatPolar_, haversine_, \ points2 as _points2, _scale_rad, thomas_, vincentys_ notOverloaded, PhiLam2Tuple 
 
 
 raise _AssertionError('%s < %s: 0 < %.6g < %.6g < 1' % ('EPS', 'EPS1', EPS, EPS1)) 
 
 and (float(n) - fraction) < n): raise FrechetError(fraction=fraction) 
 
 '''Fréchet issue. ''' 
 
 '''6-Tuple C{(fd, fi1, fi2, r, n, units)} with the I{discrete} U{Fréchet<https://WikiPedia.org/wiki/Frechet_distance>} distance C{fd}, I{fractional} indices C{fi1} and C{fi2}, the recursion depth C{r}, the number of distances computed C{n} and the name of the distance C{units}. 
 If I{fractional} indices C{fi1} and C{fi2} are type C{int}, the returned C{fd} is the distance between C{points1[fi1]} and C{points2[fi2]}. For type C{float} indices, the distance is between an intermediate point along C{points1[int(fi1)]} and C{points1[int(fi1) + 1]} respectively an intermediate point along C{points2[int(fi2)]} and C{points2[int(fi2) + 1]}. 
 Use function L{fractional} to compute the point at a I{fractional} index. ''' 
 # def __gt__(self, other): # _xinstanceof(Frechet6Tuple, other=other) # return self if self.fd > other.fd else other # PYCHOK .fd=[0] # # def __lt__(self, other): # _xinstanceof(Frechet6Tuple, other=other) # return self if self.fd < other.fd else other # PYCHOK .fd=[0] 
 
 '''Frechet base class, requires method L{Frechet.distance} to be overloaded. ''' 
 '''New C{Frechet...} calculator/interpolator. 
 @arg points: First set of points (C{LatLon}[], L{Numpy2LatLon}[], L{Tuple2LatLon}[] or C{other}[]). @kwarg fraction: Index fraction (C{float} in L{EPS}..L{EPS1}) to interpolate intermediate B{C{points}} or use C{None}, C{0} or C{1} for no intermediate B{C{points}} and no I{fractional} indices. @kwarg name: Optional calculator/interpolator name (C{str}). @kwarg units: Optional distance units (C{str}). @kwarg wrap_adjust: Optionally, C{wrap} and unroll longitudes, iff applicable (C{bool}) and C{adjust} wrapped, unrolled longitudinal delta by the cosine of the mean latitude, iff applicable. 
 @raise FrechetError: Insufficient number of B{C{points}} or invalid B{C{fraction}} or B{{wrap}} or B{C{ajust}} not applicable. 
 ''' self.name = name self.units = units 
 def adjust(self): '''Get the adjust setting (C{bool} or C{None} if not applicable). ''' 
 def datum(self): '''Get the datum (L{Datum} or C{None} if not applicable). ''' 
 '''(INTERNAL) Set the datum. ''' if d and d != self.datum: # PYCHOK no cover _xinstanceof(Datum, datum=d) self._datum = d 
 '''Compute the C{forward, discrete Fréchet} distance. 
 @arg points: Second set of points (C{LatLon}[], L{Numpy2LatLon}[], L{Tuple2LatLon}[] or C{other}[]). @kwarg fraction: Index fraction (C{float} in L{EPS}..L{EPS1}) to interpolate intermediate B{C{points}} or use C{None}, C{0} or C{1} for no intermediate B{C{points}} and no I{fractional} indices. 
 @return: A L{Frechet6Tuple}C{(fd, fi1, fi2, r, n, units)}. 
 @raise FrechetError: Insufficient number of B{C{points}} or invalid B{C{fraction}}. 
 @raise RecursionError: Recursion depth exceeded, see U{sys.getrecursionlimit() <https://docs.Python.org/3/library/sys.html#sys.getrecursionlimit>}. ''' 
 
 
 
 
 def distance(self, point1, point2): # PYCHOK no cover '''(INTERNAL) I{must be overloaded}. ''' notOverloaded(self, self.distance, point1, point2) 
 def fraction(self): '''Get the index fraction (C{float} or C{1}). ''' 
 def fraction(self, fraction): '''Set the the index fraction (C{float} or C{1}). 
 @arg fraction: Index fraction (C{float} in L{EPS}..L{EPS1}) to interpolate intermediate B{C{points}} or use C{None}, C{0} or C{1} for no intermediate B{C{points}} and no I{fractional} indices. 
 @raise FrechetError: Invalid B{C{fraction}}. ''' 
 '''Convert a point for the C{.distance} method. 
 @arg point: The point to convert ((C{LatLon}, L{Numpy2LatLon}, L{Tuple2LatLon} or C{other}). 
 @return: The converted B{C{point}}. ''' 
 '''Get and convert a point for the C{.distance} method. 
 @arg points: The orignal B{C{points}} to convert ((C{LatLon}[], L{Numpy2LatLon}[], L{Tuple2LatLon}[] or C{other}[]). @arg i: The B{C{points}} index (C{int}). 
 @return: The converted B{C{points[i]}}. ''' 
 '''Get and convert a I{fractional} point for the C{.distance} method. 
 @arg points: The orignal B{C{points}} to convert ((C{LatLon}[], L{Numpy2LatLon}[], L{Tuple2LatLon}[] or C{other}[]). @arg fi: The I{fractional} index in B{C{points}} (C{float} or C{int}). 
 @return: The interpolated, converted, intermediate B{C{points[fi]}}. ''' 
 def units(self): '''Get the distance units (C{str} or C{""}). ''' 
 def units(self, units): '''Set the distance units. 
 @arg units: New units name (C{str}). ''' 
 def wrap(self): '''Get the wrap setting (C{bool} or C{None} if not applicable). ''' 
 
 '''L{Frechet} base class for distances in C{degrees} from C{LatLon} points in C{degrees}. ''' 
 if _FOR_DOCS: __init__ = Frechet.__init__ discrete = Frechet.discrete 
 
 '''L{Frechet} base class for distances in C{radians} or C{radians squared} from C{LatLon} points converted from C{degrees} to C{radians}. ''' 
 if _FOR_DOCS: __init__ = Frechet.__init__ discrete = Frechet.discrete 
 '''Convert C{(lat, lon)} point in degrees to C{(a, b)} in radians. 
 @return: An L{PhiLam2Tuple}C{(phi, lam)}. ''' except AttributeError: # PYCHOK no cover return PhiLam2Tuple(radians(point.lat), radians(point.lon)) 
 
 '''Compute the C{Frechet} distance based on the I{angular} distance in C{radians} from function L{cosineAndoyerLambert_}. 
 @see: L{FrechetCosineForsytheAndoyerLambert}, L{FrechetDistanceTo}, L{FrechetFlatLocal}, L{FrechetHubeny}, L{FrechetThomas} and L{FrechetKarney}. ''' 
 '''New L{FrechetCosineAndoyerLambert} calculator/interpolator. 
 @arg points: First set of points (C{LatLon}[], L{Numpy2LatLon}[], L{Tuple2LatLon}[] or C{other}[]). @kwarg datum: Optional datum overriding the default C{Datums.WGS84} and first B{C{points}}' datum (L{Datum}). @kwarg wrap: Wrap and L{unrollPI} longitudes (C{bool}) @kwarg fraction: Index fraction (C{float} in L{EPS}..L{EPS1}) to interpolate intermediate B{C{points}} or use C{None}, C{0} or C{1} for no intermediate B{C{points}} and no L{fractional} indices. @kwarg name: Optional calculator/interpolator name (C{str}). 
 @raise FrechetError: Insufficient number of B{C{points}} or invalid B{C{fraction}}. 
 @raise TypeError: Invalid B{C{datum}}. ''' wrap=wrap) 
 if _FOR_DOCS: discrete = Frechet.discrete 
 '''Return the L{cosineAndoyerLambert_} distance in C{radians}. ''' 
 
 '''Compute the C{Frechet} distance based on the I{angular} distance in C{radians} from function L{cosineForsytheAndoyerLambert_}. 
 @see: L{FrechetCosineAndoyerLambert}, L{FrechetDistanceTo}, L{FrechetFlatLocal}, L{FrechetHubeny}, L{FrechetThomas} and L{FrechetKarney}. ''' 
 '''New L{FrechetCosineForsytheAndoyerLambert} calculator/interpolator. 
 @arg points: First set of points (C{LatLon}[], L{Numpy2LatLon}[], L{Tuple2LatLon}[] or C{other}[]). @kwarg datum: Optional datum overriding the default C{Datums.WGS84} and first B{C{points}}' datum (L{Datum}). @kwarg wrap: Wrap and L{unrollPI} longitudes (C{bool}) @kwarg fraction: Index fraction (C{float} in L{EPS}..L{EPS1}) to interpolate intermediate B{C{points}} or use C{None}, C{0} or C{1} for no intermediate B{C{points}} and no L{fractional} indices. @kwarg name: Optional calculator/interpolator name (C{str}). 
 @raise FrechetError: Insufficient number of B{C{points}} or invalid B{C{fraction}}. 
 @raise TypeError: Invalid B{C{datum}}. ''' wrap=wrap) 
 if _FOR_DOCS: discrete = Frechet.discrete 
 '''Return the L{cosineForsytheAndoyerLambert_} distance in C{radians}. ''' 
 
 '''Compute the C{Frechet} distance based on the I{angular} distance in C{radians} from function L{cosineLaw_}. 
 @see: L{FrechetEquirectangular}, L{FrechetEuclidean}, L{FrechetFlatPolar}, L{FrechetHaversine} and L{FrechetVincentys}. 
 @note: See note at function L{vincentys_}. ''' 
 '''New L{FrechetCosineLaw} calculator/interpolator. 
 @arg points: First set of points (C{LatLon}[], L{Numpy2LatLon}[], L{Tuple2LatLon}[] or C{other}[]). @kwarg wrap: Wrap and L{unrollPI} longitudes (C{bool}). @kwarg fraction: Index fraction (C{float} in L{EPS}..L{EPS1}) to interpolate intermediate B{C{points}} or use C{None}, C{0} or C{1} for no intermediate B{C{points}} and no I{fractional} indices. @kwarg name: Optional calculator/interpolator name (C{str}). 
 @raise FrechetError: Insufficient number of B{C{points}} or invalid B{C{fraction}}. ''' wrap=wrap) 
 if _FOR_DOCS: discrete = Frechet.discrete 
 '''Return the L{cosineLaw_} distance in C{radians}. ''' 
 
 '''Compute the C{Frechet} distance based on the distance from the points' C{LatLon.distanceTo} method, conventionally in C{meter}. 
 @see: L{FrechetCosineAndoyerLambert}, L{FrechetCosineForsytheAndoyerLambert}, L{FrechetFlatLocal}, L{FrechetHubeny}, L{FrechetThomas} and L{FrechetKarney}. ''' 
 '''New L{FrechetDistanceTo} calculator/interpolator. 
 @arg points: First set of points (C{LatLon}[]). @kwarg fraction: Index fraction (C{float} in L{EPS}..L{EPS1}) to interpolate intermediate B{C{points}} or use C{None}, C{0} or C{1} for no intermediate B{C{points}} and no I{fractional} indices. @kwarg name: Optional calculator/interpolator name (C{str}). @kwarg distanceTo_kwds: Optional keyword arguments for the B{C{points}}' C{LatLon.distanceTo} method. 
 @raise FrechetError: Insufficient number of B{C{points}} or invalid B{C{fraction}}. 
 @raise ImportError: Package U{GeographicLib <https://PyPI.org/project/geographiclib>} missing iff B{C{points}} are L{ellipsoidalKarney.LatLon}s. 
 @note: All B{C{points}} I{must} be instances of the same ellipsoidal or spherical C{LatLon} class, I{not checked however}. ''' FrechetRadians.__init__(self, points, fraction=fraction, name=name) if distanceTo_kwds: self._distanceTo_kwds = distanceTo_kwds 
 if _FOR_DOCS: discrete = Frechet.discrete 
 '''Return the distance in C{meter}. ''' return p1.distanceTo(p2, **self._distanceTo_kwds) 
 
 '''Compute the C{Frechet} distance based on the C{equirectangular} distance in C{radians squared} like function L{equirectangular_}. 
 @see: L{FrechetCosineLaw}, L{FrechetEuclidean}, L{FrechetFlatPolar}, L{FrechetHaversine} and L{FrechetVincentys}. ''' 
 '''New L{FrechetEquirectangular} calculator/interpolator. 
 @arg points: First set of points (C{LatLon}[], L{Numpy2LatLon}[], L{Tuple2LatLon}[] or C{other}[]). @kwarg adjust: Adjust the wrapped, unrolled longitudinal delta by the cosine of the mean latitude (C{bool}). @kwarg wrap: Wrap and L{unrollPI} longitudes (C{bool}). @kwarg fraction: Index fraction (C{float} in L{EPS}..L{EPS1}) to interpolate intermediate B{C{points}} or use C{None}, C{0} or C{1} for no intermediate B{C{points}} and no L{fractional} indices. @kwarg name: Optional calculator/interpolator name (C{str}). 
 @raise FrechetError: Insufficient number of B{C{points}} or invalid B{C{adjust}} or B{C{seed}}. ''' adjust=adjust, wrap=wrap) 
 if _FOR_DOCS: discrete = Frechet.discrete 
 '''Return the L{equirectangular_} distance in C{radians squared}. ''' 
 
 '''Compute the C{Frechet} distance based on the C{Euclidean} distance in C{radians} from function L{euclidean_}. 
 @see: L{FrechetCosineLaw}, L{FrechetEquirectangular}, L{FrechetFlatPolar}, L{FrechetHaversine} and L{FrechetVincentys}. ''' 
 '''New L{FrechetEuclidean} calculator/interpolator. 
 @arg points: First set of points (C{LatLon}[], L{Numpy2LatLon}[], L{Tuple2LatLon}[] or C{other}[]). @kwarg adjust: Adjust the wrapped, unrolled longitudinal delta by the cosine of the mean latitude (C{bool}). @kwarg fraction: Index fraction (C{float} in L{EPS}..L{EPS1}) to interpolate intermediate B{C{points}} or use C{None}, C{0} or C{1} for no intermediate B{C{points}} and no L{fractional} indices. @kwarg name: Optional calculator/interpolator name (C{str}). 
 @raise FrechetError: Insufficient number of B{C{points}} or invalid B{C{fraction}}. ''' adjust=adjust) 
 if _FOR_DOCS: discrete = Frechet.discrete 
 '''Return the L{euclidean_} distance in C{radians}. ''' 
 
 '''Compute the C{Frechet} distance based on the I{angular} distance in C{radians squared} like function L{flatLocal_}/L{hubeny_}. 
 @see: L{FrechetCosineAndoyerLambert}, L{FrechetCosineForsytheAndoyerLambert}, L{FrechetDistanceTo}, L{FrechetHubeny}, L{FrechetKarney} and L{FrechetThomas}. ''' 
 '''New L{FrechetFlatLocal}/L{FrechetHubeny} calculator/interpolator. 
 @arg points: First set of points (C{LatLon}[], L{Numpy2LatLon}[], L{Tuple2LatLon}[] or C{other}[]). @kwarg datum: Optional datum overriding the default C{Datums.WGS84} and first B{C{points}}' datum (L{Datum}). @kwarg wrap: Wrap and L{unrollPI} longitudes (C{bool}) @kwarg fraction: Index fraction (C{float} in L{EPS}..L{EPS1}) to interpolate intermediate B{C{points}} or use C{None}, C{0} or C{1} for no intermediate B{C{points}} and no L{fractional} indices. @kwarg name: Optional calculator/interpolator name (C{str}). 
 @raise FrechetError: Insufficient number of B{C{points}} or invalid B{C{fraction}}. 
 @raise TypeError: Invalid B{C{datum}}. ''' wrap=wrap) 
 if _FOR_DOCS: discrete = Frechet.discrete 
 '''Return the L{flatLocal_}/L{hubeny_} distance in C{radians squared}. ''' 
 
 '''Compute the C{Frechet} distance based on the I{angular} distance in C{radians} from function L{flatPolar_}. 
 @see: L{FrechetCosineLaw}, L{FrechetEquirectangular}, L{FrechetEuclidean}, L{FrechetHaversine} and L{FrechetVincentys}. ''' 
 '''New L{FrechetFlatPolar} calculator/interpolator. 
 @arg points: First set of points (C{LatLon}[], L{Numpy2LatLon}[], L{Tuple2LatLon}[] or C{other}[]). @kwarg wrap: Wrap and L{unrollPI} longitudes (C{bool}). @kwarg fraction: Index fraction (C{float} in L{EPS}..L{EPS1}) to interpolate intermediate B{C{points}} or use C{None}, C{0} or C{1} for no intermediate B{C{points}} and no I{fractional} indices. @kwarg name: Optional calculator/interpolator name (C{str}). 
 @raise FrechetError: Insufficient number of B{C{points}} or invalid B{C{fraction}}. ''' wrap=wrap) 
 if _FOR_DOCS: discrete = Frechet.discrete 
 '''Return the L{flatPolar_} distance in C{radians}. ''' 
 
 '''Compute the C{Frechet} distance based on the I{angular} distance in C{radians} from function L{haversine_}. 
 @see: L{FrechetCosineLaw}, L{FrechetEquirectangular}, L{FrechetEuclidean}, L{FrechetFlatPolar} and L{FrechetVincentys}. 
 @note: See note at function L{vincentys_}. ''' 
 '''New L{FrechetHaversine} calculator/interpolator. 
 @arg points: First set of points (C{LatLon}[], L{Numpy2LatLon}[], L{Tuple2LatLon}[] or C{other}[]). @kwarg wrap: Wrap and L{unrollPI} longitudes (C{bool}). @kwarg fraction: Index fraction (C{float} in L{EPS}..L{EPS1}) to interpolate intermediate B{C{points}} or use C{None}, C{0} or C{1} for no intermediate B{C{points}} and no I{fractional} indices. @kwarg name: Optional calculator/interpolator name (C{str}). 
 @raise FrechetError: Insufficient number of B{C{points}} or invalid B{C{fraction}}. ''' wrap=wrap) 
 if _FOR_DOCS: discrete = Frechet.discrete 
 '''Return the L{haversine_} distance in C{radians}. ''' 
 
 if _FOR_DOCS: __doc__ = FrechetFlatLocal.__doc__ __init__ = FrechetFlatLocal.__init__ discrete = FrechetFlatLocal.discrete distance = FrechetFlatLocal.discrete 
 
 '''Compute the C{Frechet} distance based on the I{angular} distance in C{degrees} from I{Charles Karney's} U{GeographicLib <https://PyPI.org/project/geographiclib>} U{Geodesic <https://geographiclib.sourceforge.io/1.49/python/code.html>} Inverse method. 
 @see: L{FrechetCosineAndoyerLambert}, L{FrechetCosineForsytheAndoyerLambert}, L{FrechetDistanceTo}, L{FrechetFlatLocal}, L{FrechetHubeny} and L{FrechetThomas}. ''' 
 '''New L{FrechetKarney} calculator/interpolator. 
 @arg points: First set of points (C{LatLon}[], L{Numpy2LatLon}[], L{Tuple2LatLon}[] or C{other}[]). @kwarg datum: Optional datum overriding the default C{Datums.WGS84} and first B{C{points}}' datum (L{Datum}). @kwarg wrap: Wrap and L{unroll180} longitudes (C{bool}) @kwarg fraction: Index fraction (C{float} in L{EPS}..L{EPS1}) to interpolate intermediate B{C{points}} or use C{None}, C{0} or C{1} for no intermediate B{C{points}} and no L{fractional} indices. @kwarg name: Optional calculator/interpolator name (C{str}). 
 @raise FrechetError: Insufficient number of B{C{points}} or invalid B{C{fraction}}. 
 @raise ImportError: Package U{GeographicLib <https://PyPI.org/project/geographiclib>} missing. 
 @raise TypeError: Invalid B{C{datum}}. ''' wrap=wrap) 
 if _FOR_DOCS: discrete = Frechet.discrete 
 '''Return the non-negative I{angular} distance in C{degrees}. ''' 
 
 '''Compute the C{Frechet} distance based on the I{angular} distance in C{radians} from function L{thomas_}. 
 @see: L{FrechetCosineAndoyerLambert}, L{FrechetCosineForsytheAndoyerLambert}, L{FrechetDistanceTo}, L{FrechetFlatLocal}, L{FrechetHubeny} and L{FrechetKarney}. ''' 
 '''New L{FrechetThomas} calculator/interpolator. 
 @arg points: First set of points (C{LatLon}[], L{Numpy2LatLon}[], L{Tuple2LatLon}[] or C{other}[]). @kwarg datum: Optional datum overriding the default C{Datums.WGS84} and first B{C{points}}' datum (L{Datum}). @kwarg wrap: Wrap and L{unrollPI} longitudes (C{bool}) @kwarg fraction: Index fraction (C{float} in L{EPS}..L{EPS1}) to interpolate intermediate B{C{points}} or use C{None}, C{0} or C{1} for no intermediate B{C{points}} and no L{fractional} indices. @kwarg name: Optional calculator/interpolator name (C{str}). 
 @raise FrechetError: Insufficient number of B{C{points}} or invalid B{C{fraction}}. 
 @raise TypeError: Invalid B{C{datum}}. ''' wrap=wrap) 
 if _FOR_DOCS: discrete = Frechet.discrete 
 '''Return the L{thomas_} distance in C{radians}. ''' 
 
 '''Compute the C{Frechet} distance based on the I{angular} distance in C{radians} from function L{vincentys_}. 
 @see: L{FrechetCosineLaw}, L{FrechetEquirectangular}, L{FrechetEuclidean}, L{FrechetFlatPolar} and L{FrechetHaversine}. 
 @note: See note at function L{vincentys_}. ''' 
 '''New L{FrechetVincentys} calculator/interpolator. 
 @arg points: First set of points (C{LatLon}[], L{Numpy2LatLon}[], L{Tuple2LatLon}[] or C{other}[]). @kwarg wrap: Wrap and L{unrollPI} longitudes (C{bool}). @kwarg fraction: Index fraction (C{float} in L{EPS}..L{EPS1}) to interpolate intermediate B{C{points}} or use C{None}, C{0} or C{1} for no intermediate B{C{points}} and no I{fractional} indices. @kwarg name: Optional calculator/interpolator name (C{str}). 
 @raise FrechetError: Insufficient number of B{C{points}} or invalid B{C{fraction}}. ''' wrap=wrap) 
 if _FOR_DOCS: discrete = Frechet.discrete 
 '''Return the L{vincentys_} distance in C{radians}. ''' 
 
 '''(INTERNAL) Compute point at L{fractional} index. ''' favg(p.lon, q.lon, f=f)) else: p = points[i + 1] 
 
 '''Return the point at a given I{fractional} index. 
 @arg points: The points (C{LatLon}[], L{Numpy2LatLon}[], L{Tuple2LatLon}[] or C{other}[]). @arg fi: The fractional index (C{float} or C{int}). @kwarg LatLon: Optional class to return the I{intermediate}, I{fractional} point (C{LatLon}) or C{None}. @kwarg LatLon_kwds: Optional B{C{LatLon}} keyword arguments, ignored of B{C{LatLon=None}}. 
 @return: A B{C{LatLon}} or if B{C{LatLon}} is C{None}, a L{LatLon2Tuple}C{(lat, lon)} for B{C{points[fi]}} if I{fractional} index B{C{fi}} is C{int}, otherwise the intermediate point between B{C{points[int(fi)]}} and B{C{points[int(fi) + 1]}} for C{float} I{fractional} index B{C{fi}}. 
 @raise IndexError: Fractional index B{C{fi}} invalid or B{C{points}} not subscriptable. ''' raise IndexError except (IndexError, TypeError): raise _IndexError(fractional.__name__, fi) 
 p = LatLon(*p, **LatLon_kwds) 
 
 '''(INTERNAL) Recursive core of function L{frechet_} and method C{discrete} of C{Frechet...} classes. ''' 
 
 
 rF(i - fi, j - fj, r), rF(i, j - fj, r)) raise IndexError else: # j == 0 raise IndexError 
 raise IndexError else: # i == j == 0 
 except IndexError: t = (INF, i, j, r) 
 # del cF, iFs 
 
 '''Compute the I{discrete} U{Fréchet<https://WikiPedia.org/wiki/Frechet_distance>} distance between two paths given as sets of points. 
 @arg points1: First set of points (C{LatLon}[], L{Numpy2LatLon}[], L{Tuple2LatLon}[] or C{other}[]). @arg points2: Second set of points (C{LatLon}[], L{Numpy2LatLon}[], L{Tuple2LatLon}[] or C{other}[]). @kwarg distance: Callable returning the distance between a B{C{points1}} and a B{C{points2}} point (signature C{(point1, point2)}). @kwarg units: Optional, name of the distance units (C{str}). 
 @return: A L{Frechet6Tuple}C{(fd, fi1, fi2, r, n, units)} where C{fi1} and C{fi2} are type C{int} indices into B{C{points1}} respectively B{C{points2}}. 
 @raise FrechetError: Insufficient number of B{C{points1}} or B{C{points2}}. 
 @raise RecursionError: Recursion depth exceeded, see U{sys.getrecursionlimit() <https://docs.Python.org/3/library/sys.html#sys.getrecursionlimit>}. 
 @raise TypeError: If B{C{distance}} is not a callable. 
 @note: Function L{frechet_} does not support I{fractional} indices for intermediate B{C{points1}} and B{C{points2}}. ''' raise _IsnotError(callable.__name__, distance=distance) 
 
 
 
 # **) MIT License # # Copyright (C) 2016-2020 -- mrJean1 at Gmail -- All Rights Reserved. # # Permission is hereby granted, free of charge, to any person obtaining a # copy of this software and associated documentation files (the "Software"), # to deal in the Software without restriction, including without limitation # the rights to use, copy, modify, merge, publish, distribute, sublicense, # and/or sell copies of the Software, and to permit persons to whom the # Software is furnished to do so, subject to the following conditions: # # The above copyright notice and this permission notice shall be included # in all copies or substantial portions of the Software. # # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS # OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL # THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR # OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, # ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR # OTHER DEALINGS IN THE SOFTWARE. |