r.futures.devpressure
Module for computing development pressure
r.futures.devpressure [-n] input=name output=name method=string size=integer [gamma=float] [scaling_factor=float] [nprocs=integer] [--overwrite] [--verbose] [--quiet] [--qq] [--ui]
Example:
r.futures.devpressure input=name output=name method=gravity size=8
grass.script.run_command("r.futures.devpressure", input, output, method="gravity", size=8, gamma=1.5, scaling_factor=1, nprocs=0, flags=None, overwrite=None, verbose=None, quiet=None, superquiet=None)
Example:
gs.run_command("r.futures.devpressure", input="name", output="name", method="gravity", size=8)
grass.tools.Tools.r_futures_devpressure(input, output, method="gravity", size=8, gamma=1.5, scaling_factor=1, nprocs=0, flags=None, overwrite=None, verbose=None, quiet=None, superquiet=None)
Example:
tools = Tools()
tools.r_futures_devpressure(input="name", output="name", method="gravity", size=8)
This grass.tools API is experimental in version 8.5 and expected to be stable in version 8.6.
Parameters
input=name [required]
    Name of input binary raster map representing development
output=name [required]
    Name of the output development pressure raster
method=string [required]
    Method for computing development pressure
    Allowed values: occurrence, gravity, kernel
    Default: gravity
    occurrence: number of developed cells in window
    gravity: scaling_factor / pow(distance, gamma)
    kernel: scaling_factor * exp (-2*distance / gamma)
size=integer [required]
    Half of neighborhood size
    Default: 8
gamma=float
    Coefficient controlling the influence of distance, needed for method gravity and kernel
    Default: 1.5
scaling_factor=float
    Scaling factor needed for method gravity and kernel
    Default: 1
nprocs=integer
    Number of threads for parallel computing
    0: use OpenMP default; >0: use nprocs; <0: use MAX-nprocs
    Default: 0
-n
    Do not propagate nulls
--overwrite
    Allow output files to overwrite existing files
--help
    Print usage summary
--verbose
    Verbose module output
--quiet
    Quiet module output
--qq
    Very quiet module output
--ui
    Force launching GUI dialog
input : str, required
    Name of input binary raster map representing development
    Used as: input, raster, name
output : str, required
    Name of the output development pressure raster
    Used as: output, raster, name
method : str, required
    Method for computing development pressure
    Allowed values: occurrence, gravity, kernel
    occurrence: number of developed cells in window
    gravity: scaling_factor / pow(distance, gamma)
    kernel: scaling_factor * exp (-2*distance / gamma)
    Default: gravity
size : int, required
    Half of neighborhood size
    Default: 8
gamma : float, optional
    Coefficient controlling the influence of distance, needed for method gravity and kernel
    Default: 1.5
scaling_factor : float, optional
    Scaling factor needed for method gravity and kernel
    Default: 1
nprocs : int, optional
    Number of threads for parallel computing
    0: use OpenMP default; >0: use nprocs; <0: use MAX-nprocs
    Default: 0
flags : str, optional
    Allowed values: n
    n
        Do not propagate nulls
overwrite : bool, optional
    Allow output files to overwrite existing files
    Default: None
verbose : bool, optional
    Verbose module output
    Default: None
quiet : bool, optional
    Quiet module output
    Default: None
superquiet : bool, optional
    Very quiet module output
    Default: None  
input : str | np.ndarray, required
    Name of input binary raster map representing development
    Used as: input, raster, name
output : str | type(np.ndarray) | type(np.array) | type(gs.array.array), required
    Name of the output development pressure raster
    Used as: output, raster, name
method : str, required
    Method for computing development pressure
    Allowed values: occurrence, gravity, kernel
    occurrence: number of developed cells in window
    gravity: scaling_factor / pow(distance, gamma)
    kernel: scaling_factor * exp (-2*distance / gamma)
    Default: gravity
size : int, required
    Half of neighborhood size
    Default: 8
