2015-06-12 11:57:06 -06:00
|
|
|
# #
|
|
|
|
# This software was developed and / or modified by Raytheon Company,
|
|
|
|
# pursuant to Contract DG133W-05-CQ-1067 with the US Government.
|
2016-03-16 16:32:17 -05:00
|
|
|
#
|
2015-06-12 11:57:06 -06:00
|
|
|
# U.S. EXPORT CONTROLLED TECHNICAL DATA
|
|
|
|
# This software product contains export-restricted data whose
|
|
|
|
# export/transfer/disclosure is restricted by U.S. law. Dissemination
|
|
|
|
# to non-U.S. persons whether in the United States or abroad requires
|
|
|
|
# an export license or other authorization.
|
2016-03-16 16:32:17 -05:00
|
|
|
#
|
2015-06-12 11:57:06 -06:00
|
|
|
# Contractor Name: Raytheon Company
|
|
|
|
# Contractor Address: 6825 Pine Street, Suite 340
|
|
|
|
# Mail Stop B8
|
|
|
|
# Omaha, NE 68106
|
|
|
|
# 402.291.0100
|
2016-03-16 16:32:17 -05:00
|
|
|
#
|
2015-06-12 11:57:06 -06:00
|
|
|
# See the AWIPS II Master Rights File ("Master Rights File.pdf") for
|
|
|
|
# further licensing information.
|
|
|
|
# #
|
|
|
|
|
|
|
|
#
|
|
|
|
# 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
|
|
|
|
2017-11-06 13:47:15 -07:00
|
|
|
def __init__(self, gridDataRecord, nx, ny, latLonGrid):
|
2015-06-12 11:57:06 -06:00
|
|
|
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
|