Coverage for pygeodesy/utmups.py : 95%
 
         
         
    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{utmupsZoneBand5} to handle both I{Universal Transverse Mercator (U{UTM<https://WikiPedia.org/wiki/Universal_Transverse_Mercator_coordinate_system>})} and I{Universal Polar Stereographic (U{UPS<https://WikiPedia.org/wiki/Universal_polar_stereographic_coordinate_system>})} coordinates. 
 A pure Python implementation, partially transcribed from C++ class U{UTMUPS <https://GeographicLib.SourceForge.io/html/classGeographicLib_1_1UTMUPS.html>} by I{Charles Karney}. ''' 
 _outside_, _range_, _SPACE_, _UPS_, _UTM_ _UPS_ZONE, _UPS_ZONE_STR, \ _UTMUPS_ZONE_MIN, _UTMUPS_ZONE_MAX 
 
 
 
 
 
 # UPS ranges for North, South pole 
 
 # UTM ranges for Northern, Southern hemisphere 
 
 '''Universal Transverse Mercator/Universal Polar Stereographic (UTM/UPS) parse, validate or other issue. ''' 
 
 '''Parse a string representing a UTM or UPS coordinate, consisting of C{"zone[band] hemisphere/pole easting northing"}. 
 @arg strUTMUPS: A UTM or UPS coordinate (C{str}). @kwarg datum: Optional datum to use (L{Datum}). @kwarg Utm: Optional class to return the UTM coordinate (L{Utm}) or C{None}. @kwarg Ups: Optional class to return the UPS coordinate (L{Ups}) or C{None}. @kwarg name: Optional instance name (C{str}). 
 @return: The UTM or UPS instance (B{C{Utm}} or B{C{Ups}}) or a L{UtmUps5Tuple}C{(zone, hemipole, easting, northing, band)} if B{C{Utm}} respectively B{C{Ups}} or both are C{None}. The C{hemipole} is C{'N'|'S'}, the UTM hemisphere or UPS pole, the UPS projection top/center. 
 @raise UTMUPSError: Invalid B{C{strUTMUPS}}. 
 @see: Functions L{parseUTM5} and L{parseUPS5}. ''' 
 except (UTMError, UPSError) as x: raise UTMUPSError(strUTMUPS=strUTMUPS, txt=str(x)) 
 
 pole=NN, name=NN, **cmoff): '''Convert a lat-/longitude point to a UTM or UPS coordinate. 
 @arg latlon: Latitude (C{degrees}) or an (ellipsoidal) geodetic C{LatLon} point. @kwarg lon: Optional longitude (C{degrees}) or C{None}. @kwarg datum: Optional datum to use this UTM coordinate, overriding B{C{latlon}}'s datum (C{Datum}). @kwarg falsed: False both easting and northing (C{bool}). @kwarg Utm: Optional class to return the UTM coordinate (L{Utm}) or C{None}. @kwarg Ups: Optional class to return the UPS coordinate (L{Ups}) or C{None}. @kwarg pole: Optional top/center of UPS (stereographic) projection (C{str}, C{'N[orth]'} or C{'S[outh]'}). @kwarg name: Optional name (C{str}). @kwarg cmoff: DEPRECATED, use B{C{falsed}}. Offset longitude from zone's central meridian, for UTM only (C{bool}). 
 @return: The UTM or UPS coordinate (B{C{Utm}} respectively B{C{Ups}}) or a L{UtmUps8Tuple}C{(zone, hemipole, easting, northing, band, datum, convergence, scale)} if B{C{Utm}} respectively B{C{Ups}} is C{None} or B{C{cmoff}} is C{False}. 
 @raise RangeError: If B{C{lat}} outside the valid UTM or UPS bands or if B{C{lat}} or B{C{lon}} outside the valid range and L{rangerrors} set to C{True}. 
 @raise TypeError: If B{C{latlon}} is not ellipsoidal or B{C{lon}} value is missing of B{C{datum}} is invalid. 
 @raise UTMUPSError: UTM or UPS validation failed. 
 @raise ValueError: Invalid B{C{lat}} or B{C{lon}}. 
 @see: Functions L{toUtm8} and L{toUps8}. ''' 
 else: 
 
 falsed=True, name=NN): '''Class-like function to create a UTM/UPS coordinate. 
 @kwarg zone: The UTM (longitudinal) zone with/-out Band letter for UTM or for UPS zone C{"00"} or C{0} (C{str} or C{int}). @kwarg hemipole: UTM hemisphere or UPS top/center of projection (C{str}, C{'N[orth]'} or C{'S[outh]'}). @arg easting: Easting, see B{C{falsed}} (C{meter}). @arg northing: Northing, see B{C{falsed}} (C{meter}). @kwarg band: Optional, UTM (latitudinal) Band letter C{'C'|'D'..'W'|'X'} or UPS (polar) Band letter C{'A'|'B'|'Y'|'Z'} (C{str}). @kwarg datum: Optional, the coordinate's datum (L{Datum}). @kwarg falsed: Both B{C{easting}} and B{C{northing}} are falsed (C{bool}). @kwarg name: Optional name (C{str}). 
 @return: New UTM or UPS instance (L{Utm} or L{Ups}). 
 @raise TypeError: Invalid B({C{datum}}. 
 @raise UTMUPSError: UTM or UPS validation failed. 
 @see: Classes L{Utm} and L{Ups} and I{Karney}'s U{UTMUPS <https://GeographicLib.SourceForge.io/html/classGeographicLib_1_1UTMUPS.html>}. ''' 
 
 '''Check a UTM or UPS coordinate. 
 @arg coord: The UTM or UPS coordinate (L{Utm}, L{Ups} or C{5+Tuple}). @kwarg falsed: C{5+Tuple} easting and northing are falsed (C{bool}). @kwarg MGRS: Increase easting and northing ranges (C{bool}). @kwarg Error: Optional error to raise, overriding the default (L{UTMUPSError}). 
 @return: C{None} if validation passed. 
 @raise Error: Validation failed. 
 @see: Function L{utmupsValidateOK}. ''' 
 except (TypeError, ValueError): pass raise Error(ename, en, txt=t) 
 else: raise _IsnotError(Error=Error, coord=coord, *map1(modulename, Utm, Ups, UtmUps5Tuple, UtmUps8Tuple)) 
 
 else: # UTM 
 U, s = _MGRS_, _MGRS_TILE else: 
 or z > _UTMUPS_ZONE_MAX \ or B not in u._Bands: t = Fmt.PAREN(U, repr(_SPACE_(NN(Fmt.zone(z), B), h))) raise Error(coord=t, zone=zone, band=band, hemisphere=hemi) 
 
 
 '''Check a UTM or UPS coordinate. 
 @arg coord: The UTM or UPS coordinate (L{Utm}, L{Ups} or C{5+Tuple}). @kwarg falsed: C{5+Tuple} easting and northing are falsed (C{bool}). @kwarg ok: Result to return if validation passed (B{C{ok}}). 
 @return: B{C{ok}} if validation passed, the L{UTMUPSError} otherwise. 
 @see: Function L{utmupsValidate}. ''' 
 
 '''Return the UTM/UPS zone number, Band letter, hemisphere/pole and clipped lat- and longitude for a given location. 
 @arg lat: Latitude in degrees (C{scalar} or C{str}). @arg lon: Longitude in degrees (C{scalar} or C{str}). @kwarg cmoff: Offset longitude from the zone's central meridian, for UTM only (C{bool}). 
 @return: A L{UtmUpsLatLon5Tuple}C{(zone, band, hemipole, lat, lon)} where C{hemipole} is C{'N'|'S'}, the UTM hemisphere or UPS pole, the UPS projection top/center. 
 @raise RangeError: If B{C{lat}} outside the valid UTM or UPS bands or if B{C{lat}} or B{C{lon}} outside the valid range and L{rangerrors} set to C{True}. 
 @raise ValueError: Invalid B{C{lat}} or B{C{lon}}. 
 @see: Functions L{utmZoneBand5} and L{upsZoneBand5}. ''' 
 # **) MIT License # # Copyright (C) 2016-2021 -- 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. |