gamma : float, optional
    Coefficient controlling the influence of distance, needed for method gravity and kernel
    Default: 1.5
scaling_factor : float, optional
    Scaling factor needed for method gravity and kernel
    Default: 1
nprocs : int, optional
    Number of threads for parallel computing
    0: use OpenMP default; >0: use nprocs; <0: use MAX-nprocs
    Default: 0
flags : str, optional
    Allowed values: n
    n
        Do not propagate nulls
overwrite : bool, optional
    Allow output files to overwrite existing files
    Default: None
verbose : bool, optional
    Verbose module output
    Default: None
quiet : bool, optional
    Quiet module output
    Default: None
superquiet : bool, optional
    Very quiet module output
    Default: None  
Returns:
result : grass.tools.support.ToolResult | np.ndarray | tuple[np.ndarray] | None
If the tool produces text as standard output, a ToolResult object will be returned. Otherwise, None will be returned. If an array type (e.g., np.ndarray) is used for one of the raster outputs, the result will be an array and will have the shape corresponding to the computational region. If an array type is used for more than one raster output, the result will be a tuple of arrays.
Raises:
grass.tools.ToolError: When the tool ended with an error.
DESCRIPTION
Module r.futures.devpressure is part of FUTURES, land change model. It computes development pressure, a predictor based on the number of neighboring developed cells within search distance, weighted by distance. The development pressure variable plays a special role in the model, allowing for a feedback between predicted change and change in subsequent steps.
There are multiple options for calculating development pressure in the model.
- occurrence: simple count of the number of developed cells within the specified window size
- gravity: defined as scaling_factor / pow(distance, gamma)
- kernel: defined as scaling_factor * exp(-2 * distance / gamma)
Coefficient gamma is the coefficient controlling the influence of distance. The best value for gamma is chosen during the model selection process (TODO).
The input raster is binary, value 1 represents development, value 0 no development. The neighborhood size describes the size of the moving window in cells (2 * size + 1).
Figure: Effect of parameters size and gamma: a) initial development, b) gamma = 2, size = 10, c) gamma = 1.5, size = 10, d) gamma = 1.5, size = 20.
NOTES
By default NULL values are propagated. This means that the edges of the resulting map will be NULLs. To avoid that, flag n internally enlarges the computational region, converts NULLs to zeros, performs the computation and then patches back the original NULL values.
Module r.futures.devpressure, although written for FUTURES model, is general enough to be used for different applications where distance pressure can be described with the functions above.
EXAMPLES
r.futures.devpressure input=developed output=pressure gamma=1.5 size=10 method=gravity
SEE ALSO
FUTURES, r.futures.pga, r.futures.calib, r.futures.demand, r.sample.category
REFERENCES
- Meentemeyer, R. K., Tang, W., Dorning, M. A., Vogler, J. B., Cunniffe, N. J., & Shoemaker, D. A. (2013). FUTURES: Multilevel Simulations of Emerging Urban-Rural Landscape Structure Using a Stochastic Patch-Growing Algorithm. Annals of the Association of American Geographers, 103(4), 785-807. DOI: 10.1080/00045608.2012.707591
- Dorning, M. A., Koch, J., Shoemaker, D. A., & Meentemeyer, R. K. (2015). Simulating urbanization scenarios reveals tradeoffs between conservation planning strategies. Landscape and Urban Planning, 136, 28-39. DOI: 10.1016/j.landurbplan.2014.11.011
- Petrasova, A., Petras, V., Van Berkel, D., Harmon, B. A., Mitasova, H., & Meentemeyer, R. K. (2016). Open Source Approach to Urban Growth Simulation. Int. Arch. Photogramm. Remote Sens. Spatial Inf. Sci., XLI-B7, 953-959. DOI: 10.5194/isprsarchives-XLI-B7-953-2016
AUTHOR
Anna Petrasova, NCSU GeoForAll
SOURCE CODE
Available at: r.futures.devpressure source code
(history)
Latest change: Friday Feb 21 10:10:05 2025 in commit 7d78fe3
