Module etm
A pure Python version of Karney's Exact Transverse 
  Mercator (ETM) projection.
  Classes Etm, 
  ETMError and
  ExactTransverseMercator, transcoded from Karney's
  C++ class TransverseMercatorExact, abbreviated as 
  TMExact below.
  Class ExactTransverseMercator provides Exact Transverse 
  Mercator projections while instances of class Etm represent ETM 
  (easting, northing) locations.  See also Karney's 
  utility TransverseMercatorProj.
  Following is a copy of Karney's TransverseMercatorExact.hpp file 
  Header.
  Copyright (C) Charles Karney (2008-2022) and licensed under the 
  MIT/X11 License.  For more information, see the GeographicLib documentation.
  The method entails using the Thompson Transverse Mercator as an intermediate 
  projection.  The projections from the intermediate coordinates to 
  phi, lam and x, y are given by elliptic 
  functions.  The inverse of these projections are found by Newton's method
  with a suitable starting guess.
  The relevant section of L.P. Lee's paper Conformal Projections Based On Jacobian Elliptic 
  Functions in part V, pp 67-101.  The C++ implementation and notation 
  closely follow Lee, with the following exceptions:
 Lee   here   Description
 x/a   xi     Northing (unit Earth)
 y/a   eta    Easting (unit Earth)
 s/a   sigma  xi + i * eta
 y     x      Easting
 x     y      Northing
 k     e      Eccentricity
 k^2   mu     Elliptic function parameter
 k'^2  mv     Elliptic function complementary parameter
 m     k      Scale
 zeta  zeta   Complex longitude = Mercator = chi in paper
 s     sigma  Complex GK = zeta in paper
  Minor alterations have been made in some of Lee's expressions in an 
  attempt to control round-off.  For example, atanh(sin(phi)) 
  is replaced by asinh(tan(phi)) which maintains accuracy near
  phi = pi/2.  Such changes are noted in the code.
    |  | 
        
          | parseETM5(strUTM,
        datum=Datum(name='WGS84', ellipsoid=Ellipsoids.WGS84, transform=Tran ...,
        Etm=<class 'pygeodesy.etm.Etm'>,
        falsed=True,
        name='')Parse a string representing a UTM coordinate, consisting of
 "zone[band] hemisphere easting northing". |  |  | 
    |  | 
        
          | toEtm8(latlon,
        lon=None,
        datum=None,
        Etm=<class 'pygeodesy.etm.Etm'>,
        falsed=True,
        name='',
        zone=None,
        **cmoff) Convert a lat-/longitude point to an ETM coordinate.
 |  |  | 
| 
  | parseETM5 (strUTM,
        datum=Datum(name='WGS84', ellipsoid=Ellipsoids.WGS84, transform=Tran...,
        Etm=<class 'pygeodesy.etm.Etm'>,
        falsed=True,
        name='') |  |  Parse a string representing a UTM coordinate, consisting of 
  "zone[band] hemisphere easting northing". 
    Arguments:
        strUTM- A UTM coordinate (str).datum- Optional datum to use (Datum, 
          Ellipsoid, Ellipsoid2 or a_f2Tuple).Etm- Optional class to return the UTM coordinate (Etm) orNone.falsed- Both easting and northing arefalsed(bool).name- OptionalEtmname (str).Returns:The UTM coordinate (Etm) or ifEtmisNone, a UtmUps5Tuple(zone, hemipole, easting, 
          northing, band).  Thehemipoleis the 
          hemisphere'N'|'S'.Raises:
        ETMError- InvalidstrUTM.TypeError- Invalid or near-sphericaldatum.       Example:
         
>>> u = parseETM5('31 N 448251 5411932')
>>> u.toRepr()  
>>> u = parseETM5('31 N 448251.8 5411932.7')
>>> u.toStr()   | 
 
| 
  | toEtm8 (latlon,
        lon=None,
        datum=None,
        Etm=<class 'pygeodesy.etm.Etm'>,
        falsed=True,
        name='',
        zone=None,
        **cmoff)
   |  |  Convert a lat-/longitude point to an ETM coordinate. 
    Arguments:
        latlon- Latitude (degrees) or an (ellipsoidal) geodeticLatLonpoint.lon- Optional longitude (degrees) orNone.datum- Optional datum for this ETM coordinate, overridinglatlon's datum (Datum, 
          Ellipsoid, Ellipsoid2 or a_f2Tuple).Etm- Optional class to return the ETM coordinate (Etm) orNone.falsed- False both easting and northing (bool).name- OptionalUtmname (str).zone- Optional UTM zone to enforce (intorstr).cmoff- DEPRECATED, usefalsed.  Offset longitude 
          from the zone's central meridian (bool).Returns:The ETM coordinate (Etm) or a UtmUps8Tuple(zone, hemipole, easting, 
          northing, band, datum, convergence, scale)ifEtmisNoneor notfalsed.  Thehemipoleis the'N'|'S'hemisphere.Raises:
        ETMError- No convergence transforming to ETM east- and northing.ETMError- Invalidzoneor near-spherical or incompatibledatumorellipsoid.RangeError- Iflatoutside the valid UTM bands or iflatorlonoutside the 
        valid range and pygeodesy.rangerrors set toTrue.TypeError- Invalid or near-sphericaldatumorlatlonnot ellipsoidal.ValueError- Thelonvalue is missing orlatlonis invalid. |