Source code for polar2grid.core.proj

#!/usr/bin/env python3
# encoding: utf-8
# Copyright (C) 2013 Space Science and Engineering Center (SSEC),
# University of Wisconsin-Madison.
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program.  If not, see <http://www.gnu.org/licenses/>.
#
# This file is part of the polar2grid software package. Polar2grid takes
# satellite observation data, remaps it, and writes it to a file format for
# input into another program.
# Documentation: http://www.ssec.wisc.edu/software/polar2grid/
#
# Written by David Hoese    March 2013
# University of Wisconsin-Madison
# Space Science and Engineering Center
# 1225 West Dayton Street
# Madison, WI  53706
# david.hoese@ssec.wisc.edu
"""Script for converting lon/lat decimal values to X/Y values of the grid provided.

This script mimics the `proj` binary that comes with the PROJ.4 library, but
handles any projection string that `pyproj` can handle (like 'latlong' which the
`proj` binary does not handle).

"""

import sys

try:
    from pyproj import Proj as BaseProj
except ImportError:
    # This module is loaded by meta.py which could be all a user needs so we shouldn't fail if they don't have pyproj
    import warnings

    warnings.warn("Package 'pyproj' could not be imported. Some functionality will be missing")
    Proj = object


[docs]class Proj(BaseProj):
[docs] def is_latlong(self): if hasattr(self, "crs"): return self.crs.is_geographic return super(Proj, self).is_latlong()
def __call__(self, data1, data2, **kwargs): if self.is_latlong(): return data1, data2 return super(Proj, self).__call__(data1, data2, **kwargs)
[docs]def get_parser(): from argparse import ArgumentParser parser = ArgumentParser(description="Convert latitude/longitude coordinates to X/Y values.") parser.add_argument( "-i", "--inverse", dest="inv", action="store_true", default=False, help="Convert X/Y values to latitude/longitude coordinates", ) parser.add_argument("proj4_str", help="PROJ.4 projection string (in quotes)") parser.add_argument("lon_point", type=float, help="Longitude of the point to be converted (single value only)") parser.add_argument("lat_point", type=float, help="Latitude of the point to be converted (single value only)") return parser
[docs]def main(): parser = get_parser() args = parser.parse_args() p = Proj(args.proj4_str) x, y = p(args.lon_point, args.lat_point, inverse=args.inv) print(x, y)
if __name__ == "__main__": sys.exit(main())