API (General)¶
High level Interface¶
The high-level interface tries to provide an opinionated, Pythonic, API to interact with openEO back-ends. It’s aim is to hide some of the details of using a web service, so the user can produce concise and readable code.
Users that want to interact with openEO on a lower level, and have more control, can use the lower level classes.
openeo¶
- openeo.connect(url=None, *, auth_type=None, auth_options=None, session=None, default_timeout=None, auto_validate=True)[source]¶
This method is the entry point to OpenEO. You typically create one connection object in your script or application and re-use it for all calls to that backend.
If the backend requires authentication, you can pass authentication data directly to this function, but it could be easier to authenticate as follows:
>>> # For basic authentication >>> conn = connect(url).authenticate_basic(username="john", password="foo") >>> # For OpenID Connect authentication >>> conn = connect(url).authenticate_oidc(client_id="myclient")
- Parameters:
url (
Optional
[str
]) – The http url of the OpenEO back-end.auth_type (
Optional
[str
]) – Which authentication to use: None, “basic” or “oidc” (for OpenID Connect)auth_options (
Optional
[dict
]) – Options/arguments specific to the authentication typedefault_timeout (
Optional
[int
]) – default timeout (in seconds) for requestsauto_validate (
bool
) – toggle to automatically validate process graphs before execution
- Return type:
Added in version 0.24.0: added
auto_validate
argument
openeo.rest.datacube¶
The main module for creating earth observation processes. It aims to easily build complex process chains, that can be evaluated by an openEO backend.
- openeo.rest.datacube.THIS¶
Symbolic reference to the current data cube, to be used as argument in
DataCube.process()
calls
- class openeo.rest.datacube.DataCube(graph, connection, metadata=None)[source]¶
Class representing a openEO (raster) data cube.
The data cube is represented by its corresponding openeo “process graph” and this process graph can be “grown” to a desired workflow by calling the appropriate methods.
- add(other, reverse=False)[source]¶
- Return type:
See also
openeo.org documentation on process “add”.
- add_dimension(name, label, type=None)[source]¶
Adds a new named dimension to the data cube. Afterwards, the dimension can be referenced with the specified name. If a dimension with the specified name exists, the process fails with a DimensionExists error. The dimension label of the dimension is set to the specified label.
This call does not modify the datacube in place, but returns a new datacube with the additional dimension.
- Parameters:
name (
str
) – The name of the dimension to addlabel (
str
) – The dimension label.type (
Optional
[str
]) – Dimension type, allowed values: ‘spatial’, ‘temporal’, ‘bands’, ‘other’, default value is ‘other’
- Returns:
The data cube with a newly added dimension. The new dimension has exactly one dimension label. All other dimensions remain unchanged.
See also
openeo.org documentation on process “add_dimension”.
- aggregate_spatial(geometries, reducer, target_dimension=None, crs=None, context=None)[source]¶
Aggregates statistics for one or more geometries (e.g. zonal statistics for polygons) over the spatial dimensions.
- Parameters:
geometries (
Union
[BaseGeometry
,dict
,str
,Path
,Parameter
,VectorCube
]) – a shapely geometry, a GeoJSON-style dictionary, a public GeoJSON URL, or a path (that is valid for the back-end) to a GeoJSON file.reducer (
Union
[str
,Callable
,PGNode
]) –the “child callback”: the name of a single openEO process, or a callback function as discussed in Processes with child “callbacks”, or a
UDF
instance.The callback should correspond to a process that receives an array of numerical values and returns a single numerical value. For example:
"mean"
(string)lambda data: data.min()
(function or lambda)
target_dimension (
Optional
[str
]) – The new dimension name to be used for storing the results.crs (
Union
[int
,str
,None
]) – The spatial reference system of the provided polygon. By default, longitude-latitude (EPSG:4326) is assumed. Seeopeneo.util.normalize_crs()
for more details about additional normalization that is applied to this argument.context (
Optional
[dict
]) –Additional data to be passed to the reducer process.
Note
this
crs
argument is a non-standard/experimental feature, only supported by specific back-ends. See https://github.com/Open-EO/openeo-processes/issues/235 for details.
- Return type:
See also
openeo.org documentation on process “aggregate_spatial”.
- aggregate_spatial_window(reducer, size, boundary='pad', align='upper-left', context=None)[source]¶
Aggregates statistics over the horizontal spatial dimensions (axes x and y) of the data cube.
The pixel grid for the axes x and y is divided into non-overlapping windows with the size specified in the parameter size. If the number of values for the axes x and y is not a multiple of the corresponding window size, the behavior specified in the parameters boundary and align is applied. For each of these windows, the reducer process computes the result.
- Parameters:
reducer (
Union
[str
,Callable
,PGNode
]) – the “child callback”: the name of a single openEO process, or a callback function as discussed in Processes with child “callbacks”, or aUDF
instance.size (
List
[int
]) – Window size in pixels along the horizontal spatial dimensions. The first value corresponds to the x axis, the second value corresponds to the y axis.boundary (
str
) –Behavior to apply if the number of values for the axes x and y is not a multiple of the corresponding value in the size parameter. Options are:
pad
(default): pad the data cube with the no-data value null to fit the required window size.trim
: trim the data cube to fit the required window size.
Use the parameter
align
to align the data to the desired corner.align (
str
) – If the data requires padding or trimming (see parameterboundary
), specifies to which corner of the spatial extent the data is aligned to. For example, if the data is aligned to the upper left, the process pads/trims at the lower-right.context (
Optional
[dict
]) – Additional data to be passed to the process.
- Return type:
- Returns:
A data cube with the newly computed values and the same dimensions.
See also
openeo.org documentation on process “aggregate_spatial_window”.
- aggregate_temporal(intervals, reducer, labels=None, dimension=None, context=None)[source]¶
Computes a temporal aggregation based on an array of date and/or time intervals.
Calendar hierarchies such as year, month, week etc. must be transformed into specific intervals by the clients. For each interval, all data along the dimension will be passed through the reducer. The computed values will be projected to the labels, so the number of labels and the number of intervals need to be equal.
If the dimension is not set, the data cube is expected to only have one temporal dimension.
- Parameters:
intervals (
List
[list
]) – Temporal left-closed intervals so that the start time is contained, but not the end time.reducer (
Union
[str
,Callable
,PGNode
]) –the “child callback”: the name of a single openEO process, or a callback function as discussed in Processes with child “callbacks”, or a
UDF
instance.The callback should correspond to a process that receives an array of numerical values and returns a single numerical value. For example:
"mean"
(string)lambda data: data.min()
(function or lambda)
labels (
Optional
[List
[str
]]) – Labels for the intervals. The number of labels and the number of groups need to be equal.dimension (
Optional
[str
]) – The temporal dimension for aggregation. All data along the dimension will be passed through the specified reducer. If the dimension is not set, the data cube is expected to only have one temporal dimension.context (
Optional
[dict
]) – Additional data to be passed to the reducer. Not set by default.
- Return type:
- Returns:
A
DataCube
containing a result for each time window
See also
openeo.org documentation on process “aggregate_temporal”.
- aggregate_temporal_period(period, reducer, dimension=None, context=None)[source]¶
Computes a temporal aggregation based on calendar hierarchies such as years, months or seasons. For other calendar hierarchies aggregate_temporal can be used.
For each interval, all data along the dimension will be passed through the reducer.
If the dimension is not set or is set to null, the data cube is expected to only have one temporal dimension.
The period argument specifies the time intervals to aggregate. The following pre-defined values are available:
hour: Hour of the day
day: Day of the year
week: Week of the year
dekad: Ten day periods, counted per year with three periods per month (day 1 - 10, 11 - 20 and 21 - end of month). The third dekad of the month can range from 8 to 11 days. For example, the fourth dekad is Feb, 1 - Feb, 10 each year.
month: Month of the year
season: Three month periods of the calendar seasons (December - February, March - May, June - August, September - November).
tropical-season: Six month periods of the tropical seasons (November - April, May - October).
year: Proleptic years
decade: Ten year periods (0-to-9 decade), from a year ending in a 0 to the next year ending in a 9.
decade-ad: Ten year periods (1-to-0 decade) better aligned with the Anno Domini (AD) calendar era, from a year ending in a 1 to the next year ending in a 0.
- Parameters:
period (
str
) – The period of the time intervals to aggregate.reducer (
Union
[str
,PGNode
,Callable
]) – A reducer to be applied on all values along the specified dimension. The reducer must be a callable process (or a set processes) that accepts an array and computes a single return value of the same type as the input values, for example median.dimension (
Optional
[str
]) – The temporal dimension for aggregation. All data along the dimension will be passed through the specified reducer. If the dimension is not set, the data cube is expected to only have one temporal dimension.context (
Optional
[Dict
]) – Additional data to be passed to the reducer.
- Return type:
- Returns:
A data cube with the same dimensions. The dimension properties (name, type, labels, reference system and resolution) remain unchanged.
See also
openeo.org documentation on process “aggregate_temporal_period”.
- apply(process, context=None)[source]¶
Applies a unary process (a local operation) to each value of the specified or all dimensions in the data cube.
- Parameters:
process (
Union
[str
,Callable
,UDF
,PGNode
]) –the “child callback”: the name of a single process, or a callback function as discussed in Processes with child “callbacks”, or a
UDF
instance.The callback should correspond to a process that receives a single numerical value and returns a single numerical value. For example:
"absolute"
(string)lambda x: x * 2 + 3
(function or lambda)
context (
Optional
[dict
]) – Additional data to be passed to the process.
- Return type:
- Returns:
A data cube with the newly computed values. The resolution, cardinality and the number of dimensions are the same as for the original data cube.
See also
openeo.org documentation on process “apply”.
- apply_dimension(code=None, runtime=None, process=None, version=None, dimension='t', target_dimension=None, context=None)[source]¶
Applies a process to all pixel values along a dimension of a raster data cube. For example, if the temporal dimension is specified the process will work on a time series of pixel values.
The process to apply is specified by either code and runtime in case of a UDF, or by providing a callback function in the process argument.
The process reduce_dimension also applies a process to pixel values along a dimension, but drops the dimension afterwards. The process apply applies a process to each pixel value in the data cube.
The target dimension is the source dimension if not specified otherwise in the target_dimension parameter. The pixel values in the target dimension get replaced by the computed pixel values. The name, type and reference system are preserved.
The dimension labels are preserved when the target dimension is the source dimension and the number of pixel values in the source dimension is equal to the number of values computed by the process. Otherwise, the dimension labels will be incrementing integers starting from zero, which can be changed using rename_labels afterwards. The number of labels will equal to the number of values computed by the process.
- Parameters:
code (
Optional
[str
]) – [deprecated] UDF code or process identifier (optional)runtime – [deprecated] UDF runtime to use (optional)
process (
Union
[str
,Callable
,UDF
,PGNode
]) –the “child callback”: the name of a single process, or a callback function as discussed in Processes with child “callbacks”, or a
UDF
instance.The callback should correspond to a process that receives an array of numerical values and returns an array of numerical values. For example:
"sort"
(string)lambda data: data.concat([42, -3])
(function or lambda)
version (
Optional
[str
]) – [deprecated] Version of the UDF runtime to usedimension (
str
) – The name of the source dimension to apply the process on. Fails with a DimensionNotAvailable error if the specified dimension does not exist.target_dimension (
Optional
[str
]) – The name of the target dimension or null (the default) to use the source dimension specified in the parameter dimension. By specifying a target dimension, the source dimension is removed. The target dimension with the specified name and the type other (see add_dimension) is created, if it doesn’t exist yet.context (
Optional
[dict
]) – Additional data to be passed to the process.
- Return type:
- Returns:
A datacube with the UDF applied to the given dimension.
- Raises:
DimensionNotAvailable
Changed in version 0.13.0: arguments
code
,runtime
andversion
are deprecated if favor of the standard approach of using anUDF
object in theprocess
argument. See openeo.UDF API and usage changes in version 0.13.0 for more background about the changes.See also
openeo.org documentation on process “apply_dimension”.
- apply_kernel(kernel, factor=1.0, border=0, replace_invalid=0)[source]¶
Applies a focal operation based on a weighted kernel to each value of the specified dimensions in the data cube.
The border parameter determines how the data is extended when the kernel overlaps with the borders. The following options are available:
numeric value - fill with a user-defined constant number n: nnnnnn|abcdefgh|nnnnnn (default, with n = 0)
replicate - repeat the value from the pixel at the border: aaaaaa|abcdefgh|hhhhhh
reflect - mirror/reflect from the border: fedcba|abcdefgh|hgfedc
reflect_pixel - mirror/reflect from the center of the pixel at the border: gfedcb|abcdefgh|gfedcb
wrap - repeat/wrap the image: cdefgh|abcdefgh|abcdef
- Parameters:
kernel (
Union
[ndarray
,List
[List
[float
]]]) – The kernel to be applied on the data cube. The kernel has to be as many dimensions as the data cube has dimensions.factor – A factor that is multiplied to each value computed by the focal operation. This is basically a shortcut for explicitly multiplying each value by a factor afterwards, which is often required for some kernel-based algorithms such as the Gaussian blur.
border – Determines how the data is extended when the kernel overlaps with the borders. Defaults to fill the border with zeroes.
replace_invalid – This parameter specifies the value to replace non-numerical or infinite numerical values with. By default, those values are replaced with zeroes.
- Return type:
- Returns:
A data cube with the newly computed values. The resolution, cardinality and the number of dimensions are the same as for the original data cube.
See also
openeo.org documentation on process “apply_kernel”.
- apply_neighborhood(process, size, overlap=None, context=None)[source]¶
Applies a focal process to a data cube.
A focal process is a process that works on a ‘neighbourhood’ of pixels. The neighbourhood can extend into multiple dimensions, this extent is specified by the size argument. It is not only (part of) the size of the input window, but also the size of the output for a given position of the sliding window. The sliding window moves with multiples of size.
An overlap can be specified so that neighbourhoods can have overlapping boundaries. This allows for continuity of the output. The values included in the data cube as overlap can’t be modified by the given process.
The neighbourhood size should be kept small enough, to avoid running beyond computational resources, but a too small size will result in a larger number of process invocations, which may slow down processing. Window sizes for spatial dimensions typically are in the range of 64 to 512 pixels, while overlaps of 8 to 32 pixels are common.
The process must not add new dimensions, or remove entire dimensions, but the result can have different dimension labels.
For the special case of 2D convolution, it is recommended to use
apply_kernel()
.- Parameters:
size (
List
[Dict
])overlap (
List
[dict
])process (
Union
[str
,PGNode
,Callable
,UDF
]) – a callback function that creates a process graph, see Processes with child “callbacks”context (
Optional
[dict
]) – Additional data to be passed to the process.
- Return type:
- Returns:
See also
openeo.org documentation on process “apply_neighborhood”.
- apply_polygon(polygons, process, mask_value=None, context=None)[source]¶
Apply a process to segments of the data cube that are defined by the given polygons. For each polygon provided, all pixels for which the point at the pixel center intersects with the polygon (as defined in the Simple Features standard by the OGC) are collected into sub data cubes. If a pixel is part of multiple of the provided polygons (e.g., when the polygons overlap), the GeometriesOverlap exception is thrown. Each sub data cube is passed individually to the given process.
Warning
experimental process: not generally supported, API subject to change.
- Parameters:
polygons (
Union
[BaseGeometry
,dict
,str
,Path
,Parameter
,VectorCube
]) – Polygons, provided as a shapely geometry, a GeoJSON-style dictionary, a public GeoJSON URL, or a path (that is valid for the back-end) to a GeoJSON file.process (
Union
[str
,PGNode
,Callable
,UDF
]) – “child callback” function, see Processes with child “callbacks”mask_value (
Optional
[float
]) – The value used for pixels outside the polygon.context (
Optional
[dict
]) – Additional data to be passed to the process.
- Return type:
See also
openeo.org documentation on process “apply_polygon”.
- ard_normalized_radar_backscatter(elevation_model=None, contributing_area=False, ellipsoid_incidence_angle=False, noise_removal=True)[source]¶
Computes CARD4L compliant backscatter (gamma0) from SAR input. This method is a variant of
sar_backscatter()
, with restricted parameters to generate backscatter according to CARD4L specifications.Note that backscatter computation may require instrument specific metadata that is tightly coupled to the original SAR products. As a result, this process may only work in combination with loading data from specific collections, not with general data cubes.
- Parameters:
elevation_model (
str
) – The digital elevation model to use. Set to None (the default) to allow the back-end to choose, which will improve portability, but reduce reproducibility.contributing_area – If set to true, a DEM-based local contributing area band named contributing_area is added. The values are given in square meters.
ellipsoid_incidence_angle (
bool
) – If set to True, an ellipsoidal incidence angle band named ellipsoid_incidence_angle is added. The values are given in degrees.noise_removal (
bool
) – If set to false, no noise removal is applied. Defaults to True, which removes noise.
- Return type:
- Returns:
Backscatter values expressed as gamma0. The data returned is CARD4L compliant and contains metadata. By default, the backscatter values are given in linear scale.
See also
openeo.org documentation on process “ard_normalized_radar_backscatter”.
- ard_surface_reflectance(atmospheric_correction_method, cloud_detection_method, elevation_model=None, atmospheric_correction_options=None, cloud_detection_options=None)[source]¶
Computes CARD4L compliant surface reflectance values from optical input.
- Parameters:
atmospheric_correction_method (
str
) – The atmospheric correction method to use.cloud_detection_method (
str
) – The cloud detection method to use.elevation_model (
str
) – The digital elevation model to use, leave empty to allow the back-end to make a suitable choice.atmospheric_correction_options (
dict
) – Proprietary options for the atmospheric correction method.cloud_detection_options (
dict
) – Proprietary options for the cloud detection method.
- Return type:
- Returns:
Data cube containing bottom of atmosphere reflectances with atmospheric disturbances like clouds and cloud shadows removed. The data returned is CARD4L compliant and contains metadata.
See also
openeo.org documentation on process “ard_surface_reflectance”.
- atmospheric_correction(method=None, elevation_model=None, options=None)[source]¶
Applies an atmospheric correction that converts top of atmosphere reflectance values into bottom of atmosphere/top of canopy reflectance values.
Note that multiple atmospheric methods exist, but may not be supported by all backends. The method parameter gives you the option of requiring a specific method, but this may result in an error if the backend does not support it.
- Parameters:
method (
str
) – The atmospheric correction method to use. To get reproducible results, you have to set a specific method. Set to null to allow the back-end to choose, which will improve portability, but reduce reproducibility as you may get different results if you run the processes multiple times.elevation_model (
str
) – The digital elevation model to use, leave empty to allow the back-end to make a suitable choice.options (
dict
) – Proprietary options for the atmospheric correction method.
- Return type:
- Returns:
datacube with bottom of atmosphere reflectances
See also
openeo.org documentation on process “atmospheric_correction”.
- band(band)[source]¶
Filter out a single band
- Parameters:
band (
Union
[str
,int
]) – band name, band common name or band index.- Return type:
- Returns:
a DataCube instance
- band_filter(bands)¶
- Return type:
Deprecated since version 0.1.0: Usage of this legacy method is deprecated. Use
filter_bands()
instead.
- chunk_polygon(chunks, process, mask_value=None, context=None)[source]¶
Apply a process to spatial chunks of a data cube.
Warning
experimental process: not generally supported, API subject to change.
- Parameters:
chunks (
Union
[BaseGeometry
,dict
,str
,Path
,Parameter
,VectorCube
]) – Polygons, provided as a shapely geometry, a GeoJSON-style dictionary, a public GeoJSON URL, or a path (that is valid for the back-end) to a GeoJSON file.process (
Union
[str
,PGNode
,Callable
,UDF
]) – “child callback” function, see Processes with child “callbacks”mask_value (
float
) – The value used for cells outside the polygon. This provides a distinction between NoData cells within the polygon (due to e.g. clouds) and masked cells outside it. If no value is provided, NoData cells are used outside the polygon.context (
Optional
[dict
]) – Additional data to be passed to the process.
- Return type:
Deprecated since version 0.26.0: Use
apply_polygon()
.
- count_time()[source]¶
Counts the number of images with a valid mask in a time series for all bands of the input dataset.
- Return type:
- Returns:
a DataCube instance
See also
openeo.org documentation on process “count”.
- classmethod create_collection(cls, collection_id, connection=None, spatial_extent=None, temporal_extent=None, bands=None, fetch_metadata=True, properties=None, max_cloud_cover=None)¶
- Return type:
Deprecated since version 0.4.6: Usage of this legacy class method is deprecated. Use
load_collection()
instead.
- create_job(out_format=None, *, title=None, description=None, plan=None, budget=None, job_options=None, validate=None, **format_options)[source]¶
Sends the datacube’s process graph as a batch job to the back-end and return a
BatchJob
instance.Note that the batch job will just be created at the back-end, it still needs to be started and tracked explicitly. Use
execute_batch()
instead to have the openEO Python client take care of that job management.- Parameters:
out_format (
Optional
[str
]) – output file format.title (
Optional
[str
]) – job titledescription (
Optional
[str
]) – job descriptionplan (
Optional
[str
]) – The billing plan to process and charge the job withbudget (
Optional
[float
]) – Maximum budget to be spent on executing the job. Note that some backends do not honor this limit.job_options (
Optional
[dict
]) – custom job options.validate (
Optional
[bool
]) – Optional toggle to enable/prevent validation of the process graphs before execution (overruling the connection’sauto_validate
setting).
- Return type:
- Returns:
Created job.
- dimension_labels(dimension)[source]¶
Gives all labels for a dimension in the data cube. The labels have the same order as in the data cube.
- Parameters:
dimension (
str
) – The name of the dimension to get the labels for.- Return type:
See also
openeo.org documentation on process “dimension_labels”.
- divide(other, reverse=False)[source]¶
- Return type:
See also
openeo.org documentation on process “divide”.
- download(outputfile=None, format=None, options=None, *, validate=None)[source]¶
Execute synchronously and download the raster data cube, e.g. as GeoTIFF.
If outputfile is provided, the result is stored on disk locally, otherwise, a bytes object is returned. The bytes object can be passed on to a suitable decoder for decoding.
- Parameters:
outputfile (
Union
[str
,Path
,None
]) – Optional, an output file if the result needs to be stored on disk.format (
Optional
[str
]) – Optional, an output format supported by the backend.options (
Optional
[dict
]) – Optional, file format optionsvalidate (
Optional
[bool
]) – Optional toggle to enable/prevent validation of the process graphs before execution (overruling the connection’sauto_validate
setting).
- Return type:
Optional
[bytes
]- Returns:
None if the result is stored to disk, or a bytes object returned by the backend.
- drop_dimension(name)[source]¶
Drops a dimension from the data cube. Dropping a dimension only works on dimensions with a single dimension label left, otherwise the process fails with a DimensionLabelCountMismatch exception. Dimension values can be reduced to a single value with a filter such as filter_bands or the reduce_dimension process. If a dimension with the specified name does not exist, the process fails with a DimensionNotAvailable exception.
- Parameters:
name (
str
) – The name of the dimension to drop- Returns:
The data cube with the given dimension dropped.
See also
openeo.org documentation on process “drop_dimension”.
- execute(*, validate=None, auto_decode=True)[source]¶
Execute a process graph synchronously and return the result. If the result is a JSON object, it will be parsed.
- Parameters:
validate (
Optional
[bool
]) – Optional toggle to enable/prevent validation of the process graphs before execution (overruling the connection’sauto_validate
setting).auto_decode (
bool
) – Boolean flag to enable/disable automatic JSON decoding of the response. Defaults to True.
- Return type:
Union
[dict
,Response
]- Returns:
parsed JSON response as a dict if auto_decode is True, otherwise response object
- execute_batch(outputfile=None, out_format=None, *, print=<built-in function print>, max_poll_interval=60, connection_retry_interval=30, job_options=None, validate=None, **format_options)[source]¶
Evaluate the process graph by creating a batch job, and retrieving the results when it is finished. This method is mostly recommended if the batch job is expected to run in a reasonable amount of time.
For very long-running jobs, you probably do not want to keep the client running.
- Parameters:
outputfile (
Union
[str
,Path
,None
]) – The path of a file to which a result can be writtenout_format (
Optional
[str
]) – (optional) File format to use for the job result.job_options (
Optional
[dict
])validate (
Optional
[bool
]) – Optional toggle to enable/prevent validation of the process graphs before execution (overruling the connection’sauto_validate
setting).
- Return type:
- static execute_local_udf(udf, datacube=None, fmt='netcdf')[source]¶
Deprecated since version 0.7.0: Use
openeo.udf.run_code.execute_local_udf()
instead
- filter_bands(bands)[source]¶
Filter the data cube by the given bands
- Parameters:
bands (
Union
[List
[Union
[str
,int
]],str
]) – list of band names, common names or band indices. Single band name can also be given as string.- Return type:
- Returns:
a DataCube instance
See also
openeo.org documentation on process “filter_bands”.
- filter_bbox(*args, west=None, south=None, east=None, north=None, crs=None, base=None, height=None, bbox=None)[source]¶
Limits the data cube to the specified bounding box.
The bounding box can be specified in multiple ways.
With keyword arguments:
>>> cube.filter_bbox(west=3, south=51, east=4, north=52, crs=4326)
With a (west, south, east, north) list or tuple (note that EPSG:4326 is the default CRS, so it’s not necessary to specify it explicitly):
>>> cube.filter_bbox([3, 51, 4, 52]) >>> cube.filter_bbox(bbox=[3, 51, 4, 52])
With a bbox dictionary:
>>> bbox = {"west": 3, "south": 51, "east": 4, "north": 52, "crs": 4326} >>> cube.filter_bbox(bbox) >>> cube.filter_bbox(bbox=bbox) >>> cube.filter_bbox(**bbox)
With a shapely geometry (of which the bounding box will be used):
>>> cube.filter_bbox(geometry) >>> cube.filter_bbox(bbox=geometry)
Passing a parameter:
>>> bbox_param = Parameter(name="my_bbox", schema="object") >>> cube.filter_bbox(bbox_param) >>> cube.filter_bbox(bbox=bbox_param)
With a CRS other than EPSG 4326:
>>> cube.filter_bbox( ... west=652000, east=672000, north=5161000, south=5181000, ... crs=32632 ... )
Deprecated: positional arguments are also supported, but follow a non-standard order for legacy reasons:
>>> west, east, north, south = 3, 4, 52, 51 >>> cube.filter_bbox(west, east, north, south)
- Parameters:
crs (
Union
[int
,str
,None
]) – value describing the coordinate reference system. Typically just an int (interpreted as EPSG code, e.g.4326
) or a string (handled as authority string, e.g."EPSG:4326"
). Seeopeneo.util.normalize_crs()
for more details about additional normalization that is applied to this argument.- Return type:
See also
openeo.org documentation on process “filter_bbox”.
- filter_labels(condition, dimension, context=None)[source]¶
Filters the dimension labels in the data cube for the given dimension. Only the dimension labels that match the specified condition are preserved, all other labels with their corresponding data get removed.
- Parameters:
condition (
Union
[PGNode
,Callable
]) – the “child callback” which will be given a single label value (number or string) and returns a boolean expressing if the label should be preserved. Also see Processes with child “callbacks”.dimension (
str
) – The name of the dimension to filter on.
- Return type:
Added in version 0.27.0.
See also
openeo.org documentation on process “filter_labels”.
- filter_spatial(geometries)[source]¶
Limits the data cube over the spatial dimensions to the specified geometries.
For polygons, the filter retains a pixel in the data cube if the point at the pixel center intersects with at least one of the polygons (as defined in the Simple Features standard by the OGC).
For points, the process considers the closest pixel center.
For lines (line strings), the process considers all the pixels whose centers are closest to at least one point on the line.
More specifically, pixels outside of the bounding box of the given geometry will not be available after filtering. All pixels inside the bounding box that are not retained will be set to null (no data).
- Parameters:
geometries – One or more geometries used for filtering, specified as GeoJSON in EPSG:4326.
- Return type:
- Returns:
A data cube restricted to the specified geometries. The dimensions and dimension properties (name, type, labels, reference system and resolution) remain unchanged, except that the spatial dimensions have less (or the same) dimension labels.
See also
openeo.org documentation on process “filter_spatial”.
- filter_temporal(*args, start_date=None, end_date=None, extent=None)[source]¶
Limit the DataCube to a certain date range, which can be specified in several ways:
>>> cube.filter_temporal("2019-07-01", "2019-08-01") >>> cube.filter_temporal(["2019-07-01", "2019-08-01"]) >>> cube.filter_temporal(extent=["2019-07-01", "2019-08-01"]) >>> cube.filter_temporal(start_date="2019-07-01", end_date="2019-08-01"])
See Filter on temporal extent for more details on temporal extent handling and shorthand notation.
- Parameters:
start_date (
Union
[str
,date
,Parameter
,PGNode
,ProcessBuilderBase
,None
]) – start date of the filter (inclusive), as a string or date objectend_date (
Union
[str
,date
,Parameter
,PGNode
,ProcessBuilderBase
,None
]) – end date of the filter (exclusive), as a string or date objectextent (
Union
[Sequence
[Union
[str
,date
,Parameter
,PGNode
,ProcessBuilderBase
,None
]],Parameter
,str
,None
]) – temporal extent. Typically, specified as a two-item list or tuple containing start and end date.
- Return type:
Changed in version 0.23.0: Arguments
start_date
,end_date
andextent
: add support for year/month shorthand notation as discussed at Year/month shorthand notation.See also
openeo.org documentation on process “filter_temporal”.
- fit_curve(parameters, function, dimension)[source]¶
Use non-linear least squares to fit a model function y = f(x, parameters) to data.
The process throws an InvalidValues exception if invalid values are encountered. Invalid values are finite numbers (see also
is_valid()
).Warning
experimental process: not generally supported, API subject to change. https://github.com/Open-EO/openeo-processes/pull/240
- Parameters:
parameters (
list
)function (
Union
[str
,PGNode
,Callable
]) – “child callback” function, see Processes with child “callbacks”dimension (
str
)
See also
openeo.org documentation on process “fit_curve”.
- flat_graph()¶
Get the process graph in internal flat dict representation. :rtype:
Dict
[str
,dict
]Warning
This method is mainly intended for internal use. It is not recommended for general use and is subject to change.
Instead, it is recommended to use
to_json()
orprint_json()
to obtain a standardized, interoperable JSON representation of the process graph. See Export a process graph for more information.
- flatten_dimensions(dimensions, target_dimension, label_separator=None)[source]¶
Combines multiple given dimensions into a single dimension by flattening the values and merging the dimension labels with the given label_separator. Non-string dimension labels will be converted to strings. This process is the opposite of the process
unflatten_dimension()
but executing both processes subsequently doesn’t necessarily create a data cube that is equal to the original data cube.- Parameters:
dimensions (
List
[str
]) – The names of the dimension to combine.target_dimension (
str
) – The name of a target dimension with a single dimension label to replace.label_separator (
Optional
[str
]) – The string that will be used as a separator for the concatenated dimension labels.
- Returns:
A data cube with the new shape.
Warning
experimental process: not generally supported, API subject to change.
Added in version 0.10.0.
See also
openeo.org documentation on process “flatten_dimensions”.
- graph_add_node(process_id, arguments=None, metadata=None, namespace=None, **kwargs)¶
- Return type:
Deprecated since version 0.1.1: Usage of this legacy method is deprecated. Use
process()
instead.
- linear_scale_range(input_min, input_max, output_min, output_max)[source]¶
Performs a linear transformation between the input and output range.
The given number in x is clipped to the bounds specified in inputMin and inputMax so that the underlying formula
((x - inputMin) / (inputMax - inputMin)) * (outputMax - outputMin) + outputMin
never returns any value lower than outputMin or greater than outputMax.
Potential use case include scaling values to the 8-bit range (0 - 255) often used for numeric representation of values in one of the channels of the RGB colour model or calculating percentages (0 - 100).
The no-data value null is passed through and therefore gets propagated.
- Parameters:
input_min – Minimum input value
input_max – Maximum input value
output_min – Minimum value of the desired output range.
output_max – Maximum value of the desired output range.
- Return type:
- Returns:
a DataCube instance
See also
openeo.org documentation on process “linear_scale_range”.
- ln()[source]¶
- Return type:
See also
openeo.org documentation on process “ln”.
- classmethod load_collection(collection_id, connection=None, spatial_extent=None, temporal_extent=None, bands=None, fetch_metadata=True, properties=None, max_cloud_cover=None)[source]¶
Create a new Raster Data cube.
- Parameters:
collection_id (
Union
[str
,Parameter
]) – image collection identifierconnection (
Connection
) – The connection to use to connect with the backend.spatial_extent (
Union
[Dict
[str
,float
],Parameter
,None
]) – limit data to specified bounding box or polygonstemporal_extent (
Union
[Sequence
[Union
[str
,date
,Parameter
,PGNode
,ProcessBuilderBase
,None
]],Parameter
,str
,None
]) – limit data to specified temporal interval. Typically, just a two-item list or tuple containing start and end date. See Filter on temporal extent for more details on temporal extent handling and shorthand notation.bands (
Union
[None
,List
[str
],Parameter
]) – only add the specified bands.properties (
Union
[None
,Dict
[str
,Union
[str
,PGNode
,Callable
]],List
[CollectionProperty
],CollectionProperty
]) – limit data by metadata property predicates. Seecollection_property()
for easy construction of such predicates.max_cloud_cover (
Optional
[float
]) – shortcut to set maximum cloud cover (“eo:cloud_cover” collection property)
- Return type:
- Returns:
new DataCube containing the collection
Changed in version 0.13.0: added the
max_cloud_cover
argument.Changed in version 0.23.0: Argument
temporal_extent
: add support for year/month shorthand notation as discussed at Year/month shorthand notation.Changed in version 0.26.0: Add
collection_property()
support toproperties
argument.See also
openeo.org documentation on process “load_collection”.
- classmethod load_disk_collection(connection, file_format, glob_pattern, **options)[source]¶
Loads image data from disk as a DataCube. This is backed by a non-standard process (‘load_disk_data’). This will eventually be replaced by standard options such as
openeo.rest.connection.Connection.load_stac()
or https://processes.openeo.org/#load_uploaded_files- Parameters:
connection (
Connection
) – The connection to use to connect with the backend.file_format (
str
) – the file format, e.g. ‘GTiff’glob_pattern (
str
) – a glob pattern that matches the files to load from diskoptions – options specific to the file format
- Return type:
- Returns:
the data as a DataCube
Deprecated since version 0.25.0: Depends on non-standard process, replace with
openeo.rest.connection.Connection.load_stac()
where possible.
- log10()[source]¶
- Return type:
See also
openeo.org documentation on process “log”.
- log2()[source]¶
- Return type:
See also
openeo.org documentation on process “log”.
- logarithm(base)[source]¶
- Return type:
See also
openeo.org documentation on process “log”.
- logical_and(other)[source]¶
Apply element-wise logical and operation
See also
openeo.org documentation on process “and”.
- logical_or(other)[source]¶
Apply element-wise logical or operation
See also
openeo.org documentation on process “or”.
- mask(mask=None, replacement=None)[source]¶
Applies a mask to a raster data cube. To apply a vector mask use mask_polygon.
A mask is a raster data cube for which corresponding pixels among data and mask are compared and those pixels in data are replaced whose pixels in mask are non-zero (for numbers) or true (for boolean values). The pixel values are replaced with the value specified for replacement, which defaults to null (no data).
- Parameters:
mask (
DataCube
) – the raster maskreplacement – the value to replace the masked pixels with
- Return type:
See also
openeo.org documentation on process “mask”.
- mask_polygon(mask, srs=None, replacement=None, inside=None)[source]¶
Applies a polygon mask to a raster data cube. To apply a raster mask use mask.
All pixels for which the point at the pixel center does not intersect with any polygon (as defined in the Simple Features standard by the OGC) are replaced. This behaviour can be inverted by setting the parameter inside to true.
The pixel values are replaced with the value specified for replacement, which defaults to no data.
- Parameters:
mask (
Union
[BaseGeometry
,dict
,str
,Path
,Parameter
,VectorCube
]) – The geometry to mask with: a shapely geometry, a GeoJSON-style dictionary, a public GeoJSON URL, or a path (that is valid for the back-end) to a GeoJSON file.srs (
str
) –The spatial reference system of the provided polygon. By default longitude-latitude (EPSG:4326) is assumed.
Note
this
srs
argument is a non-standard/experimental feature, only supported by specific back-ends. See https://github.com/Open-EO/openeo-processes/issues/235 for details.replacement – the value to replace the masked pixels with
- Return type:
See also
openeo.org documentation on process “mask_polygon”.
- max_time()[source]¶
Finds the maximum value of a time series for all bands of the input dataset.
- Return type:
- Returns:
a DataCube instance
See also
openeo.org documentation on process “max”.
- mean_time()[source]¶
Finds the mean value of a time series for all bands of the input dataset.
- Return type:
- Returns:
a DataCube instance
See also
openeo.org documentation on process “mean”.
- median_time()[source]¶
Finds the median value of a time series for all bands of the input dataset.
- Return type:
- Returns:
a DataCube instance
See also
openeo.org documentation on process “median”.
- merge(other, overlap_resolver=None, context=None)¶
- Return type:
Deprecated since version 0.4.6: Usage of this legacy method is deprecated. Use
merge_cubes()
instead.
- merge_cubes(other, overlap_resolver=None, context=None)[source]¶
Merging two data cubes
The data cubes have to be compatible. A merge operation without overlap should be reversible with (a set of) filter operations for each of the two cubes. The process performs the join on overlapping dimensions, with the same name and type. An overlapping dimension has the same name, type, reference system and resolution in both dimensions, but can have different labels. One of the dimensions can have different labels, for all other dimensions the labels must be equal. If data overlaps, the parameter overlap_resolver must be specified to resolve the overlap.
Examples for merging two data cubes:
Data cubes with the dimensions x, y, t and bands have the same dimension labels in x,y and t, but the labels for the dimension bands are B1 and B2 for the first cube and B3 and B4. An overlap resolver is not needed. The merged data cube has the dimensions x, y, t and bands and the dimension bands has four dimension labels: B1, B2, B3, B4.
Data cubes with the dimensions x, y, t and bands have the same dimension labels in x,y and t, but the labels for the dimension bands are B1 and B2 for the first data cube and B2 and B3 for the second. An overlap resolver is required to resolve overlap in band B2. The merged data cube has the dimensions x, y, t and bands and the dimension bands has three dimension labels: B1, B2, B3.
- Data cubes with the dimensions x, y and t have the same dimension labels in x,y and t. There are two options:
Keep the overlapping values separately in the merged data cube: An overlap resolver is not needed, but for each data cube you need to add a new dimension using add_dimension. The new dimensions must be equal, except that the labels for the new dimensions must differ by name. The merged data cube has the same dimensions and labels as the original data cubes, plus the dimension added with add_dimension, which has the two dimension labels after the merge.
Combine the overlapping values into a single value: An overlap resolver is required to resolve the overlap for all pixels. The merged data cube has the same dimensions and labels as the original data cubes, but all pixel values have been processed by the overlap resolver.
Merging a data cube with dimensions x, y, t with another cube with dimensions x, y will join on the x, y dimension, so the lower dimension cube is merged with each time step in the higher dimensional cube. This can for instance be used to apply a digital elevation model to a spatiotemporal data cube.
- Parameters:
other (
DataCube
) – The data cube to merge with.overlap_resolver (
Union
[str
,PGNode
,Callable
]) – A reduction operator that resolves the conflict if the data overlaps. The reducer must return a value of the same data type as the input values are. The reduction operator may be a single process such as multiply or consist of multiple sub-processes. null (the default) can be specified if no overlap resolver is required.context (
Optional
[dict
]) – Additional data to be passed to the process.
- Return type:
- Returns:
The merged data cube.
See also
openeo.org documentation on process “merge_cubes”.
- min_time()[source]¶
Finds the minimum value of a time series for all bands of the input dataset.
- Return type:
- Returns:
a DataCube instance
See also
openeo.org documentation on process “min”.
- multiply(other, reverse=False)[source]¶
- Return type:
See also
openeo.org documentation on process “multiply”.
- ndvi(nir=None, red=None, target_band=None)[source]¶
Normalized Difference Vegetation Index (NDVI)
- Parameters:
nir (
str
) – (optional) name of NIR bandred (
str
) – (optional) name of red bandtarget_band (
str
) – (optional) name of the newly created band
- Return type:
- Returns:
a DataCube instance
See also
openeo.org documentation on process “ndvi”.
- normalized_difference(other)[source]¶
- Return type:
See also
openeo.org documentation on process “normalized_difference”.
- polygonal_histogram_timeseries(polygon)[source]¶
Extract a histogram time series for the given (multi)polygon. Its points are expected to be in the EPSG:4326 coordinate reference system.
- Parameters:
polygon (
Union
[Polygon
,MultiPolygon
,str
]) – The (multi)polygon; or a file path or HTTP URL to a GeoJSON file or shape file- Return type:
Deprecated since version 0.10.0: Use
aggregate_spatial()
with reducer'histogram'
.
- polygonal_mean_timeseries(polygon)[source]¶
Extract a mean time series for the given (multi)polygon. Its points are expected to be in the EPSG:4326 coordinate reference system.
- Parameters:
polygon (
Union
[Polygon
,MultiPolygon
,str
]) – The (multi)polygon; or a file path or HTTP URL to a GeoJSON file or shape file- Return type:
Deprecated since version 0.10.0: Use
aggregate_spatial()
with reducer'mean'
.
- polygonal_median_timeseries(polygon)[source]¶
Extract a median time series for the given (multi)polygon. Its points are expected to be in the EPSG:4326 coordinate reference system.
- Parameters:
polygon (
Union
[Polygon
,MultiPolygon
,str
]) – The (multi)polygon; or a file path or HTTP URL to a GeoJSON file or shape file- Return type:
Deprecated since version 0.10.0: Use
aggregate_spatial()
with reducer'median'
.
- polygonal_standarddeviation_timeseries(polygon)[source]¶
Extract a time series of standard deviations for the given (multi)polygon. Its points are expected to be in the EPSG:4326 coordinate reference system.
- Parameters:
polygon (
Union
[Polygon
,MultiPolygon
,str
]) – The (multi)polygon; or a file path or HTTP URL to a GeoJSON file or shape file- Return type:
Deprecated since version 0.10.0: Use
aggregate_spatial()
with reducer'sd'
.
- power(p)[source]¶
See also
openeo.org documentation on process “power”.
- predict_curve(parameters, function, dimension, labels=None)[source]¶
Predict values using a model function and pre-computed parameters.
Warning
experimental process: not generally supported, API subject to change. https://github.com/Open-EO/openeo-processes/pull/240
- Parameters:
parameters (
list
)function (
Union
[str
,PGNode
,Callable
]) – “child callback” function, see Processes with child “callbacks”dimension (
str
)
See also
openeo.org documentation on process “predict_curve”.
- predict_random_forest(model, dimension='bands')[source]¶
Apply
reduce_dimension
process with apredict_random_forest
reducer.- Parameters:
model (
Union
[str
,BatchJob
,MlModel
]) –a reference to a trained model, one of
a
MlModel
instance (e.g. loaded fromConnection.load_ml_model()
)a
BatchJob
instance of a batch job that saved a single random forest modela job id (
str
) of a batch job that saved a single random forest modela STAC item URL (
str
) to load the random forest from. (The STAC Item must implement the ml-model extension.)
dimension (
str
) – dimension along which to apply thereduce_dimension
process.
Added in version 0.10.0.
See also
openeo.org documentation on process “predict_random_forest”.
- preview(center=None, zoom=None)[source]¶
Creates a service with the process graph and displays a map widget. Only supports XYZ.
- Parameters:
center (
Optional
[Iterable
]) – (optional) Map center. Default is (0,0).zoom (
Optional
[int
]) – (optional) Zoom level of the map. Default is 1.
- Returns:
ipyleaflet Map object and the displayed Service
Warning
experimental feature, subject to change.
Added in version 0.19.0.
- print_json(*, file=None, indent=2, separators=None, end='\\n')¶
Print interoperable JSON representation of the process graph.
See
DataCube.to_json()
to get the JSON representation as a string and Export a process graph for more usage information.Also see
json.dumps
docs for more information on the JSON formatting options.- Parameters:
file – file-like object (stream) to print to (current
sys.stdout
by default). Or a path (string or pathlib.Path) to a file to write to.indent (
Optional
[int
]) – JSON indentation level.separators (
Optional
[Tuple
[str
,str
]]) – (optional) tuple of item/key separators.end (
str
) – additional string to be printed at the end (newline by default).
Added in version 0.12.0.
Added in version 0.23.0: added the
end
argument.
- process(process_id, arguments=None, metadata=None, namespace=None, **kwargs)[source]¶
Generic helper to create a new DataCube by applying a process.
- Parameters:
process_id (
str
) – process id of the process.arguments (
Optional
[dict
]) – argument dictionary for the process.metadata (
Optional
[CollectionMetadata
]) – optional: metadata to override original cube metadata (e.g. when reducing dimensions)namespace (
Optional
[str
]) – optional: process namespace
- Return type:
- Returns:
new DataCube instance
- process_with_node(pg, metadata=None)[source]¶
Generic helper to create a new DataCube by applying a process (given as process graph node)
- Parameters:
pg (
PGNode
) – process graph node (containing process id and arguments)metadata (
Optional
[CollectionMetadata
]) – optional: metadata to override original cube metadata (e.g. when reducing dimensions)
- Return type:
- Returns:
new DataCube instance
- raster_to_vector()[source]¶
Converts this raster data cube into a
VectorCube
. The bounding polygon of homogenous areas of pixels is constructed.Warning
experimental process: not generally supported, API subject to change.
- Return type:
- Returns:
- reduce_bands(reducer)[source]¶
Shortcut for
reduce_dimension()
along the band dimension- Parameters:
reducer (
Union
[str
,PGNode
,Callable
,UDF
]) – “child callback” function, see Processes with child “callbacks”- Return type:
- reduce_bands_udf(code, runtime=None, version=None)[source]¶
Use reduce_dimension process with given UDF along band/spectral dimension. :rtype:
DataCube
Deprecated since version 0.13.0: Use
reduce_bands()
withUDF
as reducer.
- reduce_dimension(dimension, reducer, context=None, process_id='reduce_dimension', band_math_mode=False)[source]¶
Add a reduce process with given reducer callback along given dimension
- Parameters:
dimension (
str
) – the label of the dimension to reducereducer (
Union
[str
,Callable
,UDF
,PGNode
]) –the “child callback”: the name of a single openEO process, or a callback function as discussed in Processes with child “callbacks”, or a
UDF
instance.The callback should correspond to a process that receives an array of numerical values and returns a single numerical value. For example:
"mean"
(string)lambda data: data.min()
(function or lambda)
context (
Optional
[dict
]) – Additional data to be passed to the process.
- Return type:
See also
openeo.org documentation on process “reduce_dimension”.
- reduce_spatial(reducer, context=None)[source]¶
Add a reduce process with given reducer callback along the spatial dimensions
- Parameters:
reducer (
Union
[str
,Callable
,UDF
,PGNode
]) –the “child callback”: the name of a single openEO process, or a callback function as discussed in Processes with child “callbacks”, or a
UDF
instance.The callback should correspond to a process that receives an array of numerical values and returns a single numerical value. For example:
"mean"
(string)lambda data: data.min()
(function or lambda)
context (
Optional
[dict
]) – Additional data to be passed to the process.
- Return type:
See also
openeo.org documentation on process “reduce_spatial”.
- reduce_temporal(reducer)[source]¶
Shortcut for
reduce_dimension()
along the temporal dimension- Parameters:
reducer (
Union
[str
,PGNode
,Callable
,UDF
]) – “child callback” function, see Processes with child “callbacks”- Return type:
- reduce_temporal_simple(reducer)¶
- Return type:
Deprecated since version 0.13.0: Usage of this legacy method is deprecated. Use
reduce_temporal()
instead.
- reduce_temporal_udf(code, runtime='Python', version='latest')[source]¶
Apply reduce (reduce_dimension) process with given UDF along temporal dimension.
- Parameters:
code (
str
) – The UDF code, compatible with the given runtime and versionruntime – The UDF runtime
version – The UDF runtime version
Deprecated since version 0.13.0: Use
reduce_temporal()
withUDF
as reducer
- reduce_tiles_over_time(code, runtime='Python', version='latest')¶
Deprecated since version 0.1.1: Usage of this legacy method is deprecated. Use
reduce_temporal_udf()
instead.
- rename_dimension(source, target)[source]¶
Renames a dimension in the data cube while preserving all other properties.
- Parameters:
source (
str
) – The current name of the dimension. Fails with a DimensionNotAvailable error if the specified dimension does not exist.target (
str
) – A new Name for the dimension. Fails with a DimensionExists error if a dimension with the specified name exists.
- Returns:
A new datacube with the dimension renamed.
See also
openeo.org documentation on process “rename_dimension”.
- rename_labels(dimension, target, source=None)[source]¶
Renames the labels of the specified dimension in the data cube from source to target.
- Parameters:
dimension (
str
) – Dimension nametarget (
list
) – The new names for the labels.source (
list
) – The names of the labels as they are currently in the data cube.
- Return type:
- Returns:
An DataCube instance
See also
openeo.org documentation on process “rename_labels”.
- resample_cube_spatial(target, method='near')[source]¶
Resamples the spatial dimensions (x,y) from a source data cube to align with the corresponding dimensions of the given target data cube. Returns a new data cube with the resampled dimensions.
To resample a data cube to a specific resolution or projection regardless of an existing target data cube, refer to
resample_spatial()
.
- resample_cube_temporal(target, dimension=None, valid_within=None)[source]¶
Resamples one or more given temporal dimensions from a source data cube to align with the corresponding dimensions of the given target data cube using the nearest neighbor method. Returns a new data cube with the resampled dimensions.
By default, this process simply takes the nearest neighbor independent of the value (including values such as no-data /
null
). Depending on the data cubes this may lead to values being assigned to two target timestamps. To only consider valid values in a specific range around the target timestamps, use the parametervalid_within
.The rare case of ties is resolved by choosing the earlier timestamps.
- Parameters:
target (
DataCube
) – A data cube that describes the temporal target resolution.dimension (
Optional
[str
]) – The name of the temporal dimension to resample.valid_within (
Optional
[int
])
- Return type:
- Returns:
Added in version 0.10.0.
See also
openeo.org documentation on process “resample_cube_temporal”.
- resample_spatial(resolution, projection=None, method='near', align='upper-left')[source]¶
- Return type:
See also
openeo.org documentation on process “resample_spatial”.
- resolution_merge(high_resolution_bands, low_resolution_bands, method=None)[source]¶
Resolution merging algorithms try to improve the spatial resolution of lower resolution bands (e.g. Sentinel-2 20M) based on higher resolution bands. (e.g. Sentinel-2 10M).
External references:
Warning
experimental process: not generally supported, API subject to change.
- Parameters:
high_resolution_bands (
List
[str
]) – A list of band names to use as ‘high-resolution’ band. Either the unique band name (metadata field name in bands) or one of the common band names (metadata field common_name in bands). If unique band name and common name conflict, the unique band name has higher priority. The order of the specified array defines the order of the bands in the data cube. If multiple bands match a common name, all matched bands are included in the original order. These bands will remain unmodified.low_resolution_bands (
List
[str
]) – A list of band names for which the spatial resolution should be increased. Either the unique band name (metadata field name in bands) or one of the common band names (metadata field common_name in bands). If unique band name and common name conflict, the unique band name has higher priority. The order of the specified array defines the order of the bands in the data cube. If multiple bands match a common name, all matched bands are included in the original order. These bands will be modified by the process.method (
str
) – The method to use. The supported algorithms can vary between back-ends. Set to null (the default) to allow the back-end to choose, which will improve portability, but reduce reproducibility..
- Return type:
- Returns:
A datacube with the same bands and metadata as the input, but algorithmically increased spatial resolution for the selected bands.
See also
openeo.org documentation on process “resolution_merge”.
- result_node()¶
Get the current result node (
PGNode
) of the process graph. :rtype:PGNode
Added in version 0.10.1.
- sar_backscatter(coefficient='gamma0-terrain', elevation_model=None, mask=False, contributing_area=False, local_incidence_angle=False, ellipsoid_incidence_angle=False, noise_removal=True, options=None)[source]¶
Computes backscatter from SAR input.
Note that backscatter computation may require instrument specific metadata that is tightly coupled to the original SAR products. As a result, this process may only work in combination with loading data from specific collections, not with general data cubes.
- Parameters:
coefficient (
Optional
[str
]) –Select the radiometric correction coefficient. The following options are available:
”beta0”: radar brightness
”sigma0-ellipsoid”: ground area computed with ellipsoid earth model
”sigma0-terrain”: ground area computed with terrain earth model
”gamma0-ellipsoid”: ground area computed with ellipsoid earth model in sensor line of sight
”gamma0-terrain”: ground area computed with terrain earth model in sensor line of sight (default)
None: non-normalized backscatter
elevation_model (
Optional
[str
]) – The digital elevation model to use. Set to None (the default) to allow the back-end to choose, which will improve portability, but reduce reproducibility.mask (
bool
) – If set to true, a data mask is added to the bands with the name mask. It indicates which values are valid (1), invalid (0) or contain no-data (null).contributing_area (
bool
) – If set to true, a DEM-based local contributing area band named contributing_area is added. The values are given in square meters.local_incidence_angle (
bool
) – If set to true, a DEM-based local incidence angle band named local_incidence_angle is added. The values are given in degrees.ellipsoid_incidence_angle (
bool
) – If set to true, an ellipsoidal incidence angle band named ellipsoid_incidence_angle is added. The values are given in degrees.noise_removal (
bool
) – If set to false, no noise removal is applied. Defaults to true, which removes noise.options (
Optional
[dict
]) – dictionary with additional (backend-specific) options.
- Return type:
- Returns:
Added in version 0.4.9.
Changed in version 0.4.10: replace orthorectify and rtc arguments with coefficient.
See also
openeo.org documentation on process “sar_backscatter”.
- save_result(format='GTiff', options=None)[source]¶
- Return type:
See also
openeo.org documentation on process “save_result”.
- save_user_defined_process(user_defined_process_id, public=False, summary=None, description=None, returns=None, categories=None, examples=None, links=None)[source]¶
Saves this process graph in the backend as a user-defined process for the authenticated user.
- Parameters:
user_defined_process_id (
str
) – unique identifier for the processpublic (
bool
) – visible to other users?summary (
Optional
[str
]) – A short summary of what the process does.description (
Optional
[str
]) – Detailed description to explain the entity. CommonMark 0.29 syntax MAY be used for rich text representation.returns (
Optional
[dict
]) – Description and schema of the return value.categories (
Optional
[List
[str
]]) – A list of categories.examples (
Optional
[List
[dict
]]) – A list of examples.links (
Optional
[List
[dict
]]) – A list of links.
- Return type:
- Returns:
a RESTUserDefinedProcess instance
- send_job(out_format=None, *, title=None, description=None, plan=None, budget=None, job_options=None, validate=None, **format_options)¶
- Return type:
Deprecated since version 0.10.0: Usage of this legacy method is deprecated. Use
create_job()
instead.
- subtract(other, reverse=False)[source]¶
- Return type:
See also
openeo.org documentation on process “subtract”.
- to_json(*, indent=2, separators=None)¶
Get interoperable JSON representation of the process graph.
See
DataCube.print_json()
to directly print the JSON representation and Export a process graph for more usage information.Also see
json.dumps
docs for more information on the JSON formatting options.- Parameters:
indent (
Optional
[int
]) – JSON indentation level.separators (
Optional
[Tuple
[str
,str
]]) – (optional) tuple of item/key separators.
- Return type:
str
- Returns:
JSON string
- unflatten_dimension(dimension, target_dimensions, label_separator=None)[source]¶
Splits a single dimension into multiple dimensions by systematically extracting values and splitting the dimension labels by the given label_separator. This process is the opposite of the process
flatten_dimensions()
but executing both processes subsequently doesn’t necessarily create a data cube that is equal to the original data cube.- Parameters:
dimension (
str
) – The name of the dimension to split.target_dimensions (
List
[str
]) – The names of the target dimensions.label_separator (
Optional
[str
]) – The string that will be used as a separator to split the dimension labels.
- Returns:
A data cube with the new shape.
Warning
experimental process: not generally supported, API subject to change.
Added in version 0.10.0.
See also
openeo.org documentation on process “unflatten_dimension”.
- class openeo.rest._datacube.UDF(code, runtime=None, data=None, version=None, context=None, _source=None)[source]¶
Helper class to load UDF code (e.g. from file) and embed them as “callback” or child process in a process graph.
Usage example:
udf = UDF.from_file("my-udf-code.py") cube = cube.apply(process=udf)
Changed in version 0.13.0: Added auto-detection of
runtime
. Specifying thedata
argument is not necessary anymore, and actually deprecated. Addedfrom_file()
to simplify loading UDF code from a file. See openeo.UDF API and usage changes in version 0.13.0 for more background about the changes.- classmethod from_file(path, runtime=None, version=None, context=None)[source]¶
Load a UDF from a local file.
See also
from_url()
for loading from a URL.- Parameters:
path (
Union
[str
,Path
]) – path to the local file with UDF source coderuntime (
Optional
[str
]) – optional UDF runtime identifier, will be auto-detected from source code if omitted.version (
Optional
[str
]) – optional UDF runtime version stringcontext (
Optional
[dict
]) – optional additional UDF context data
- Return type:
- classmethod from_url(url, runtime=None, version=None, context=None)[source]¶
Load a UDF from a URL.
See also
from_file()
for loading from a local file.- Parameters:
url (
str
) – URL path to load the UDF source code fromruntime (
Optional
[str
]) – optional UDF runtime identifier, will be auto-detected from source code if omitted.version (
Optional
[str
]) – optional UDF runtime version stringcontext (
Optional
[dict
]) – optional additional UDF context data
- Return type:
openeo.rest.vectorcube¶
- class openeo.rest.vectorcube.VectorCube(graph, connection, metadata=None)[source]¶
A Vector Cube, or ‘Vector Collection’ is a data structure containing ‘Features’: https://www.w3.org/TR/sdw-bp/#dfn-feature
The features in this cube are restricted to have a geometry. Geometries can be points, lines, polygons etcetera. A geometry is specified in a ‘coordinate reference system’. https://www.w3.org/TR/sdw-bp/#dfn-coordinate-reference-system-(crs)
- apply_dimension(process, dimension, target_dimension=None, context=None)[source]¶
Applies a process to all values along a dimension of a data cube. For example, if the temporal dimension is specified the process will work on the values of a time series.
The process to apply is specified by providing a callback function in the process argument.
- Parameters:
process (
Union
[str
,Callable
,UDF
,PGNode
]) –the “child callback”: the name of a single process, or a callback function as discussed in Processes with child “callbacks”, or a
UDF
instance.The callback should correspond to a process that receives an array of numerical values and returns an array of numerical values. For example:
"sort"
(string)lambda data: data.concat([42, -3])
(function or lambda)
dimension (
str
) – The name of the source dimension to apply the process on. Fails with a DimensionNotAvailable error if the specified dimension does not exist.target_dimension (
Optional
[str
]) – The name of the target dimension or null (the default) to use the source dimension specified in the parameter dimension. By specifying a target dimension, the source dimension is removed. The target dimension with the specified name and the type other (see add_dimension) is created, if it doesn’t exist yet.context (
Optional
[dict
]) – Additional data to be passed to the process.
- Return type:
- Returns:
A datacube with the UDF applied to the given dimension.
- Raises:
DimensionNotAvailable
Added in version 0.22.0.
See also
openeo.org documentation on process “apply_dimension”.
- create_job(out_format=None, *, title=None, description=None, plan=None, budget=None, job_options=None, validate=None, **format_options)[source]¶
Sends a job to the backend and returns a ClientJob instance.
- Parameters:
out_format (
Optional
[str
]) – String Format of the job result.title (
Optional
[str
]) – job titledescription (
Optional
[str
]) – job descriptionplan (
Optional
[str
]) – The billing plan to process and charge the job withbudget (
Optional
[float
]) – Maximum budget to be spent on executing the job. Note that some backends do not honor this limit.job_options (
Optional
[dict
]) – A dictionary containing (custom) job optionsformat_options – String Parameters for the job result format
validate (
Optional
[bool
]) – Optional toggle to enable/prevent validation of the process graphs before execution (overruling the connection’sauto_validate
setting).
- Return type:
- Returns:
Created job.
- download(outputfile=None, format=None, options=None, *, validate=None)[source]¶
Execute synchronously and download the vector cube.
The result will be stored to the output path, when specified. If no output path (or
None
) is given, the raw download content will be returned asbytes
object.- Parameters:
outputfile (
Union
[str
,Path
,None
]) – (optional) output file to store the result toformat (
Optional
[str
]) – (optional) output format to use.options (
Optional
[dict
]) – (optional) additional output format options.validate (
Optional
[bool
]) – Optional toggle to enable/prevent validation of the process graphs before execution (overruling the connection’sauto_validate
setting).
- Return type:
Optional
[bytes
]
Changed in version 0.21.0: When not specified explicitly, output format is guessed from output file extension.
- execute_batch(outputfile=None, out_format=None, *, print=<built-in function print>, max_poll_interval=60, connection_retry_interval=30, job_options=None, validate=None, **format_options)[source]¶
Evaluate the process graph by creating a batch job, and retrieving the results when it is finished. This method is mostly recommended if the batch job is expected to run in a reasonable amount of time.
For very long running jobs, you probably do not want to keep the client running.
- Parameters:
job_options (
Optional
[dict
])outputfile (
Union
[str
,Path
,None
]) – The path of a file to which a result can be writtenout_format (
Optional
[str
]) – (optional) output format to use.format_options – (optional) additional output format options
validate (
Optional
[bool
]) – Optional toggle to enable/prevent validation of the process graphs before execution (overruling the connection’sauto_validate
setting).
- Return type:
Changed in version 0.21.0: When not specified explicitly, output format is guessed from output file extension.
- filter_bands(bands)[source]¶
- Return type:
Added in version 0.22.0.
See also
openeo.org documentation on process “filter_bands”.
- filter_bbox(*, west=None, south=None, east=None, north=None, extent=None, crs=None)[source]¶
- Return type:
Added in version 0.22.0.
See also
openeo.org documentation on process “filter_bbox”.
- filter_labels(condition, dimension, context=None)[source]¶
Filters the dimension labels in the data cube for the given dimension. Only the dimension labels that match the specified condition are preserved, all other labels with their corresponding data get removed.
- Parameters:
condition (
Union
[PGNode
,Callable
]) – the “child callback” which will be given a single label value (number or string) and returns a boolean expressing if the label should be preserved. Also see Processes with child “callbacks”.dimension (
str
) – The name of the dimension to filter on.
- Return type:
Added in version 0.22.0.
See also
openeo.org documentation on process “filter_labels”.
- filter_vector(geometries, relation='intersects')[source]¶
- Return type:
Added in version 0.22.0.
See also
openeo.org documentation on process “filter_vector”.
- fit_class_random_forest(target, max_variables=None, num_trees=100, seed=None)[source]¶
Executes the fit of a random forest classification based on the user input of target and predictors. The Random Forest classification model is based on the approach by Breiman (2001).
Warning
EXPERIMENTAL: not generally supported, API subject to change.
- Parameters:
target (
dict
) – The training sites for the classification model as a vector data cube. This is associated with the target variable for the Random Forest model. The geometry has to be associated with a value to predict (e.g. fractional forest canopy cover).max_variables (
Optional
[int
]) – Specifies how many split variables will be used at a node. Default value is null, which corresponds to the number of predictors divided by 3.num_trees (
int
) – The number of trees build within the Random Forest classification.seed (
Optional
[int
]) – A randomization seed to use for the random sampling in training.
- Return type:
Added in version 0.16.0: Originally added in version 0.10.0 as
DataCube
method, but moved toVectorCube
in version 0.16.0.See also
openeo.org documentation on process “fit_class_random_forest”.
- fit_regr_random_forest(target, max_variables=None, num_trees=100, seed=None)[source]¶
Executes the fit of a random forest regression based on training data. The Random Forest regression model is based on the approach by Breiman (2001).
Warning
EXPERIMENTAL: not generally supported, API subject to change.
- Parameters:
target (
dict
) – The training sites for the regression model as a vector data cube. This is associated with the target variable for the Random Forest model. The geometry has to associated with a value to predict (e.g. fractional forest canopy cover).max_variables (
Optional
[int
]) – Specifies how many split variables will be used at a node. Default value is null, which corresponds to the number of predictors divided by 3.num_trees (
int
) – The number of trees build within the Random Forest classification.seed (
Optional
[int
]) – A randomization seed to use for the random sampling in training.
- Return type:
Added in version 0.16.0: Originally added in version 0.10.0 as
DataCube
method, but moved toVectorCube
in version 0.16.0.See also
openeo.org documentation on process “fit_regr_random_forest”.
- flat_graph()¶
Get the process graph in internal flat dict representation. :rtype:
Dict
[str
,dict
]Warning
This method is mainly intended for internal use. It is not recommended for general use and is subject to change.
Instead, it is recommended to use
to_json()
orprint_json()
to obtain a standardized, interoperable JSON representation of the process graph. See Export a process graph for more information.
- classmethod load_geojson(connection, data, properties=None)[source]¶
Converts GeoJSON data as defined by RFC 7946 into a vector data cube.
- Parameters:
connection (
Connection
) – the connection to use to connect with the openEO back-end.data (
Union
[dict
,str
,Path
,BaseGeometry
,Parameter
]) –the geometry to load. One of:
GeoJSON-style data structure: e.g. a dictionary with
"type": "Polygon"
and"coordinates"
fieldsa path to a local GeoJSON file
a GeoJSON string
a shapely geometry object
properties (
Optional
[List
[str
]]) – A list of properties from the GeoJSON file to construct an additional dimension from.
- Return type:
- Returns:
new VectorCube instance
Warning
EXPERIMENTAL: this process is experimental with the potential for major things to change.
Added in version 0.22.0.
See also
openeo.org documentation on process “load_geojson”.
- classmethod load_url(connection, url, format, options=None)[source]¶
Loads a file from a URL
- Parameters:
connection (
Connection
) – the connection to use to connect with the openEO back-end.url (
str
) – The URL to read from. Authentication details such as API keys or tokens may need to be included in the URL.format (
str
) – The file format to use when loading the data.options (
Optional
[dict
]) – The file format parameters to use when reading the data. Must correspond to the parameters that the server reports as supported parameters for the chosenformat
- Return type:
- Returns:
new VectorCube instance
Warning
EXPERIMENTAL: this process is experimental with the potential for major things to change.
Added in version 0.22.0.
See also
openeo.org documentation on process “load_url”.
- print_json(*, file=None, indent=2, separators=None, end='\\n')¶
Print interoperable JSON representation of the process graph.
See
DataCube.to_json()
to get the JSON representation as a string and Export a process graph for more usage information.Also see
json.dumps
docs for more information on the JSON formatting options.- Parameters:
file – file-like object (stream) to print to (current
sys.stdout
by default). Or a path (string or pathlib.Path) to a file to write to.indent (
Optional
[int
]) – JSON indentation level.separators (
Optional
[Tuple
[str
,str
]]) – (optional) tuple of item/key separators.end (
str
) – additional string to be printed at the end (newline by default).
Added in version 0.12.0.
Added in version 0.23.0: added the
end
argument.
- process(process_id, arguments=None, metadata=None, namespace=None, **kwargs)[source]¶
Generic helper to create a new VectorCube by applying a process.
- Parameters:
process_id (
str
) – process id of the process.args – argument dictionary for the process.
- Return type:
- Returns:
new VectorCube instance
- result_node()¶
Get the current result node (
PGNode
) of the process graph. :rtype:PGNode
Added in version 0.10.1.
- run_udf(udf, runtime=None, version=None, context=None)[source]¶
Run a UDF on the vector cube.
It is recommended to provide the UDF just as
UDF
instance. (the other arguments could be used to override UDF parameters if necessary).- Parameters:
- Return type:
Warning
EXPERIMENTAL: not generally supported, API subject to change.
Added in version 0.10.0.
Changed in version 0.16.0: Added support to pass self-contained
UDF
instance.See also
openeo.org documentation on process “run_udf”.
- save_result(format='GeoJSON', options=None)[source]¶
See also
openeo.org documentation on process “save_result”.
- send_job(out_format=None, *, title=None, description=None, plan=None, budget=None, job_options=None, validate=None, **format_options)¶
- Return type:
Deprecated since version 0.10.0: Usage of this legacy method is deprecated. Use
create_job()
instead.
- to_json(*, indent=2, separators=None)¶
Get interoperable JSON representation of the process graph.
See
DataCube.print_json()
to directly print the JSON representation and Export a process graph for more usage information.Also see
json.dumps
docs for more information on the JSON formatting options.- Parameters:
indent (
Optional
[int
]) – JSON indentation level.separators (
Optional
[Tuple
[str
,str
]]) – (optional) tuple of item/key separators.
- Return type:
str
- Returns:
JSON string
- vector_to_raster(target)[source]¶
Converts this vector cube (
VectorCube
) into a raster data cube (DataCube
). The bounding polygon of homogenous areas of pixels is constructed.- Parameters:
target (
DataCube
) – a reference raster data cube to adopt the CRS/projection/resolution from.- Return type:
Warning
vector_to_raster
is an experimental, non-standard process. It is not widely supported, and its API is subject to change.Added in version 0.28.0.
openeo.rest.mlmodel¶
- class openeo.rest.mlmodel.MlModel(graph, connection)[source]¶
A machine learning model.
It is the result of a training procedure, e.g. output of a
fit_...
process, and can be used for prediction (classification or regression) with the correspondingpredict_...
process.Added in version 0.10.0.
- create_job(*, title=None, description=None, plan=None, budget=None, job_options=None)[source]¶
Sends a job to the backend and returns a ClientJob instance.
- Parameters:
title (
Optional
[str
]) – job titledescription (
Optional
[str
]) – job descriptionplan (
Optional
[str
]) – The billing plan to process and charge the job withbudget (
Optional
[float
]) – Maximum budget to be spent on executing the job. Note that some backends do not honor this limit.job_options (
Optional
[dict
]) – A dictionary containing (custom) job optionsformat_options – String Parameters for the job result format
- Return type:
- Returns:
Created job.
- execute_batch(outputfile, print=<built-in function print>, max_poll_interval=60, connection_retry_interval=30, job_options=None)[source]¶
Evaluate the process graph by creating a batch job, and retrieving the results when it is finished. This method is mostly recommended if the batch job is expected to run in a reasonable amount of time.
For very long running jobs, you probably do not want to keep the client running.
- Parameters:
job_options
outputfile (
Union
[str
,Path
]) – The path of a file to which a result can be writtenout_format – (optional) Format of the job result.
format_options – String Parameters for the job result format
- Return type:
- flat_graph()¶
Get the process graph in internal flat dict representation. :rtype:
Dict
[str
,dict
]Warning
This method is mainly intended for internal use. It is not recommended for general use and is subject to change.
Instead, it is recommended to use
to_json()
orprint_json()
to obtain a standardized, interoperable JSON representation of the process graph. See Export a process graph for more information.
- static load_ml_model(connection, id)[source]¶
Loads a machine learning model from a STAC Item.
- Parameters:
connection (
Connection
) – connection objectid (
Union
[str
,BatchJob
]) – STAC item reference, as URL, batch job (id) or user-uploaded file
- Return type:
- Returns:
Added in version 0.10.0.
See also
openeo.org documentation on process “load_ml_model”.
- print_json(*, file=None, indent=2, separators=None, end='\\n')¶
Print interoperable JSON representation of the process graph.
See
DataCube.to_json()
to get the JSON representation as a string and Export a process graph for more usage information.Also see
json.dumps
docs for more information on the JSON formatting options.- Parameters:
file – file-like object (stream) to print to (current
sys.stdout
by default). Or a path (string or pathlib.Path) to a file to write to.indent (
Optional
[int
]) – JSON indentation level.separators (
Optional
[Tuple
[str
,str
]]) – (optional) tuple of item/key separators.end (
str
) – additional string to be printed at the end (newline by default).
Added in version 0.12.0.
Added in version 0.23.0: added the
end
argument.
- result_node()¶
Get the current result node (
PGNode
) of the process graph. :rtype:PGNode
Added in version 0.10.1.
- save_ml_model(options=None)[source]¶
Saves a machine learning model as part of a batch job.
- Parameters:
options (
Optional
[dict
]) – Additional parameters to create the file(s).
- to_json(*, indent=2, separators=None)¶
Get interoperable JSON representation of the process graph.
See
DataCube.print_json()
to directly print the JSON representation and Export a process graph for more usage information.Also see
json.dumps
docs for more information on the JSON formatting options.- Parameters:
indent (
Optional
[int
]) – JSON indentation level.separators (
Optional
[Tuple
[str
,str
]]) – (optional) tuple of item/key separators.
- Return type:
str
- Returns:
JSON string
openeo.metadata¶
- class openeo.metadata.BandDimension(name, bands)[source]¶
-
- band_index(band)[source]¶
Resolve a given band (common) name/index to band index
- Parameters:
band (
Union
[int
,str
]) – band name, common name or index- Return int:
band index
- Return type:
int
- band_name(band, allow_common=True)[source]¶
Resolve (common) name or index to a valid (common) name
- Return type:
str
- class openeo.metadata.CollectionMetadata(metadata, dimensions=None)[source]¶
Wrapper for EO Data Collection metadata.
Simplifies getting values from deeply nested mappings, allows additional parsing and normalizing compatibility issues.
Metadata is expected to follow format defined by https://openeo.org/documentation/1.0/developers/api/reference.html#operation/describe-collection (with partial support for older versions)
openeo.api.process¶
- class openeo.api.process.Parameter(name, description=None, schema=None, default=<object object>, optional=None)[source]¶
A (process) parameter to build parameterized user-defined processes.
Parameter objects can be defined with at least a name and expected schema (e.g. is the parameter a placeholder for a string, a bounding box, a date, …) and can then be used with various functions and classes, like
DataCube
, to build parameterized user-defined processes.Apart from the generic
Parameter
constructor, this class also provides various helpers (class methods) to easily create parameters for common parameter types.- Parameters:
name (
str
) – parameter name, which will be used to assign concrete values to. It is recommended to stick to the convention of snake case naming (using lowercase with underscores).description (
Optional
[str
]) – human-readable description of the parameter.schema (
Union
[dict
,str
,None
]) – JSON schema describing the expected data type and structure of the parameter.default – default value for the parameter when it’s optional.
optional (
Optional
[bool
]) – toggle to indicate whether the parameter is optional or required.
- classmethod array(name, description=None, *, item_schema=None, **kwargs)[source]¶
Helper to easily create parameter with an ‘array’ schema.
- Parameters:
name (
str
) – parameter name, which will be used to assign concrete values to. It is recommended to stick to the convention of snake case naming (using lowercase with underscores).description (
Optional
[str
]) – human-readable description of the parameter.item_schema (
Union
[str
,dict
,None
]) – Schema of the array items given in JSON Schema style, e.g.{"type": "string"}
. Simple schemas can also be specified as single string: e.g."string"
will be expanded to{"type": "string"}
.
- Return type:
See the generic
Parameter
constructor for information on additional arguments (exceptschema
).Changed in version 0.23.0: Added
item_schema
argument.
- classmethod boolean(name, description=None, **kwargs)[source]¶
Helper to easily create a ‘boolean’ parameter.
- Parameters:
name (
str
) – parameter name, which will be used to assign concrete values to. It is recommended to stick to the convention of snake case naming (using lowercase with underscores).description (
Optional
[str
]) – human-readable description of the parameter.
- Return type:
See the generic
Parameter
constructor for information on additional arguments (exceptschema
).
- classmethod bounding_box(name, description="Spatial extent specified as a bounding box with 'west', 'south', 'east' and 'north' fields.", **kwargs)[source]¶
Helper to easily create a ‘bounding box’ parameter, which allows to specify a spatial extent with “west”, “south”, “east” and “north” bounds (and optionally a CRS identifier).
- Parameters:
name (
str
) – parameter name, which will be used to assign concrete values to. It is recommended to stick to the convention of snake case naming (using lowercase with underscores).description (
str
) – human-readable description of the parameter.
- Return type:
See the generic
Parameter
constructor for information on additional arguments (exceptschema
).Added in version 0.30.0.
- classmethod datacube(name='data', description='A data cube.', **kwargs)[source]¶
Helper to easily create a ‘datacube’ parameter.
- Parameters:
name (
str
) – parameter name, which will be used to assign concrete values to. It is recommended to stick to the convention of snake case naming (using lowercase with underscores).description (
str
) – human-readable description of the parameter.
- Return type:
See the generic
Parameter
constructor for information on additional arguments (exceptschema
).Added in version 0.22.0.
- classmethod date(name, description='A date.', **kwargs)[source]¶
Helper to easily create a ‘date’ parameter.
- Parameters:
name (
str
) – parameter name, which will be used to assign concrete values to. It is recommended to stick to the convention of snake case naming (using lowercase with underscores).description (
str
) – human-readable description of the parameter.
- Return type:
See the generic
Parameter
constructor for information on additional arguments (exceptschema
).Added in version 0.30.0.
- classmethod date_time(name, description='A date with time.', **kwargs)[source]¶
Helper to easily create a ‘date-time’ parameter.
- Parameters:
name (
str
) – parameter name, which will be used to assign concrete values to. It is recommended to stick to the convention of snake case naming (using lowercase with underscores).description (
str
) – human-readable description of the parameter.
- Return type:
See the generic
Parameter
constructor for information on additional arguments (exceptschema
).Added in version 0.30.0.
- classmethod geojson(name, description='Geometries specified as GeoJSON object.', **kwargs)[source]¶
Helper to easily create a ‘geojson’ parameter, which allows to specify geometries as an inline GeoJSON object.
- Parameters:
name (
str
) – parameter name, which will be used to assign concrete values to. It is recommended to stick to the convention of snake case naming (using lowercase with underscores).description (
str
) – human-readable description of the parameter.
- Return type:
See the generic
Parameter
constructor for information on additional arguments (exceptschema
).Added in version 0.30.0.
- classmethod integer(name, description=None, **kwargs)[source]¶
Helper to create an ‘integer’ parameter.
- Parameters:
name (
str
) – parameter name, which will be used to assign concrete values to. It is recommended to stick to the convention of snake case naming (using lowercase with underscores).description (
Optional
[str
]) – human-readable description of the parameter.
- Return type:
See the generic
Parameter
constructor for information on additional arguments (exceptschema
).
- classmethod number(name, description=None, **kwargs)[source]¶
Helper to easily create a ‘number’ parameter.
- Parameters:
name (
str
) – parameter name, which will be used to assign concrete values to. It is recommended to stick to the convention of snake case naming (using lowercase with underscores).description (
Optional
[str
]) – human-readable description of the parameter.
- Return type:
See the generic
Parameter
constructor for information on additional arguments (exceptschema
).
- classmethod object(name, description=None, *, subtype=None, **kwargs)[source]¶
Helper to create an ‘object’ type parameter
- Parameters:
name (
str
) – parameter name, which will be used to assign concrete values to. It is recommended to stick to the convention of snake case naming (using lowercase with underscores).description (
Optional
[str
]) – human-readable description of the parameter.subtype (
Optional
[str
]) – subtype of the ‘object’ schema
- Return type:
See the generic
Parameter
constructor for information on additional arguments (exceptschema
).Added in version 0.26.0.
- classmethod raster_cube(name='data', description='A data cube.', **kwargs)[source]¶
Helper to easily create a ‘raster-cube’ parameter.
- Parameters:
name (
str
) – parameter name, which will be used to assign concrete values to. It is recommended to stick to the convention of snake case naming (using lowercase with underscores).description (
str
) – human-readable description of the parameter.
- Return type:
See the generic
Parameter
constructor for information on additional arguments (exceptschema
).
- classmethod string(name, description=None, *, values=None, subtype=None, format=None, **kwargs)[source]¶
Helper to easily create a ‘string’ parameter.
- Parameters:
name (
str
) – parameter name, which will be used to assign concrete values to. It is recommended to stick to the convention of snake case naming (using lowercase with underscores).description (
Optional
[str
]) – human-readable description of the parameter.values (
Optional
[List
[str
]]) – Optional list of allowed string values to make this an “enum”.subtype (
Optional
[str
]) – Optional subtype of the ‘string’ schema.format (
Optional
[str
]) – Optional format of the ‘string’ schema.
- Return type:
See the generic
Parameter
constructor for information on additional arguments (exceptschema
).
- classmethod temporal_interval(name, description='Temporal extent specified as two-element array with start and end date/date-time.', **kwargs)[source]¶
Helper to easily create a ‘temporal-interval’ parameter, which allows to specify a temporal extent as a two-element array with start and end date/date-time.
- Parameters:
name (
str
) – parameter name, which will be used to assign concrete values to. It is recommended to stick to the convention of snake case naming (using lowercase with underscores).description (
str
) – human-readable description of the parameter.
- Return type:
See the generic
Parameter
constructor for information on additional arguments (exceptschema
).Added in version 0.30.0.
openeo.api.logs¶
- class openeo.api.logs.LogEntry(*args, **kwargs)[source]¶
Log message and info for jobs and services
- Fields:
id
: Unique ID for the log, string, REQUIREDcode
: Error code, string, optionallevel
: Severity level, string (error, warning, info or debug), REQUIREDmessage
: Error message, string, REQUIREDtime
: Date and time of the error event as RFC3339 date-time, string, available since API 1.1.0path
: A “stack trace” for the process, array of dictslinks
: Related links, array of dictsusage
: Usage metrics available as property ‘usage’, dict, available since API 1.1.0 May contain the following metrics: cpu, memory, duration, network, disk, storage and other custom ones Each of the metrics is also a dict with the following parts: value (numeric) and unit (string)data
: Arbitrary data the user wants to “log” for debugging purposes. Please note that this property may not exist as there’s a difference between None and non-existing. None for example refers to no-data in many cases while the absence of the property means that the user did not provide any data for debugging.
- openeo.api.logs.normalize_log_level(log_level, default=10)[source]¶
Helper function to convert a openEO API log level (e.g. string “error”) to the integer constants defined in Python’s standard library
logging
module (e.g.logging.ERROR
).- Parameters:
log_level (
Union
[int
,str
,None
]) – log level to normalize: a log level string in the style of the openEO API (“error”, “warning”, “info”, or “debug”), an integer value (e.g. alogging
constant), orNone
.default (
int
) – fallback log level to return on unknown log level strings orNone
input.
- Raises:
TypeError – when log_level is any other type than str, an int or None.
- Return type:
int
- Returns:
One of the following log level constants from the standard module
logging
:logging.ERROR
,logging.WARNING
,logging.INFO
, orlogging.DEBUG
.
openeo.rest.connection¶
This module provides a Connection object to manage and persist settings when interacting with the OpenEO API.
- class openeo.rest.connection.Connection(url, *, auth=None, session=None, default_timeout=None, auth_config=None, refresh_token_store=None, slow_response_threshold=None, oidc_auth_renewer=None, auto_validate=True)[source]¶
Connection to an openEO backend.
- as_curl(data, path='/result', method='POST', obfuscate_auth=False)[source]¶
Build curl command to evaluate given process graph or data cube (including authorization and content-type headers).
>>> print(connection.as_curl(cube)) curl -i -X POST -H 'Content-Type: application/json' -H 'Authorization: Bearer ...' \ --data '{"process":{"process_graph":{...}}' \ https://openeo.example/openeo/1.1/result
- Parameters:
data (
Union
[dict
,DataCube
,FlatGraphableMixin
]) – something that is convertable to an openEO process graph: a dictionary, aDataCube
object, aProcessBuilder
, …path – endpoint to send request to: typically
"/result"
(default) for synchronous requests or"/jobs"
for batch jobsmethod – HTTP method to use (typically
"POST"
)obfuscate_auth (
bool
) – don’t show actual bearer token
- Return type:
str
- Returns:
curl command as a string
- assert_user_defined_process_support()[source]¶
Capabilities document based verification that back-end supports user-defined processes.
Added in version 0.23.0.
- authenticate_basic(username=None, password=None)[source]¶
Authenticate a user to the backend using basic username and password.
- Parameters:
username (
Optional
[str
]) – User namepassword (
Optional
[str
]) – User passphrase
- Return type:
- authenticate_oidc(provider_id=None, client_id=None, client_secret=None, *, store_refresh_token=True, use_pkce=None, display=<built-in function print>, max_poll_time=300)[source]¶
Generic method to do OpenID Connect authentication.
In the context of interactive usage, this method first tries to use refresh tokens and falls back on device code flow.
For non-interactive, machine-to-machine contexts, it is also possible to trigger the usage of the “client_credentials” flow through environment variables. Assuming you have set up a OIDC client (with a secret): set
OPENEO_AUTH_METHOD
toclient_credentials
, setOPENEO_AUTH_CLIENT_ID
to the client id, and setOPENEO_AUTH_CLIENT_SECRET
to the client secret.See OIDC Authentication: Dynamic Method Selection for more details.
- Parameters:
provider_id (
Optional
[str
]) – provider id to useclient_id (
Optional
[str
]) – client id to useclient_secret (
Optional
[str
]) – client secret to usemax_poll_time (
float
) – maximum time in seconds to keep polling for successful authentication.
Added in version 0.6.0.
Changed in version 0.17.0: Add
max_poll_time
argumentChanged in version 0.18.0: Add support for client credentials flow.
- authenticate_oidc_access_token(access_token, provider_id=None)[source]¶
Set up authorization headers directly with an OIDC access token.
Connection
provides multiple methods to handle various OIDC authentication flows end-to-end. If you already obtained a valid OIDC access token in another “out-of-band” way, you can use this method to set up the authorization headers appropriately.- Parameters:
access_token (
str
) – OIDC access tokenprovider_id (
Optional
[str
]) – id of the OIDC provider as listed by the openEO backend (/credentials/oidc
). If not specified, the first (default) OIDC provider will be used.skip_verification – Skip clients-side verification of the provider_id against the backend’s list of providers to avoid and related OIDC configuration
- Return type:
None
Added in version 0.31.0.
- authenticate_oidc_authorization_code(client_id=None, client_secret=None, provider_id=None, timeout=None, server_address=None, webbrowser_open=None, store_refresh_token=False)[source]¶
OpenID Connect Authorization Code Flow (with PKCE). :rtype:
Connection
Deprecated since version 0.19.0: Usage of the Authorization Code flow is deprecated (because of its complexity) and will be removed. It is recommended to use the Device Code flow with
authenticate_oidc_device()
or Client Credentials flow withauthenticate_oidc_client_credentials()
.
- authenticate_oidc_client_credentials(client_id=None, client_secret=None, provider_id=None)[source]¶
Authenticate with OIDC Client Credentials flow
Client id, secret and provider id can be specified directly through the available arguments. It is also possible to leave these arguments empty and specify them through environment variables
OPENEO_AUTH_CLIENT_ID
,OPENEO_AUTH_CLIENT_SECRET
andOPENEO_AUTH_PROVIDER_ID
respectively as discussed in OIDC Client Credentials Using Environment Variables.- Parameters:
client_id (
Optional
[str
]) – client id to useclient_secret (
Optional
[str
]) – client secret to useprovider_id (
Optional
[str
]) – provider id to use Fallback value can be set through environment variableOPENEO_AUTH_PROVIDER_ID
.
- Return type:
Changed in version 0.18.0: Allow specifying client id, secret and provider id through environment variables.
- authenticate_oidc_device(client_id=None, client_secret=None, provider_id=None, *, store_refresh_token=False, use_pkce=None, max_poll_time=300, **kwargs)[source]¶
Authenticate with the OIDC Device Code flow
- Parameters:
client_id (
Optional
[str
]) – client id to use instead of the default oneclient_secret (
Optional
[str
]) – client secret to use instead of the default oneprovider_id (
Optional
[str
]) – provider id to use. Fallback value can be set through environment variableOPENEO_AUTH_PROVIDER_ID
.store_refresh_token (
bool
) – whether to store the received refresh token automaticallyuse_pkce (
Optional
[bool
]) – Use PKCE instead of client secret. If not set explicitly to True (use PKCE) or False (use client secret), it will be attempted to detect the best mode automatically. Note that PKCE for device code is not widely supported among OIDC providers.max_poll_time (
float
) – maximum time in seconds to keep polling for successful authentication.
- Return type:
Changed in version 0.5.1: Add
use_pkce
argumentChanged in version 0.17.0: Add
max_poll_time
argumentChanged in version 0.19.0: Support fallback provider id through environment variable
OPENEO_AUTH_PROVIDER_ID
.
- authenticate_oidc_refresh_token(client_id=None, refresh_token=None, client_secret=None, provider_id=None, *, store_refresh_token=False)[source]¶
Authenticate with OIDC Refresh Token flow
- Parameters:
client_id (
Optional
[str
]) – client id to userefresh_token (
Optional
[str
]) – refresh token to useclient_secret (
Optional
[str
]) – client secret to useprovider_id (
Optional
[str
]) – provider id to use. Fallback value can be set through environment variableOPENEO_AUTH_PROVIDER_ID
.store_refresh_token (
bool
) – whether to store the received refresh token automatically
- Return type:
Changed in version 0.19.0: Support fallback provider id through environment variable
OPENEO_AUTH_PROVIDER_ID
.
- authenticate_oidc_resource_owner_password_credentials(username, password, client_id=None, client_secret=None, provider_id=None, store_refresh_token=False)[source]¶
OpenId Connect Resource Owner Password Credentials
- Return type:
- collection_items(name, spatial_extent=None, temporal_extent=None, limit=None)[source]¶
Loads items for a specific image collection. May not be available for all collections.
This is an experimental API and is subject to change.
- Parameters:
name – String Id of the collection
spatial_extent (
Optional
[List
[float
]]) – Limits the items to the given bounding box in WGS84: 1. Lower left corner, coordinate axis 1 2. Lower left corner, coordinate axis 2 3. Upper right corner, coordinate axis 1 4. Upper right corner, coordinate axis 2temporal_extent (
Optional
[List
[Union
[str
,datetime
]]]) – Limits the items to the specified temporal interval.limit (
Optional
[int
]) – The amount of items per request/page. If None, the back-end decides. The interval has to be specified as an array with exactly two elements (start, end). Also supports open intervals by setting one of the boundaries to None, but never both.
- Return type:
Iterator
[dict
]- Returns:
data_list: List A list of items
- create_job(process_graph, *, title=None, description=None, plan=None, budget=None, additional=None, validate=None)[source]¶
Create a new job from given process graph on the back-end.
- Parameters:
process_graph (
Union
[dict
,str
,Path
]) – (flat) dict representing a process graph, or process graph as raw JSON string, or as local file path or URLtitle (
Optional
[str
]) – job titledescription (
Optional
[str
]) – job descriptionplan (
Optional
[str
]) – The billing plan to process and charge the job withbudget (
Optional
[float
]) – Maximum budget to be spent on executing the job. Note that some backends do not honor this limit.additional (
Optional
[dict
]) – additional job options to pass to the backendvalidate (
Optional
[bool
]) – Optional toggle to enable/prevent validation of the process graphs before execution (overruling the connection’sauto_validate
setting).
- Return type:
- Returns:
Created job
- datacube_from_flat_graph(flat_graph, parameters=None)[source]¶
Construct a
DataCube
from a flat dictionary representation of a process graph.- Parameters:
flat_graph (
dict
) – flat dictionary representation of a process graph or a process dictionary with such a flat process graph under a “process_graph” field (and optionally parameter metadata under a “parameters” field).parameters (
Optional
[dict
]) – Optional dictionary mapping parameter names to parameter values to use for parameters occurring in the process graph (e.g. as used in user-defined processes)
- Return type:
- Returns:
A
DataCube
corresponding with the operations encoded in the process graph
- datacube_from_json(src, parameters=None)[source]¶
Construct a
DataCube
from JSON resource containing (flat) process graph representation.- Parameters:
src (
Union
[str
,Path
]) – raw JSON string, URL to JSON resource or path to local JSON fileparameters (
Optional
[dict
]) – Optional dictionary mapping parameter names to parameter values to use for parameters occurring in the process graph (e.g. as used in user-defined processes)
- Return type:
- Returns:
A
DataCube
corresponding with the operations encoded in the process graph
- datacube_from_process(process_id, namespace=None, **kwargs)[source]¶
Load a data cube from a (custom) process.
- Parameters:
process_id (
str
) – The process id.namespace (
Optional
[str
]) – optional: process namespacekwargs – The arguments of the custom process
- Return type:
- Returns:
A
DataCube
, without valid metadata, as the client is not aware of this custom process.
- describe_collection(collection_id)[source]¶
Get full collection metadata for given collection id.
See also
list_collection_ids()
to list all collection ids provided by the back-end.- Parameters:
collection_id (
str
) – collection id- Return type:
dict
- Returns:
collection metadata.
- describe_process(id, namespace=None)[source]¶
Returns a single process from the back end.
- Parameters:
id (
str
) – The id of the process.namespace (
Optional
[str
]) – The namespace of the process.
- Return type:
dict
- Returns:
The process definition.
- download(graph, outputfile=None, *, timeout=None, validate=None, chunk_size=10000000)[source]¶
Downloads the result of a process graph synchronously, and save the result to the given file or return bytes object if no outputfile is specified. This method is useful to export binary content such as images. For json content, the execute method is recommended.
- Parameters:
graph (
Union
[dict
,FlatGraphableMixin
,str
,Path
]) – (flat) dict representing a process graph, or process graph as raw JSON string, or as local file path or URLoutputfile (
Union
[Path
,str
,None
]) – output filetimeout (
Optional
[int
]) – timeout to wait for responsevalidate (
Optional
[bool
]) – Optional toggle to enable/prevent validation of the process graphs before execution (overruling the connection’sauto_validate
setting).chunk_size (
int
) – chunk size for streaming response.
- Return type:
Optional
[bytes
]
- execute(process_graph, *, timeout=None, validate=None, auto_decode=True)[source]¶
Execute a process graph synchronously and return the result. If the result is a JSON object, it will be parsed.
- Parameters:
process_graph (
Union
[dict
,str
,Path
]) – (flat) dict representing a process graph, or process graph as raw JSON string, or as local file path or URLvalidate (
Optional
[bool
]) – Optional toggle to enable/prevent validation of the process graphs before execution (overruling the connection’sauto_validate
setting).auto_decode (
bool
) – Boolean flag to enable/disable automatic JSON decoding of the response. Defaults to True.
- Return type:
Union
[dict
,Response
]- Returns:
parsed JSON response as a dict if auto_decode is True, otherwise response object
- get_file(path, metadata=None)[source]¶
Gets a handle to a user-uploaded file in the user workspace on the back-end.
- Parameters:
path (
Union
[str
,PurePosixPath
]) – The path on the user workspace.- Return type:
- imagecollection(collection_id, spatial_extent=None, temporal_extent=None, bands=None, properties=None, max_cloud_cover=None, fetch_metadata=True)¶
- Return type:
Deprecated since version 0.4.10: Usage of this legacy method is deprecated. Use
load_collection()
instead.
- job(job_id)[source]¶
Get the job based on the id. The job with the given id should already exist.
Use
openeo.rest.connection.Connection.create_job()
to create new jobs- Parameters:
job_id (
str
) – the job id of an existing job- Return type:
- Returns:
A job object.
- job_logs(job_id, offset)[source]¶
Get batch job logs. :rtype:
list
Deprecated since version 0.4.10: Use
openeo.rest.job.BatchJob.logs()
instead.
- job_results(job_id)[source]¶
Get batch job results metadata. :rtype:
dict
Deprecated since version 0.4.10: Use
openeo.rest.job.BatchJob.get_results()
instead.
- list_collection_ids()[source]¶
List all collection ids provided by the back-end.
See also
describe_collection()
to get the metadata of a particular collection.- Return type:
List
[str
]- Returns:
list of collection ids
- list_collections()[source]¶
List basic metadata of all collections provided by the back-end.
Caution
Only the basic collection metadata will be returned. To obtain full metadata of a particular collection, it is recommended to use
describe_collection()
instead.- Return type:
List
[dict
]- Returns:
list of dictionaries with basic collection metadata.
- list_file_types()¶
- Return type:
dict
Deprecated since version 0.4.6: Usage of this legacy method is deprecated. Use
list_output_formats()
instead.
- list_files()[source]¶
Lists all user-uploaded files in the user workspace on the back-end.
- Return type:
List
[UserFile
]- Returns:
List of the user-uploaded files.
- list_jobs()[source]¶
Lists all jobs of the authenticated user.
- Return type:
List
[dict
]- Returns:
job_list: Dict of all jobs of the user.
- list_processes(namespace=None)[source]¶
Loads all available processes of the back end.
- Parameters:
namespace (
Optional
[str
]) – The namespace for which to list processes.- Return type:
List
[dict
]- Returns:
processes_dict: Dict All available processes of the back end.
- list_service_types()[source]¶
Loads all available service types.
- Return type:
dict
- Returns:
data_dict: Dict All available service types
- list_services()[source]¶
Loads all available services of the authenticated user.
- Return type:
dict
- Returns:
data_dict: Dict All available services
- list_udf_runtimes()[source]¶
List information about the available UDF runtimes.
- Return type:
dict
- Returns:
A dictionary with metadata about each available UDF runtime.
- list_user_defined_processes()[source]¶
Lists all user-defined processes of the authenticated user.
- Return type:
List
[dict
]
- load_collection(collection_id, spatial_extent=None, temporal_extent=None, bands=None, properties=None, max_cloud_cover=None, fetch_metadata=True)[source]¶
Load a DataCube by collection id.
- Parameters:
collection_id (
Union
[str
,Parameter
]) – image collection identifierspatial_extent (
Union
[Dict
[str
,float
],Parameter
,None
]) – limit data to specified bounding box or polygonstemporal_extent (
Union
[Sequence
[Union
[str
,date
,Parameter
,PGNode
,ProcessBuilderBase
,None
]],Parameter
,str
,None
]) – limit data to specified temporal interval. Typically, just a two-item list or tuple containing start and end date. See Filter on temporal extent for more details on temporal extent handling and shorthand notation.bands (
Union
[None
,List
[str
],Parameter
]) – only add the specified bands.properties (
Union
[None
,Dict
[str
,Union
[str
,PGNode
,Callable
]],List
[CollectionProperty
],CollectionProperty
]) – limit data by collection metadata property predicates. Seecollection_property()
for easy construction of such predicates.max_cloud_cover (
Optional
[float
]) – shortcut to set maximum cloud cover (“eo:cloud_cover” collection property)
- Return type:
- Returns:
a datacube containing the requested data
Added in version 0.13.0: added the
max_cloud_cover
argument.Changed in version 0.23.0: Argument
temporal_extent
: add support for year/month shorthand notation as discussed at Year/month shorthand notation.Changed in version 0.26.0: Add
collection_property()
support toproperties
argument.See also
openeo.org documentation on process “load_collection”.
- load_disk_collection(format, glob_pattern, options=None)[source]¶
Loads image data from disk as a
DataCube
.This is backed by a non-standard process (‘load_disk_data’). This will eventually be replaced by standard options such as
openeo.rest.connection.Connection.load_stac()
or https://processes.openeo.org/#load_uploaded_files- Parameters:
format (
str
) – the file format, e.g. ‘GTiff’glob_pattern (
str
) – a glob pattern that matches the files to load from diskoptions (
Optional
[dict
]) – options specific to the file format
- Return type:
Deprecated since version 0.25.0: Depends on non-standard process, replace with
openeo.rest.connection.Connection.load_stac()
where possible.
- load_geojson(data, properties=None)[source]¶
Converts GeoJSON data as defined by RFC 7946 into a vector data cube.
- Parameters:
data (
Union
[dict
,str
,Path
,BaseGeometry
,Parameter
]) –the geometry to load. One of:
GeoJSON-style data structure: e.g. a dictionary with
"type": "Polygon"
and"coordinates"
fieldsa path to a local GeoJSON file
a GeoJSON string
a shapely geometry object
properties (
Optional
[List
[str
]]) – A list of properties from the GeoJSON file to construct an additional dimension from.
- Returns:
new VectorCube instance
Warning
EXPERIMENTAL: this process is experimental with the potential for major things to change.
Added in version 0.22.0.
See also
openeo.org documentation on process “load_geojson”.
- load_ml_model(id)[source]¶
Loads a machine learning model from a STAC Item.
- Parameters:
id (
Union
[str
,BatchJob
]) – STAC item reference, as URL, batch job (id) or user-uploaded file- Return type:
- Returns:
Added in version 0.10.0.
- load_result(id, spatial_extent=None, temporal_extent=None, bands=None)[source]¶
Loads batch job results by job id from the server-side user workspace. The job must have been stored by the authenticated user on the back-end currently connected to.
- Parameters:
id (
str
) – The id of a batch job with results.spatial_extent (
Optional
[Dict
[str
,float
]]) – limit data to specified bounding box or polygonstemporal_extent (
Union
[Sequence
[Union
[str
,date
,Parameter
,PGNode
,ProcessBuilderBase
,None
]],Parameter
,str
,None
]) – limit data to specified temporal interval. Typically, just a two-item list or tuple containing start and end date. See Filter on temporal extent for more details on temporal extent handling and shorthand notation.bands (
Optional
[List
[str
]]) – only add the specified bands
- Return type:
- Returns:
a
DataCube
Changed in version 0.23.0: Argument
temporal_extent
: add support for year/month shorthand notation as discussed at Year/month shorthand notation.See also
openeo.org documentation on process “load_result”.
- load_stac(url, spatial_extent=None, temporal_extent=None, bands=None, properties=None)[source]¶
Loads data from a static STAC catalog or a STAC API Collection and returns the data as a processable
DataCube
. A batch job result can be loaded by providing a reference to it.If supported by the underlying metadata and file format, the data that is added to the data cube can be restricted with the parameters
spatial_extent
,temporal_extent
andbands
. If no data is available for the given extents, aNoDataAvailable
error is thrown.Remarks:
The bands (and all dimensions that specify nominal dimension labels) are expected to be ordered as specified in the metadata if the
bands
parameter is set tonull
.If no additional parameter is specified this would imply that the whole data set is expected to be loaded. Due to the large size of many data sets, this is not recommended and may be optimized by back-ends to only load the data that is actually required after evaluating subsequent processes such as filters. This means that the values should be processed only after the data has been limited to the required extent and as a consequence also to a manageable size.
- Parameters:
url (
str
) –The URL to a static STAC catalog (STAC Item, STAC Collection, or STAC Catalog) or a specific STAC API Collection that allows to filter items and to download assets. This includes batch job results, which itself are compliant to STAC. For external URLs, authentication details such as API keys or tokens may need to be included in the URL.
Batch job results can be specified in two ways:
For Batch job results at the same back-end, a URL pointing to the corresponding batch job results endpoint should be provided. The URL usually ends with
/jobs/{id}/results
and{id}
is the corresponding batch job ID.For external results, a signed URL must be provided. Not all back-ends support signed URLs, which are provided as a link with the link relation canonical in the batch job result metadata.
spatial_extent (
Union
[Dict
[str
,float
],Parameter
,None
]) –Limits the data to load to the specified bounding box or polygons.
For raster data, the process loads the pixel into the data cube if the point at the pixel center intersects with the bounding box or any of the polygons (as defined in the Simple Features standard by the OGC).
For vector data, the process loads the geometry into the data cube if the geometry is fully within the bounding box or any of the polygons (as defined in the Simple Features standard by the OGC). Empty geometries may only be in the data cube if no spatial extent has been provided.
The GeoJSON can be one of the following feature types:
A
Polygon
orMultiPolygon
geometry,a
Feature
with aPolygon
orMultiPolygon
geometry, ora
FeatureCollection
containing at least oneFeature
withPolygon
orMultiPolygon
geometries.
Set this parameter to
None
to set no limit for the spatial extent. Be careful with this when loading large datasets. It is recommended to use this parameter instead of usingfilter_bbox()
orfilter_spatial()
directly after loading unbounded data.temporal_extent (
Union
[Sequence
[Union
[str
,date
,Parameter
,PGNode
,ProcessBuilderBase
,None
]],Parameter
,str
,None
]) –Limits the data to load to the specified left-closed temporal interval. Applies to all temporal dimensions. The interval has to be specified as an array with exactly two elements:
The first element is the start of the temporal interval. The specified instance in time is included in the interval.
The second element is the end of the temporal interval. The specified instance in time is excluded from the interval.
The second element must always be greater/later than the first element. Otherwise, a TemporalExtentEmpty exception is thrown.
Also supports open intervals by setting one of the boundaries to
None
, but never both.Set this parameter to
None
to set no limit for the temporal extent. Be careful with this when loading large datasets. It is recommended to use this parameter instead of usingfilter_temporal()
directly after loading unbounded data.bands (
Optional
[List
[str
]]) –Only adds the specified bands into the data cube so that bands that don’t match the list of band names are not available. Applies to all dimensions of type bands.
Either the unique band name (metadata field
name
in bands) or one of the common band names (metadata fieldcommon_name
in bands) can be specified. If the unique band name and the common name conflict, the unique band name has a higher priority.The order of the specified array defines the order of the bands in the data cube. If multiple bands match a common name, all matched bands are included in the original order.
It is recommended to use this parameter instead of using
filter_bands()
directly after loading unbounded data.properties (
Optional
[Dict
[str
,Union
[str
,PGNode
,Callable
]]]) –Limits the data by metadata properties to include only data in the data cube which all given conditions return
True
for (AND operation).Specify key-value-pairs with the key being the name of the metadata property, which can be retrieved with the openEO Data Discovery for Collections. The value must be a condition (user-defined process) to be evaluated against a STAC API. This parameter is not supported for static STAC.
- Return type:
Added in version 0.17.0.
Changed in version 0.23.0: Argument
temporal_extent
: add support for year/month shorthand notation as discussed at Year/month shorthand notation.See also
openeo.org documentation on process “load_stac”.
- load_stac_from_job(job, spatial_extent=None, temporal_extent=None, bands=None, properties=None)[source]¶
Wrapper for
load_stac()
that loads the result of a previous job using the STAC collection of its results.- Parameters:
job (
Union
[BatchJob
,str
]) – aBatchJob
or job id pointing to a finished job. Note that theBatchJob
approach allows to point to a batch job on a different back-end.spatial_extent (
Union
[Dict
[str
,float
],Parameter
,None
]) – limit data to specified bounding box or polygonstemporal_extent (
Union
[Sequence
[Union
[str
,date
,Parameter
,PGNode
,ProcessBuilderBase
,None
]],Parameter
,str
,None
]) – limit data to specified temporal interval.bands (
Optional
[List
[str
]]) – limit data to the specified bands
- Return type:
Added in version 0.30.0.
- load_url(url, format, options=None)[source]¶
Loads a file from a URL
- Parameters:
url (
str
) – The URL to read from. Authentication details such as API keys or tokens may need to be included in the URL.format (
str
) – The file format to use when loading the data.options (
Optional
[dict
]) – The file format parameters to use when reading the data. Must correspond to the parameters that the server reports as supported parameters for the chosenformat
- Returns:
new VectorCube instance
Warning
EXPERIMENTAL: this process is experimental with the potential for major things to change.
Added in version 0.22.0.
See also
openeo.org documentation on process “load_url”.
- remove_service(service_id)[source]¶
Stop and remove a secondary web service.
- Parameters:
service_id (
str
) – service identifier- Returns:
Deprecated since version 0.8.0: Use
openeo.rest.service.Service.delete_service()
instead.
- request(method, path, headers=None, auth=None, check_error=True, expected_status=None, **kwargs)[source]¶
Generic request send
- save_user_defined_process(user_defined_process_id, process_graph, parameters=None, public=False, summary=None, description=None, returns=None, categories=None, examples=None, links=None)[source]¶
Store a process graph and its metadata on the backend as a user-defined process for the authenticated user.
- Parameters:
user_defined_process_id (
str
) – unique identifier for the user-defined processprocess_graph (
Union
[dict
,ProcessBuilderBase
]) – a process graphparameters (
List
[Union
[dict
,Parameter
]]) – a list of parameterspublic (
bool
) – visible to other users?summary (
Optional
[str
]) – A short summary of what the process does.description (
Optional
[str
]) – Detailed description to explain the entity. CommonMark 0.29 syntax MAY be used for rich text representation.returns (
Optional
[dict
]) – Description and schema of the return value.categories (
Optional
[List
[str
]]) – A list of categories.examples (
Optional
[List
[dict
]]) – A list of examples.links (
Optional
[List
[dict
]]) – A list of links.
- Return type:
- Returns:
a RESTUserDefinedProcess instance
- service(service_id)[source]¶
Get the secondary web service based on the id. The service with the given id should already exist.
Use
openeo.rest.connection.Connection.create_service()
to create new services- Parameters:
job_id – the service id of an existing secondary web service
- Return type:
Service
- Returns:
A service object.
- upload_file(source, target=None)[source]¶
Uploads a file to the given target location in the user workspace on the back-end.
If a file at the target path exists in the user workspace it will be replaced.
- Parameters:
source (
Union
[Path
,str
]) – A path to a file on the local file system to upload.target (
Union
[str
,PurePosixPath
,None
]) – The desired path (which can contain a folder structure if desired) on the user workspace. If not set: defaults to the original filename (without any folder structure) of the local file .
- Return type:
- user_defined_process(user_defined_process_id)[source]¶
Get the user-defined process based on its id. The process with the given id should already exist.
- Parameters:
user_defined_process_id (
str
) – the id of the user-defined process- Return type:
- Returns:
a RESTUserDefinedProcess instance
- user_jobs()[source]¶
- Return type:
List
[dict
]
Deprecated since version 0.4.10: use
list_jobs()
instead
- validate_process_graph(process_graph)[source]¶
Validate a process graph without executing it.
- Parameters:
process_graph (
Union
[dict
,FlatGraphableMixin
,Any
]) – (flat) dict representing process graph- Return type:
List
[dict
]- Returns:
list of errors (dictionaries with “code” and “message” fields)
- vectorcube_from_paths(paths, format, options={})[source]¶
Loads one or more files referenced by url or path that is accessible by the backend.
- Parameters:
paths (
List
[str
]) – The files to read.format (
str
) – The file format to read from. It must be one of the values that the server reports as supported input file formats.options (
dict
) – The file format parameters to be used to read the files. Must correspond to the parameters that the server reports as supported parameters for the chosen format.
- Return type:
- Returns:
A
VectorCube
.
Added in version 0.14.0.
- classmethod version_discovery(url, session=None, timeout=None)[source]¶
Do automatic openEO API version discovery from given url, using a “well-known URI” strategy.
- Parameters:
url (
str
) – initial backend url (not including “/.well-known/openeo”)- Return type:
str
- Returns:
root url of highest supported backend version
openeo.rest.job¶
- class openeo.rest.job.BatchJob(job_id, connection)[source]¶
Handle for an openEO batch job, allowing it to describe, start, cancel, inspect results, etc.
Added in version 0.11.0: This class originally had the more cryptic name
RESTJob
, which is still available as legacy alias, butBatchJob
is recommended since version 0.11.0.- delete()[source]¶
Delete this batch job.
Added in version 0.20.0: This method was previously called
delete_job()
.This method uses openEO endpoint
DELETE /jobs/{job_id}
- delete_job()¶
Delete this batch job.
Deprecated since version 0.20.0: Usage of this legacy method is deprecated. Use
delete()
instead.
- describe()[source]¶
Get detailed metadata about a submitted batch job (title, process graph, status, progress, …). :rtype:
dict
Added in version 0.20.0: This method was previously called
describe_job()
.This method uses openEO endpoint
GET /jobs/{job_id}
- describe_job()¶
Get detailed metadata about a submitted batch job (title, process graph, status, progress, …). :rtype:
dict
Deprecated since version 0.20.0: Usage of this legacy method is deprecated. Use
describe()
instead.
- download_result(target=None)[source]¶
Download single job result to the target file path or into folder (current working dir by default).
Fails if there are multiple result files.
- Parameters:
target (
Union
[str
,Path
]) – String or path where the file should be downloaded to.- Return type:
Path
- download_results(target=None)[source]¶
Download all job result files into given folder (current working dir by default).
The names of the files are taken directly from the backend.
- Parameters:
target (
Union
[str
,Path
]) – String/path, folder where to put the result files.- Return type:
Dict
[Path
,dict
]- Returns:
file_list: Dict containing the downloaded file path as value and asset metadata
Deprecated since version 0.4.10: Instead use
BatchJob.get_results()
and the more flexible download functionality ofJobResults
- estimate()[source]¶
Calculate time/cost estimate for a job.
This method uses openEO endpoint
GET /jobs/{job_id}/estimate
- estimate_job()¶
Calculate time/cost estimate for a job.
Deprecated since version 0.20.0: Usage of this legacy method is deprecated. Use
estimate()
instead.
- get_result()[source]¶
Deprecated since version 0.4.10: Use
BatchJob.get_results()
instead.
- get_results()[source]¶
Get handle to batch job results for result metadata inspection or downloading resulting assets. :rtype:
JobResults
Added in version 0.4.10.
- job_id¶
Unique identifier of the batch job (string).
- list_results()[source]¶
Get batch job results metadata. :rtype:
dict
Deprecated since version 0.4.10: Use
get_results()
instead.
- logs(offset=None, level=None)[source]¶
Retrieve job logs.
- Parameters:
offset (
Optional
[str
]) –The last identifier (property
id
of a LogEntry) the client has received.If provided, the back-ends only sends the entries that occurred after the specified identifier. If not provided or empty, start with the first entry.
Defaults to None.
level (
Union
[int
,str
,None
]) –Minimum log level to retrieve.
You can use either constants from Python’s standard module
logging
or their names (case-insensitive).- For example:
logging.INFO
,"info"
or"INFO"
can all be used to show the messages for levellogging.INFO
and above, i.e. alsologging.WARNING
andlogging.ERROR
will be included.
Default is to show all log levels, in other words
logging.DEBUG
. This is also the result when you explicitly pass log_level=None or log_level=””.
- Return type:
List
[LogEntry
]- Returns:
A list containing the log entries for the batch job.
- run_synchronous(outputfile=None, print=<built-in function print>, max_poll_interval=60, connection_retry_interval=30)[source]¶
Start the job, wait for it to finish and download result
- Return type:
- start()[source]¶
Start this batch job.
- Return type:
- Returns:
Started batch job
Added in version 0.20.0: This method was previously called
start_job()
.This method uses openEO endpoint
POST /jobs/{job_id}/results
- start_and_wait(print=<built-in function print>, max_poll_interval=60, connection_retry_interval=30, soft_error_max=10)[source]¶
Start the batch job, poll its status and wait till it finishes (or fails)
- Parameters:
print – print/logging function to show progress/status
max_poll_interval (
int
) – maximum number of seconds to sleep between status pollsconnection_retry_interval (
int
) – how long to wait when status poll failed due to connection issuesoft_error_max – maximum number of soft errors (e.g. temporary connection glitches) to allow
- Return type:
- Returns:
- start_job()¶
Start this batch job. :rtype:
BatchJob
Deprecated since version 0.20.0: Usage of this legacy method is deprecated. Use
start()
instead.
- status()[source]¶
Get the status of the batch job
- Return type:
str
- Returns:
batch job status, one of “created”, “queued”, “running”, “canceled”, “finished” or “error”.
- stop()[source]¶
Stop this batch job.
Added in version 0.20.0: This method was previously called
stop_job()
.This method uses openEO endpoint
DELETE /jobs/{job_id}/results
- class openeo.rest.job.JobResults(job)[source]¶
Results of a batch job: listing of one or more output files (assets) and some metadata.
Added in version 0.4.10.
- download_file(target=None, name=None)[source]¶
Download single asset. Can be used when there is only one asset in the
JobResults
, or when the desired asset name is given explicitly.- Parameters:
target (
Union
[Path
,str
]) – path to download to. Can be an existing directory (in which case the filename advertised by backend will be used) or full file name. By default, the working directory will be used.name (
str
) – asset name to download (not required when there is only one asset)
- Return type:
Path
- Returns:
path of downloaded asset
- download_files(target=None, include_stac_metadata=True)[source]¶
Download all assets to given folder.
- Parameters:
target (
Union
[Path
,str
]) – path to folder to download to (must be a folder if it already exists)include_stac_metadata (
bool
) – whether to download the job result metadata as a STAC (JSON) file.
- Return type:
List
[Path
]- Returns:
list of paths to the downloaded assets.
- get_asset(name=None)[source]¶
Get single asset by name or without name if there is only one.
- Return type:
- get_assets()[source]¶
Get all assets from the job results.
- Return type:
List
[ResultAsset
]
- class openeo.rest.job.RESTJob(job_id, connection)[source]¶
Legacy alias for
BatchJob
.Deprecated since version 0.11.0: Use
BatchJob
instead
- class openeo.rest.job.ResultAsset(job, name, href, metadata)[source]¶
Result asset of a batch job (e.g. a GeoTIFF or JSON file)
Added in version 0.4.10.
- download(target=None, *, chunk_size=10000000)[source]¶
Download asset to given location
- Parameters:
target (
Union
[str
,Path
,None
]) – download target path. Can be an existing folder (in which case the filename advertised by backend will be used) or full file name. By default, the working directory will be used.chunk_size (
int
) – chunk size for streaming response.
- Return type:
Path
- href¶
Download URL of the asset.
- metadata¶
Asset metadata provided by the backend, possibly containing keys “type” (for media type), “roles”, “title”, “description”.
- name¶
Asset name as advertised by the backend.
openeo.rest.conversions¶
Helpers for data conversions between Python ecosystem data types and openEO data structures.
- openeo.rest.conversions.datacube_from_file(filename, fmt='netcdf')[source]¶
- Return type:
Deprecated since version 0.7.0: Use
XarrayDataCube.from_file()
instead.
- openeo.rest.conversions.datacube_plot(datacube, *args, **kwargs)[source]¶
Deprecated since version 0.7.0: Use
XarrayDataCube.plot()
instead.
- openeo.rest.conversions.datacube_to_file(datacube, filename, fmt='netcdf')[source]¶
Deprecated since version 0.7.0: Use
XarrayDataCube.save_to_file()
instead.
- openeo.rest.conversions.timeseries_json_to_pandas(timeseries, index='date', auto_collapse=True)[source]¶
Convert a timeseries JSON object as returned by the aggregate_spatial process to a pandas DataFrame object
This timeseries data has three dimensions in general: date, polygon index and band index. One of these will be used as index of the resulting dataframe (as specified by the index argument), and the other two will be used as multilevel columns. When there is just a single polygon or band in play, the dataframe will be simplified by removing the corresponding dimension if auto_collapse is enabled (on by default).
- Parameters:
timeseries (
dict
) – dictionary as returned by aggregate_spatialindex (
str
) – which dimension should be used for the DataFrame index: ‘date’ or ‘polygon’auto_collapse – whether single band or single polygon cases should be simplified automatically
- Return type:
DataFrame
- Returns:
pandas DataFrame or Series
openeo.rest.udp¶
- class openeo.rest.udp.RESTUserDefinedProcess(user_defined_process_id, connection)[source]¶
Wrapper for a user-defined process stored (or to be stored) on an openEO back-end
- openeo.rest.udp.build_process_dict(process_graph, process_id=None, summary=None, description=None, parameters=None, returns=None, categories=None, examples=None, links=None)[source]¶
Build a dictionary describing a process with metadaa (process_graph, parameters, description, …)
- Parameters:
process_graph (
Union
[dict
,FlatGraphableMixin
]) – dict or builder representing a process graphprocess_id (
Optional
[str
]) – identifier of the processsummary (
Optional
[str
]) – short summary of what the process doesdescription (
Optional
[str
]) – detailed descriptionparameters (
Optional
[List
[Union
[dict
,Parameter
]]]) – list of process parameters (which have name, schema, default value, …)returns (
Optional
[dict
]) – description and schema of what the process returnscategories (
Optional
[List
[str
]]) – list of categoriesexamples (
Optional
[List
[dict
]]) – list of examples, may be used for unit testslinks (
Optional
[List
[dict
]]) – list of links related to the process
- Return type:
dict
- Returns:
dictionary in openEO “process graph with metadata” format
openeo.rest.userfile¶
- class openeo.rest.userfile.UserFile(path, *, connection, metadata=None)[source]¶
Handle to a (user-uploaded) file in the user workspace on a openEO back-end.
- download(target=None)[source]¶
Downloads a user-uploaded file from the user workspace on the back-end locally to the given location.
- Parameters:
target (
Union
[Path
,str
]) – local download target path. Can be an existing folder (in which case the file name advertised by backend will be used) or full file name. By default, the working directory will be used.- Return type:
Path
- classmethod from_metadata(metadata, connection)[source]¶
Build
UserFile
from a workspace file metadata dictionary.- Return type:
- upload(source)[source]¶
Uploads a local file to the path corresponding to this
UserFile
in the user workspace and returns newUserFile
of newly uploaded file.Tip
Usually you’ll just need
Connection.upload_file()
instead of thisUserFile
method.If the file exists in the user workspace it will be replaced.
openeo.udf¶
- class openeo.udf.udf_data.UdfData(proj=None, datacube_list=None, feature_collection_list=None, structured_data_list=None, user_context=None)[source]¶
Container for data passed to a user defined function (UDF)
- property datacube_list: List[XarrayDataCube] | None¶
Get the data cube list
- property feature_collection_list: List[FeatureCollection] | None¶
get all feature collections as list
- classmethod from_dict(udf_dict)[source]¶
Create a udf data object from a python dictionary that was created from the JSON definition of the UdfData class
- Parameters:
udf_dict (
dict
) – The dictionary that contains the udf data definition- Return type:
- get_datacube_list()[source]¶
Get the data cube list
- Return type:
Optional
[List
[XarrayDataCube
]]
- get_feature_collection_list()[source]¶
get all feature collections as list
- Return type:
Optional
[List
[FeatureCollection
]]
- get_structured_data_list()[source]¶
Get all structured data entries
- Return type:
Optional
[List
[StructuredData
]]- Returns:
A list of StructuredData objects
- set_datacube_list(datacube_list)[source]¶
Set the data cube list
- Parameters:
datacube_list (
Optional
[List
[XarrayDataCube
]]) – A list of data cubes
- set_structured_data_list(structured_data_list)[source]¶
Set the list of structured data
- Parameters:
structured_data_list (
Optional
[List
[StructuredData
]]) – A list of StructuredData objects
- property structured_data_list: List[StructuredData] | None¶
Get all structured data entries
- Returns:
A list of StructuredData objects
- to_dict()[source]¶
Convert this UdfData object into a dictionary that can be converted into a valid JSON representation
- Return type:
dict
- property user_context: dict¶
Return the user context that was passed to the run_udf function
- class openeo.udf.xarraydatacube.XarrayDataCube(array)[source]¶
This is a thin wrapper around
xarray.DataArray
providing a basic “DataCube” interface for openEO UDF usage around multi-dimensional data.- property array: DataArray¶
Get the
xarray.DataArray
that contains the data and dimension definition
- classmethod from_dict(xdc_dict)[source]¶
Create a
XarrayDataCube
from a Python dictionary that was created from the JSON definition of the data cube- Parameters:
data – The dictionary that contains the data cube definition
- Return type:
- classmethod from_file(path, fmt=None, **kwargs)[source]¶
Load data file as
XarrayDataCube
in memory- Parameters:
path (
Union
[str
,Path
]) – the file on diskfmt – format to load from, e.g. “netcdf” or “json” (will be auto-detected when not specified)
- Return type:
- Returns:
loaded data cube
- get_array()[source]¶
Get the
xarray.DataArray
that contains the data and dimension definition- Return type:
DataArray
- plot(title=None, limits=None, show_bandnames=True, show_dates=True, show_axeslabels=False, fontsize=10.0, oversample=1, cmap='RdYlBu_r', cbartext=None, to_file=None, to_show=True)[source]¶
Visualize a
XarrayDataCube
with matplotlib- Parameters:
datacube – data to plot
title (str) – title text drawn in the top left corner (default: nothing)
limits – range of the contour plot as a tuple(min,max) (default: None, in which case the min/max is computed from the data)
show_bandnames (bool) – whether to plot the column names (default: True)
show_dates (bool) – whether to show the dates for each row (default: True)
show_axeslabels (bool) – whether to show the labels on the axes (default: False)
fontsize (float) – font size in pixels (default: 10)
oversample (float) – one value is plotted into oversample x oversample number of pixels (default: 1 which means each value is plotted as a single pixel)
cmap (Union[str, ‘matplotlib.colors.Colormap’]) – built-in matplotlib color map name or ColorMap object (default: RdYlBu_r which is a blue-yellow-red rainbow)
cbartext (str) – text on top of the legend (default: nothing)
to_file (str) – filename to save the image to (default: None, which means no file is generated)
to_show (bool) – whether to show the image in a matplotlib window (default: True)
- Returns:
None
- save_to_file(path, fmt=None, **kwargs)[source]¶
Store
XarrayDataCube
to file- Parameters:
path (
Union
[str
,Path
]) – destination file on diskfmt – format to save as, e.g. “netcdf” or “json” (will be auto-detected when not specified)
- to_dict()[source]¶
Convert this hypercube into a dictionary that can be converted into a valid JSON representation
>>> example = { ... "id": "test_data", ... "data": [ ... [[0.0, 0.1], [0.2, 0.3]], ... [[0.0, 0.1], [0.2, 0.3]], ... ], ... "dimension": [ ... {"name": "time", "coordinates": ["2001-01-01", "2001-01-02"]}, ... {"name": "X", "coordinates": [50.0, 60.0]}, ... {"name": "Y"}, :rtype: :sphinx_autodoc_typehints_type:`\:py\:class\:\`dict\``
… ], … }
- class openeo.udf.structured_data.StructuredData(data, description=None, type=None)[source]¶
This class represents structured data that is produced by an UDF and can not be represented as a raster or vector data cube. For example: the result of a statistical computation.
Usage example:
>>> StructuredData([3, 5, 8, 13]) >>> StructuredData({"mean": 5, "median": 8}) >>> StructuredData([('col_1', 'col_2'), (1, 2), (2, 3)], type="table")
Note: this module was initially developed under the openeo-udf
project (https://github.com/Open-EO/openeo-udf)
- openeo.udf.run_code.execute_local_udf(udf, datacube, fmt='netcdf')[source]¶
Locally executes an user defined function on a previously downloaded datacube.
- Parameters:
udf (
Union
[str
,UDF
]) – the code of the user defined functiondatacube (
Union
[str
,DataArray
,XarrayDataCube
]) – the path to the downloaded data in disk or a DataCubefmt – format of the file if datacube is string
- Returns:
the resulting DataCube
- openeo.udf.run_code.extract_udf_dependencies(udf)[source]¶
Extract dependencies from UDF code declared in a top-level comment block following the inline script metadata specification (PEP 508).
Basic example UDF snippet declaring expected dependencies as embedded metadata in a comment block:
# /// script # dependencies = [ # "geojson", # ] # /// import geojson def apply_datacube(cube: xarray.DataArray, context: dict) -> xarray.DataArray: ...
See also
Standard for declaring Python UDF dependencies for more in-depth information.
- Parameters:
- Return type:
Optional
[List
[str
]]- Returns:
List of extracted dependencies or
None
when no valid metadata block with dependencies was found.
Added in version 0.30.0.
Debug utilities for UDFs
- openeo.udf.debug.inspect(data=None, message='', code='User', level='info')[source]¶
Implementation of the openEO inspect process for UDF contexts.
Note that it is up to the back-end implementation to properly capture this logging and include it in the batch job logs.
- Parameters:
data – data to log
message (
str
) – message to send in addition to the datacode (
str
) – A label to help identify one or more log entrieslevel (
str
) – The severity level of this message. Allowed values: “error”, “warning”, “info”, “debug”
Added in version 0.10.1.
See also
openeo.util¶
Various utilities and helpers.
- class openeo.util.BBoxDict(*, west, south, east, north, crs=None)[source]¶
Dictionary based helper to easily create/work with bounding box dictionaries (having keys “west”, “south”, “east”, “north”, and optionally “crs”).
- Parameters:
crs (
Union
[int
,str
,None
]) – value describing the coordinate reference system. Typically just an int (interpreted as EPSG code, e.g.4326
) or a string (handled as authority string, e.g."EPSG:4326"
). Seeopeneo.util.normalize_crs()
for more details about additional normalization that is applied to this argument.
Added in version 0.10.1.
- openeo.util.load_json_resource(src)[source]¶
Helper to load some kind of JSON resource
- Parameters:
src (
Union
[str
,Path
]) – a JSON resource: a raw JSON string, a path to (local) JSON file, or a URL to a remote JSON resource- Return type:
dict
- Returns:
data structured parsed from JSON
- openeo.util.normalize_crs(crs, *, use_pyproj=True)[source]¶
Normalize the given value (describing a CRS or Coordinate Reference System) to an openEO compatible EPSG code (int) or WKT2 CRS string.
At minimum, the following input values are handled:
an integer value (e.g.
4326
) is interpreted as an EPSG codea string that just contains an integer (e.g.
"4326"
) or with and additional"EPSG:"
prefix (e.g."EPSG:4326"
) will also be interpreted as an EPSG value
Additional support and behavior depends on the availability of the
pyproj
library:When available, it will be used for parsing and validation: everything supported by pyproj.CRS.from_user_input is allowed. See the
pyproj
docs for more details.Otherwise, some best effort validation is done: EPSG looking integer or string values will be parsed as such as discussed above. Other strings will be assumed to be WKT2 already. Other data structures will not be accepted.
- Parameters:
crs (
Any
) – value that encodes a coordinate reference system, typically just an int (EPSG code) or string (authority string). If thepyproj
library is available, everything supported by it is allowed.use_pyproj (
bool
) – whetherpyproj
should be leveraged at all (mainly useful for testing the “no pyproj available” code path)
- Return type:
Union
[None
,int
,str
]- Returns:
EPSG code as int, or WKT2 string. Or None if input was empty.
- Raises:
ValueError – When the given CRS data can not be parsed/converted/normalized.
- openeo.util.to_bbox_dict(x, *, crs=None)[source]¶
Convert given data or object to a bounding box dictionary (having keys “west”, “south”, “east”, “north”, and optionally “crs”).
Supports various input types/formats:
list/tuple (assumed to be in west-south-east-north order)
>>> to_bbox_dict([3, 50, 4, 51]) {'west': 3, 'south': 50, 'east': 4, 'north': 51}
dictionary (unnecessary items will be stripped)
>>> to_bbox_dict({ ... "color": "red", "shape": "triangle", ... "west": 1, "south": 2, "east": 3, "north": 4, "crs": "EPSG:4326", ... }) {'west': 1, 'south': 2, 'east': 3, 'north': 4, 'crs': 'EPSG:4326'}
a shapely geometry
Added in version 0.10.1.
- Parameters:
x (
Any
) – input data that describes west-south-east-north bounds in some way, e.g. as a dictionary, a list, a tuple, ashapely geometry, …crs (
Union
[int
,str
,None
]) – (optional) CRS field
- Return type:
- Returns:
dictionary (subclass) with keys “west”, “south”, “east”, “north”, and optionally “crs”.
openeo.processes¶
- openeo.processes.process(process_id, arguments=None, namespace=None, **kwargs)¶
Apply process, using given arguments
- Parameters:
process_id (
str
) – process id of the process.arguments (
dict
) – argument dictionary for the process.namespace (
Optional
[str
]) – process namespace (only necessary to specify for non-predefined or non-user-defined processes)
- Returns:
new ProcessBuilder instance
Graph building¶
Various utilities and helpers to simplify the construction of openEO process graphs.
Public openEO process graph building utilities¶
- class openeo.rest.graph_building.CollectionProperty(name, _builder=None)[source]¶
Helper object to easily create simple collection metadata property filters to be used with
Connection.load_collection()
.Note
This class should not be used directly by end user code. Use the
collection_property()
factory instead.Warning
this is an experimental feature, naming might change.
- openeo.rest.graph_building.collection_property(name)[source]¶
Helper to easily create simple collection metadata property filters to be used with
Connection.load_collection()
.Usage example:
from openeo import collection_property ... connection.load_collection( ... properties=[ collection_property("eo:cloud_cover") <= 75, collection_property("platform") == "Sentinel-2B", ] )
Warning
this is an experimental feature, naming might change.
Added in version 0.26.0.
- Parameters:
name (
str
) – name of the collection property to filter on- Return type:
- Returns:
an object that supports operators like
<=
,==
to easily build simple property filters.
Internal openEO process graph building utilities¶
Internal functionality for abstracting, building, manipulating and processing openEO process graphs.
- class openeo.internal.graph_building.FlatGraphableMixin[source]¶
Mixin for classes that can be exported/converted to a “flat graph” representation of an openEO process graph.
- print_json(*, file=None, indent=2, separators=None, end='\\n')[source]¶
Print interoperable JSON representation of the process graph.
See
DataCube.to_json()
to get the JSON representation as a string and Export a process graph for more usage information.Also see
json.dumps
docs for more information on the JSON formatting options.- Parameters:
file – file-like object (stream) to print to (current
sys.stdout
by default). Or a path (string or pathlib.Path) to a file to write to.indent (
Optional
[int
]) – JSON indentation level.separators (
Optional
[Tuple
[str
,str
]]) – (optional) tuple of item/key separators.end (
str
) – additional string to be printed at the end (newline by default).
Added in version 0.12.0.
Added in version 0.23.0: added the
end
argument.
- to_json(*, indent=2, separators=None)[source]¶
Get interoperable JSON representation of the process graph.
See
DataCube.print_json()
to directly print the JSON representation and Export a process graph for more usage information.Also see
json.dumps
docs for more information on the JSON formatting options.- Parameters:
indent (
Optional
[int
]) – JSON indentation level.separators (
Optional
[Tuple
[str
,str
]]) – (optional) tuple of item/key separators.
- Return type:
str
- Returns:
JSON string
- class openeo.internal.graph_building.PGNode(process_id, arguments=None, namespace=None, **kwargs)[source]¶
A process node in a process graph: has at least a process_id and arguments.
Note that a full openEO “process graph” is essentially a directed acyclic graph of nodes pointing to each other. A full process graph is practically equivalent with its “result” node, as it points (directly or indirectly) to all the other nodes it depends on.
Warning
This class is an implementation detail meant for internal use. It is not recommended for general use in normal user code. Instead, use process graph abstraction builders like
Connection.load_collection()
,Connection.datacube_from_process()
,Connection.datacube_from_flat_graph()
,Connection.datacube_from_json()
,Connection.load_ml_model()
,openeo.processes.process()
,- flat_graph()[source]¶
Get the process graph in internal flat dict representation.
- Return type:
Dict
[str
,dict
]
- static from_flat_graph(flat_graph, parameters=None)[source]¶
Unflatten a given flat dict representation of a process graph and return result node.
- Return type:
- to_dict()[source]¶
Convert process graph to a nested dictionary structure. Uses deep copy style: nodes that are reused in graph will be deduplicated
- Return type:
dict
Testing¶
Various utilities for testing use cases (unit tests, integration tests, benchmarking, …)
openeo.testing¶
Utilities for testing of openEO client workflows.
- class openeo.testing.TestDataLoader(root)[source]¶
Helper to resolve paths to test data files, load them as JSON, optionally preprocess them, etc.
It’s intended to be used as a pytest fixture, e.g. from
conftest.py
:@pytest.fixture def test_data() -> TestDataLoader: return TestDataLoader(root=Path(__file__).parent / "data")
Added in version 0.30.0.
openeo.testing.results¶
Assert functions for comparing actual (batch job) results against expected reference data.
- openeo.testing.results.assert_job_results_allclose(actual, expected, *, rtol=1e-06, atol=1e-06, tmp_path=None)[source]¶
Assert that two job results sets are equal (with tolerance).
- Parameters:
actual (
Union
[BatchJob
,JobResults
,str
,Path
]) – actual job results, provided asBatchJob
object,JobResults()
object or path to directory with downloaded assets.expected (
Union
[BatchJob
,JobResults
,str
,Path
]) – expected job results, provided asBatchJob
object,JobResults()
object or path to directory with downloaded assets.rtol (
float
) – relative toleranceatol (
float
) – absolute tolerancetmp_path (
Optional
[Path
]) – root temp path to download results if needed. It’s recommended to pass pytest’s tmp_path fixture here
- Raises:
AssertionError – if not equal within the given tolerance
Added in version 0.31.0.
Warning
This function is experimental and subject to change.
- openeo.testing.results.assert_xarray_allclose(actual, expected, *, rtol=1e-06, atol=1e-06)[source]¶
Assert that two Xarray
DataSet
orDataArray
instances are equal (with tolerance).- Parameters:
actual (
Union
[Dataset
,DataArray
,str
,Path
]) – actual data, provided as Xarray object or path to NetCDF/GeoTIFF file.expected (
Union
[Dataset
,DataArray
,str
,Path
]) – expected or reference data, provided as Xarray object or path to NetCDF/GeoTIFF file.rtol (
float
) – relative toleranceatol (
float
) – absolute tolerance
- Raises:
AssertionError – if not equal within the given tolerance
Added in version 0.31.0.
Warning
This function is experimental and subject to change.
- openeo.testing.results.assert_xarray_dataarray_allclose(actual, expected, *, rtol=1e-06, atol=1e-06)[source]¶
Assert that two Xarray
DataArray
instances are equal (with tolerance).- Parameters:
actual (
Union
[DataArray
,str
,Path
]) – actual data, provided as Xarray DataArray object or path to NetCDF/GeoTIFF file.expected (
Union
[DataArray
,str
,Path
]) – expected or reference data, provided as Xarray DataArray object or path to NetCDF/GeoTIFF file.rtol (
float
) – relative toleranceatol (
float
) – absolute tolerance
- Raises:
AssertionError – if not equal within the given tolerance
Added in version 0.31.0.
Warning
This function is experimental and subject to change.
- openeo.testing.results.assert_xarray_dataset_allclose(actual, expected, *, rtol=1e-06, atol=1e-06)[source]¶
Assert that two Xarray
DataSet
instances are equal (with tolerance).- Parameters:
actual (
Union
[Dataset
,str
,Path
]) – actual data, provided as Xarray Dataset object or path to NetCDF/GeoTIFF fileexpected (
Union
[Dataset
,str
,Path
]) – expected or reference data, provided as Xarray Dataset object or path to NetCDF/GeoTIFF file.rtol (
float
) – relative toleranceatol (
float
) – absolute tolerance
- Raises:
AssertionError – if not equal within the given tolerance
Added in version 0.31.0.
Warning
This function is experimental and subject to change.