Provided by: grass-doc_8.4.1-1_all 

NAME
r.neighbors - Makes each cell category value a function of the category values assigned to the cells
around it, and stores new cell values in an output raster map layer.
KEYWORDS
raster, algebra, statistics, aggregation, neighbor, focal statistics, filter, parallel
SYNOPSIS
r.neighbors
r.neighbors --help
r.neighbors [-ac] input=name [selection=name] output=name[,name,...] [size=integer]
[method=string[,string,...]] [weighting_function=string] [weighting_factor=float] [weight=name]
[quantile=float[,float,...]] [title=phrase] [nprocs=integer] [memory=memory in MB] [--overwrite]
[--help] [--verbose] [--quiet] [--ui]
Flags:
-a
Do not align output with the input
-c
Use circular neighborhood
--overwrite
Allow output files to overwrite existing files
--help
Print usage summary
--verbose
Verbose module output
--quiet
Quiet module output
--ui
Force launching GUI dialog
Parameters:
input=name [required]
Name of input raster map
selection=name
Name of an input raster map to select the cells which should be processed
output=name[,name,...] [required]
Name for output raster map
size=integer
Neighborhood size
Default: 3
method=string[,string,...]
Neighborhood operation
Options: average, median, mode, minimum, maximum, range, stddev, sum, count, variance, diversity,
interspersion, quart1, quart3, perc90, quantile
Default: average
weighting_function=string
Weighting function
Options: none, gaussian, exponential, file
Default: none
none: No weighting
gaussian: Gaussian weighting function
exponential: Exponential weighting function
file: File with a custom weighting matrix
weighting_factor=float
Factor used in the selected weighting function (ignored for none and file)
weight=name
Text file containing weights
quantile=float[,float,...]
Quantile to calculate for method=quantile
Options: 0.0-1.0
title=phrase
Title for output raster map
nprocs=integer
Number of threads for parallel computing
Default: 1
memory=memory in MB
Maximum memory to be used (in MB)
Cache size for raster rows
Default: 300
DESCRIPTION
r.neighbors looks at each cell in a raster input map, and examines the values assigned to the cells in
some user-defined "neighborhood" around it. It outputs a new raster map layer in which each cell is
assigned a value that is some (user-specified) function of the values in that cell’s neighborhood. For
example, each cell in the output layer might be assigned a value equal to the average of the values
appearing in its 3 x 3 cell "neighborhood" in the input layer. Note that the centre cell is also included
in the calculation.
Figure: Illustration for an 3x3 average neighborhood
OPTIONS
The user must specify the names of the raster map layers to be used for input and output, the method used
to analyze neighborhood values (i.e., the neighborhood function or operation to be performed), and the
size of the neighborhood.
The user can optionally specify a selection map, to compute new values only where the raster cells of the
selection map are not NULL. In case of a NULL cells, the values from the input map are copied into the
output map. This may useful to smooth only parts of an elevation map (pits, peaks, ...).
Example how to use a selection map with method=average:
input map:
1 1 1 1 1
1 1 1 1 1
1 1 10 1 1
1 1 1 1 1
1 1 1 1 1
selection map, NULL values are marked as *:
* * * * *
* * 1 * *
* 1 1 1 *
* * 1 * *
* * * * *
The output map:
1 1 1 1 1
1 1 2 1 1
1 2 2 2 1
1 1 2 1 1
1 1 1 1 1
Without using the selection map, the output map would look like this:
1 1 1 1 1
1 2 2 2 1
1 2 2 2 1
1 2 2 2 1
1 1 1 1 1
It is also possible to weigh cells within the neighborhood. This can be either done with a custom weights
matrix or by specifying a weighting function.
In order to use a custom weights matrix, file needs to be specified as a weighting_function and a path to
a text file containing the weights needs to be given in the weight option.
Alternatively, gaussian and exponential weighting functions can be selected as weighting function.
For the gaussian weighting function, the user specifies the sigma value (σ) for the gauss filter in the
weighting_factor option. The sigma value represents the standard deviation of the gaussian distribution,
where the weighting formula for the gaussian filter is defined as follows:
exp(-(x*x+y*y)/(2*σ^2))/(2*π*σ^2)
Lower values for sigma result in a steeper curve, so that more weight is put on cells close to the center
of the moving window with a steeper decrease in weights with distance from the center.
For the exponential weighting function, the user specifies a factor for an exponential kernel in the
weighting_factor. Negative factors result in negative exponential decrease in weights from the center
cell. The weighting formula for the exponential kernel is defined as follows:
exp(factor*sqrt(x*x+y*y))
Stronger negative values for the factor result in a steeper curve, so that more weight is put on cells
close to the center of the moving window with a steeper decrease in weights with distance from the
center.
Optionally, the user can also run r.neighbors specify the TITLE to be assigned to the raster map layer
output, select to not align the resolution of the output with that of the input (the -a option). These
options are described further below.
Neighborhood Operation Methods: The neighborhood operators determine what new value a center cell in a
neighborhood will have after examining values inside its neighboring cells. Each cell in a raster map
layer becomes the center cell of a neighborhood as the neighborhood window moves from cell to cell
throughout the map layer. r.neighbors can perform the following operations:
average
The average value within the neighborhood. In the following example, the result would be:
(7*4 + 6 + 5 + 4*3)/9 = 5.6667
The result is rounded to the nearest integer (in this case 6).
Raw Data Operation New Data
+---+---+---+ +---+---+---+
| 7 | 7 | 5 | | | | |
+---+---+---+ average +---+---+---+
| 4 | 7 | 4 |--------->| | 6 | |
+---+---+---+ +---+---+---+
| 7 | 6 | 4 | | | | |
+---+---+---+ +---+---+---+
median
The value found half-way through a list of the neighborhood’s values, when these are ranged in
numerical order.
mode
The most frequently occurring value in the neighborhood.
minimum
The minimum value within the neighborhood.
maximum
The maximum value within the neighborhood.
range
The range value within the neighborhood.
stddev
The statistical standard deviation of values within the neighborhood (rounded to the nearest
integer).
sum
The sum of values within the neighborhood.
count
The count of filled (not NULL) cells.
variance
The statistical variance of values within the neighborhood (rounded to the nearest integer).
diversity
The number of different values within the neighborhood. In the above example, the diversity is 4.
interspersion
The percentage of cells containing values which differ from the values assigned to the center cell in
the neighborhood, plus 1. In the above example, the interspersion is:
5/8 * 100 + 1 = 63.5
The result is rounded to the nearest integer (in this case 64).
quart1, quart3
The result will be the first or the third quartile (equal of 25th and 75th percentiles).
perc90
The result will be the 90th percentile of neighborhood.
quantile
Any quantile as specified by "quantile" input parameter.
Neighborhood Size: The neighborhood size specifies which cells surrounding any given cell fall into the
neighborhood for that cell. The size must be an odd integer and represent the length of one of moving
window edges in cells. For example, a size value of 3 will result in
_ _ _
|_|_|_|
3 x 3 neighborhood ---> |_|_|_|
|_|_|_|
Matrix weights: A custom matrix can be used if none of the neighborhood operation methods are desirable
by using the weight. This option must be used in conjunction with the size option to specify the matrix
size and file needs to be specified as weighting_function. The weights desired are to be entered into a
text file. For example, to calculate the focal mean with a matrix size of 3,
r.neigbors in=input.map out=output.map size=3 weighting_function=file \
weight=weights.txt
The contents of the weight.txt file:
3 3 3
1 4 8
9 5 3
This corresponds to the following 3x3 matrix:
+-+-+-+
|3|3|3|
+-+-+-+
|1|4|8|
+-+-+-+
|9|5|3|
+-+-+-+
To calculate an annulus shaped neighborhood the contents of weight.txt file may be e.g. for size=5:
0 1 1 1 0
1 0 0 0 1
1 0 0 0 1
1 0 0 0 1
0 1 1 1 0
The way that weights are used depends upon the specific aggregate (method) being used. However, most of
the aggregates have the property that multiplying all of the weights by the same factor won’t change the
final result (an exception is method=count). Also, most (if not all) of them have the properties that an
integer weight of N is equivalent to N occurrences of the cell value, and having all weights equal to one
produces the same result as when weights are not used. When weights are used, the calculation for
method=average is:
sum(w[i]*x[i]) / sum(w[i])
In the case where all weights are zero, this will end up with both the numerator and denominator to zero,
which produces a NULL result.
FLAGS
-a
If specified, r.neighbors will not align the output raster map layer with that of the input raster
map layer. The r.neighbors program works in the current geographic region. It is recommended, but
not required, that the resolution of the geographic region be the same as that of the raster map
layer. By default, if unspecified, r.neighbors will align these geographic region settings.
-c
This flag will use a circular neighborhood for the moving analysis window, centered on the current
cell.
The exact masks for the first few neighborhood sizes are as follows:
3x3 . X . 5x5 . . X . . 7x7 . . . X . . .
X O X . X X X . . X X X X X .
. X . X X O X X . X X X X X .
. X X X . X X X O X X X
. . X . . . X X X X X .
. X X X X X .
. . . X . . .
9x9 . . . . X . . . . 11x11 . . . . . X . . . . .
. . X X X X X . . . . X X X X X X X . .
. X X X X X X X . . X X X X X X X X X .
. X X X X X X X . . X X X X X X X X X .
X X X X O X X X X . X X X X X X X X X .
. X X X X X X X . X X X X X O X X X X X
. X X X X X X X . . X X X X X X X X X .
. . X X X X X . . . X X X X X X X X X .
. . . . X . . . . . X X X X X X X X X .
. . X X X X X X X . .
. . . . . X . . . . .
NOTES
The r.neighbors program works in the current geographic region with the current mask, if any. It is
recommended, but not required, that the resolution of the geographic region be the same as that of the
raster map layer. By default, r.neighbors will align these geographic region settings. However, the
user can select to keep original input and output resolutions which are not aligned by specifying this
(e.g., using the -a option).
r.neighbors doesn’t propagate NULLs, but computes the aggregate over the non-NULL cells in the
neighborhood.
The -c flag and the weights parameter are mutually exclusive. Any use of the two together will produce
an error. Differently-shaped neighborhood analysis windows may be achieved by using the weight= parameter
to specify a weights file where all values are equal. The user can also vary the weights at the edge of
the neighborhood according to the proportion of the cell that lies inside the neighborhood circle,
effectively anti-aliasing the analysis mask.
For aggregates where a weighted calculation isn’t meaningful (specifically: minimum, maximum, diversity
and interspersion), the weights are used to create a binary mask, where zero causes the cell to be
ignored and any non-zero value causes the cell to be used.
r.neighbors copies the GRASS color files associated with the input raster map layer for those output map
layers that are based on the neighborhood average, median, mode, minimum, and maximum. Because standard
deviation, variance, diversity, and interspersion are indices, rather than direct correspondents to input
values, no color files are copied for these map layers. (The user should note that although the color
file is copied for average neighborhood function output, whether or not the color file makes sense for
the output will be dependent on the input data values.)
Propagation of output precision
The following logic has been implemented: For any aggregate, there are two factors affecting the output
type:
1 Whether the input map is integer or floating-point.
2 Whether the weighted or unweighted version of the aggregate is used.
These combine to create four possibilities:
input type/weight integer float
no yes no yes
average float float float float
median [1] [1] float float
mode integer integer [2] [2]
minimum integer integer float float
maximum integer integer float float
range integer integer float float
stddev float float float float
sum integer float float float
count integer float integer float
variance float float float float
diversity integer integer integer integer
interspersion integer integer integer integer
quart1 [1] [1] float float
quart3 [1] [1] float float
perc90 [1] [1] float float
quantile [1] [1] float float
[1] For integer input, quantiles may produce float results from interpolating between adjacent values.
[2] Calculating the mode of floating-point data is essentially meaningless.
With the current aggregates, there are 5 cases:
1 Output is always float: average, variance, stddev, quantiles (with interpolation).
2 Output is always integer: diversity, interspersion.
3 Output is integer if unweighted, float if weighted: count.
4 Output matches input: minimum, maximum, range, mode (subject to note 2 above), quantiles (without
interpolation).
5 Output is integer for integer input and unweighted aggregate, otherwise float: sum.
Performance
To enable parallel processing, the user can specify the number of threads to be used with the nprocs
parameter (default 1). The memory parameter (default 300) can also be provided to determine the size of
the buffer for computation.
Figure: Benchmark on the left shows execution time for different number of cells, benchmark in the middle
shows execution time for different sizes of neighborhood for a 10000x10000 raster and benchmark on the
right shows execution time for different memory size for a 10000x10000 raster. See benchmark scripts in
source code. (Intel Core i9-10940X CPU @ 3.30GHz x 28)
To reduce the memory requirements to minimum, set option memory to zero. To take advantage of the
parallelization, GRASS GIS needs to be compiled with OpenMP enabled.
EXAMPLES
Measure occupancy of neighborhood
Set up 10x10 computational region to aid visual inspection of results
g.region rows=10 cols=10
Fill 50% of computational region with randomly located cells. "distance=0" will allow filling adjacent
cells.
r.random.cells output=random_cells distance=0 ncells=50
Count non-empty (not NULL) cells in 3x3 neighborhood
r.neighbors input=random_cells output=counts method=count
Optionally - exclude centre cell from the count (= only look around)
r.mapcalc "count_around = if( isnull(random_cells), counts, counts - 1)"
SEE ALSO
g.region, r.clump, r.mapcalc, r.mfilter, r.statistics, r.support
AUTHORS
Original version: Michael Shapiro, U.S.Army Construction Engineering Research Laboratory
Updates for GRASS GIS 7 by Glynn Clements and others
SOURCE CODE
Available at: r.neighbors source code (history)
Accessed: Friday Apr 04 01:19:16 2025
Main index | Raster index | Topics index | Keywords index | Graphical index | Full index
© 2003-2025 GRASS Development Team, GRASS GIS 8.4.1 Reference Manual
GRASS 8.4.1 r.neighbors(1grass)