python-awips/awips/dataaccess/PyGridData.py

57 lines
1.6 KiB
Python
Raw Permalink Normal View History

2015-06-12 11:57:06 -06:00
# #
# #
#
# Implements IGridData for use by native Python clients to the Data Access
# Framework.
2016-03-16 16:32:17 -05:00
#
#
2015-06-12 11:57:06 -06:00
# SOFTWARE HISTORY
2016-03-16 16:32:17 -05:00
#
2015-06-12 11:57:06 -06:00
# Date Ticket# Engineer Description
# ------------ ---------- ----------- --------------------------
# 06/03/13 #2023 dgilling Initial Creation.
2017-01-06 12:00:14 -07:00
# 11/10/16 #5900 bsteffen Correct grid shape
2016-03-16 16:32:17 -05:00
#
2015-06-12 11:57:06 -06:00
#
import numpy
import warnings
2016-03-11 15:05:01 -07:00
from awips.dataaccess import IGridData
from awips.dataaccess import PyData
2015-06-12 11:57:06 -06:00
NO_UNIT_CONVERT_WARNING = """
The ability to unit convert grid data is not currently available in this version of the Data Access Framework.
"""
class PyGridData(IGridData, PyData.PyData):
2016-03-16 16:32:17 -05:00
2015-06-12 11:57:06 -06:00
def __init__(self, gridDataRecord, nx, ny, latLonGrid):
PyData.PyData.__init__(self, gridDataRecord)
nx = nx
ny = ny
self.__parameter = gridDataRecord.getParameter()
self.__unit = gridDataRecord.getUnit()
2017-01-06 12:00:14 -07:00
self.__gridData = numpy.reshape(numpy.array(gridDataRecord.getGridData()), (ny, nx))
2015-06-12 11:57:06 -06:00
self.__latLonGrid = latLonGrid
2016-03-16 16:32:17 -05:00
2015-06-12 11:57:06 -06:00
def getParameter(self):
return self.__parameter
2016-03-16 16:32:17 -05:00
2015-06-12 11:57:06 -06:00
def getUnit(self):
return self.__unit
2016-03-16 16:32:17 -05:00
2015-06-12 11:57:06 -06:00
def getRawData(self, unit=None):
# TODO: Find a proper python library that deals will with numpy and
# javax.measure style unit strings and hook it in to this method to
# allow end-users to perform unit conversion for grid data.
if unit is not None:
warnings.warn(NO_UNIT_CONVERT_WARNING, stacklevel=2)
return self.__gridData
2016-03-16 16:32:17 -05:00
2015-06-12 11:57:06 -06:00
def getLatLonCoords(self):
return self.__latLonGrid