GeoEco.Datasets.Virtual.TimeSeriesGridStack
- class GeoEco.Datasets.Virtual.TimeSeriesGridStack(collection, expression=None, reportProgress=True, **options)
Bases:
GridA
Gridbuilt by stacking a set of 2D (yx) or 3D (zyx) Grids queried from aDatasetCollection.- Parameters:
collection (
DatasetCollection) –DatasetCollectioncontaining theGrids to stack. The Grids must all have the same dimensions. Typically, they are either 2-dimensional with dimensionsyxor 3-dimensional with dimensionszyx. However, they may also include atdimension (i.e.tyxortzyx) so long as the length of each Grid in thetdirection is 1. In any case, they must all have the same length as each other for the other dimensions. They must also each have aQueryableAttributedefined with aDataTypeofDateTimeTypeMetadata. The value of this QueryableAttribute must give the time coordinate of the Grid.The oldest Grid in collection selected by expression must also have three lazy properties defined:
TIncrement,TIncrementUnit, andTCornerCoordType. It should also haveTSemiRegularitydefined if necessary. Please see theGriddocumentation for descriptions of these properties.Alternatively, if collection is the parent collection of the Grids, those lazy properties can be defined by collection itself, rather than being defined by the oldest Grid it contains. This is the common use pattern when the Grids do not have a
tdimension.The Grids that are selected by expression must form a time series with time coordinates that are consistent with the
TIncrementandTIncrementUnit. For example, ifTIncrementis 1 andTIncrementUnitis'month', the Grids must occur as a monthly series. Missing time slices are OK and will be automatically represented as slices of NoData. For example, if the DatasetCollection contains 118 monthly Grids spanning 10 years but is missing 2 Grids due to a satellite failure in one of those years, then those two months will automatically be represented as NoData across the entire spatial extent.There must not be any duplicate time slices used to define the
TimeSeriesGridStack. If collection contains duplicates, expression should be used to select a unique set of slices. For example, if collection includes Grids for several oceanographic variables but they can be distinguished from each other by theVariableNameQueryableAttribute, then expression could be set to"VariableName = 'SST'", so that only the SST Grids are stacked.expression (
str, optional) –A SQL-like query expression that selects the datasets of interest based on the values of their queryable attributes. If not provided, all of the datasets in the collection will be selected.
The expression is similar to a SQL “where” clause and may contain the following elements:
The names of any queryable attributes, with no delimiters, that are defined for objects in the collection, including those they inherit from their parents.
The binary comparison operators
=,<,>,<=,>=, and<>.Literals for integers, floating point numbers (with
.as the decimal point), Booleans (writtentrueandfalse), strings (delimited with single or double quotation marks), or dates (written#YYYY-mm-dd HH:MM:SS#or#YYYY-mm-dd#withYYYYas the four-digit year,mmas the two-digit month,ddas the two-digit day,HHas the two-digit hour00to23,MMas the two-digit second, andSSas the two-digit second, with the hour, minute, and second assumed to be00:00:00if not provided).The binary comparison operator
inornot infollowed by a comma-delimited list of literals, enclosed in(and).The binary comparison operator
matchesfollowed by a string literal that specifies a regular expression in Python syntax.The binary arithmetic operators
+,-,*, and/, which may be applied to queryable attributes and numeric literals.The unary arithmetic operator
-, which may be used to negate a queryable attribute or numeric literal.The binary logical operators
orandandand unary logical operatornot.nothas highest precedence;orhas lowest. Logical expressions may be chained together but not nested (in parentheses or by any other means).
Operators and queryable attribute names are case-insensitive.
Minimum length꞉ 1.
reportProgress (
bool, optional) – If True, progress messages will be logged periodically as the query proceeds.options (
dictmappingstrtoobject) – Additional options specific to the collection type.
- Returns:
TimeSeriesGridStackinstance.- Return type:
Properties
- property CenterCoords
(
object) Coordinates of the grid cell centers, indexed using the 1-character dimension of interest and optionally arangeto retrieve anumpy.ndarrayof coordinates (e.g.CenterCoords['x', 0:4]) or an integer to retrieve afloatfor a single coordinate (e.g.CenterCoords['x', 10]). Coordinates for thetdimension are returned asdatetimeinstances. Read only.
- property CoordDependencies
(
tupleofstr) Same length asDimensions. Dimensions that each dimension depends on for determining its coordinates.Nonefor dimensions that have a constant coordinate increment. Read only.
- property CoordIncrements
(
tupleoffloat) Same length asDimensions. Coordinate increment for each dimension.Nonefor dimensions that do not have a constant coordinate increment. Read only.
- property Data
(
object) This grid’s data, indexable using slices (e.g.grid.Data[:, 5:10, -10:]) or integers (e.g.grid.Data[0,1,-2]) or both in combination. Strides and negative indexes are supported in the traditional manner. If the grid is writable,Datacan be assigned to write values to the grid, e.g.grid.Data[0,1] = 5orgrid.Data[:,:] = numpy.zeros(grid.Shape). Returns and acceptsnumpy.ndarray,float, andint. Read only.
- property DataIsScaled
(
bool) If True, the underlying raw data are stored as theUnscaledDataTypeto save storage space and then transformed by a scaling equation on the fly when they are returned byData. The raw data can be accessed withUnscaledData. If False, the raw data are returned as is, with no transformation needed, andUnscaledDataTypeandDataTypeare the same, andUnscaledDatareturns the same values asData. Read only.
- property DataType
(
str) Numeric data type of the grid, after the scaling function (if any) has been applied to the raw data.numpy.ndarrays returned byDatahave this type. Read only. Allowed values꞉'int8','uint8','int16','uint16','int32','uint32','float32','float64'. Case sensitive.
- property Dimensions
(
str) Dimensions of this grid. Read only. Allowed values꞉'yx','zyx','tyx','tzyx'. Case sensitive.
- property DisplayName
(
str) Informal name of this object, suitable to be displayed to the user. Read only. Minimum length꞉ 1.
- property MaxCoords
(
object) Maximum coordinate value for each cell (i.e., the coordinates of the cells’ right edges), indexed using the 1-character dimension of interest and optionally arangeto retrieve anumpy.ndarrayof coordinates (e.g.MaxCoords['x', 0:4]) or an integer to retrieve afloatfor a single coordinate (e.g.MaxCoords['x', 10]). Coordinates for thetdimension are returned asdatetimeinstances. Read only.
- property MinCoords
(
object) Minimum coordinate value for each cell (i.e., the coordinates of the cells’ left edges), indexed using the 1-character dimension of interest and optionally arangeto retrieve anumpy.ndarrayof coordinates (e.g.MinCoords['x', 0:4]) or an integer to retrieve afloatfor a single coordinate (e.g.MinCoords['x', 10]). Coordinates for thetdimension are returned asdatetimeinstances. Read only.
- property NoDataValue
(
objectorNone)int,float, or single-element numpy array giving the value that indicates that cells ofDatashould be interpreted as having no data (these are also known as missing, NA, or NULL cells), orNoneif all cells must have data. Read only.
- property ParentCollection
(
DatasetCollectionorNone) ParentDatasetCollectionthat this object is part of (if any). Read only.
- property ReportProgress
None
- property Shape
(
tupleofint) Same length asDimensions. Length (number of grid cells) of each dimension. Read only.
- property TCountPerSemiRegularPeriod
(
intorNone) Number of time slices per semi-regular period (i.e. per year).Noneif the grid’s dimensions do not contain atcoordinate or thetcoordinate is not semi-regular. Read only.
- property TIncrementUnit
(
strorNone) Unit of thetcoordinate.Noneif the grid’s dimensions do not contain atcoordinate. Read only. Allowed values꞉'year','month','day','hour','minute','second'. Case sensitive.
- property TSemiRegularity
(
strorNone) Type of semi-regularity used for thetcoordinate.Noneif the grid’s dimensions do not contain atcoordinate or thetcoordinate is not semi-regular. Read only. Allowed values꞉'annual'. Case sensitive.
- property UnscaledData
(
object) This grid’s data underlying raw data, before it has been transformed by a scaling equation.UnscaledDatais indexable using slices (e.g.grid.UnscaledData[:, 5:10, -10:]) or integers (e.g.grid.UnscaledData[0,1,-2]) or both in combination. Strides and negative indexes are supported in the traditional manner. If the grid is writable,UnscaledDatacan be assigned to write values to the grid, e.g.grid.UnscaledData[0,1] = 5orgrid.UnscaledData[:,:] = numpy.zeros(grid.Shape). Returns and acceptsnumpy.ndarray,float, andint. Read only.
- property UnscaledDataType
(
str) Numeric data type of the grid’s raw data, before it has been transformed by a scaling equation.numpy.ndarrays returned byUnscaledDatahave this type. If no transformation is needed (DataIsScaledis False), thenUnscaledDataTypeandScaledDataTypeare the same, andUnscaledDatareturns the same values asData. Read only. Allowed values꞉'int8','uint8','int16','uint16','int32','uint32','float32','float64'. Case sensitive.
- property UnscaledNoDataValue
(
objectorNone)intorfloatvalue that indicates that cells ofUnscaledDatashould be interpreted as having no data (these are also known as missing, NA, or NULL cells), orNoneif all cells must have data. Read only.
Methods
Closes any open files or connections associated with this object and releases any other resources allocated to access it.
Converts a spatial reference from one format to another, such as an OGC WKT string to a Proj4 string.
Deletes the lazy property with the specified name.
Returns a list of all queryable attributes.
Given a
tupleorlistof coordinates, returns alistofintindices intoDatafor the cell that contains the coordinates.Returns the value of the lazy property with the specified name.
Returns the queryable attribute with the specified name.
Returns the value of the queryable attribute with the specified name.
Returns a list queryable attributes having the specified data type.
Returns the spatial reference of this dataset.
Returns True if the specified lazy property has a value.
Sets the lazy property with the specified name to the specified value.
Sets the spatial reference of this dataset.
Tests whether a capability is supported by this class or an instance of it.