The NeighborhoodAggregate operator computes an aggregate function for a pixel and its neighborhood. The operator can be defined as a neighborhood matrix with either weights or predefined shapes and an aggregate function.
NeighborhoodAggregate
An example usage scenario is to calculate a Gaussian filter to smoothen or blur an image. For each time step in the raster time series, the operator computes the aggregate for each pixel and its neighborhood.
The output data type is the same as the input data type. As the matrix and the aggregate in- and outputs are defined as floating point values, the internal computation is done as floating point calculations.
neighborhood
Neighborhood
{ "type": "weightsMatrix", "weights": [ [1.0, 2.0, 3.0], [4.0, 5.0, 6.0], [7.0, 8.0, 9.0] ]}
aggregateFunction
AggregateFunction
"sum"
The following describes the types used in the parameters.
There are several types of neighborhoods. They define a matrix of weights. The rows and columns of this matrix must be odd.
The weights matrix is defined as an \( n \times m \) matrix of floating point values. It is applied to the pixel and its neighborhood to serve as the input for the aggregate function.
For instance, a vertical derivative filter (a component of a Sobel filter) can be defined like this:
{ "type": "weightsMatrix", "weights": [ [1.0, 0.0, -1.0], [2.0, 0.0, -2.0], [1.0, 0.0, -1.0] ] }
The aggregate function should be sum in this case.
sum
The rectangle neighborhood is defined by its shape \( n \times m \). The result is a weights matrix with all weights set to 1.0.
1.0
{ "type": "rectangle", "dimensions": [3, 3] }
The aggregate function computes a single value from a set of values. The following aggregate functions are supported:
standardDeviation
NO DATA
The NeighborhoodAggregate operator expects exactly one raster input.
source
SingleRasterSource
If the neighborhood rows or columns are not positive or odd, an error will be thrown.
{ "type": "NeighborhoodAggregate", "params": { "neighborhood": { "type": "weightsMatrix", "weights": [ [1.0, 2.0, 3.0], [4.0, 5.0, 6.0], [7.0, 8.0, 9.0] ] }, "aggregateFunction": "sum" }, "sources": { "raster": { "type": "GdalSource", "params": { "data": "ndvi" } } } }