Title: | Implementation of the Potential Model |
---|---|
Description: | Provides functions to compute the potential model as defined by Stewart (1941) <doi:10.1126/science.93.2404.89>. Several options are available to customize the model, such as the possibility to fine-tune the distance friction functions or to use custom distance matrices. Some computations are parallelized to improve their efficiency. |
Authors: | Timothée Giraud [cre, aut] , Hadrien Commenges [aut] |
Maintainer: | Timothée Giraud <[email protected]> |
License: | GPL-3 |
Version: | 0.3.0.0 |
Built: | 2025-01-08 05:44:28 UTC |
Source: | https://github.com/riatelab/potential |
This package provides functions to compute the potential model as defined by Stewart (1941) <doi:10.1126/science.93.2404.89>. Several options are available to customize the model, such as the possibility to fine-tune the distance friction functions or to use custom distance matrices. Some computations are parallelized to improve their efficiency.
This function creates a regular grid of points from the extent of a given spatial object and a given resolution.
create_grid(x, res)
create_grid(x, res)
x |
an sf or sfc object, the spatial extent of this object is used to create the regular grid. |
res |
resolution of the grid (in map units). |
The output of the function is an sf object of regularly spaced points with the extent of x.
library(sf) g <- create_grid(x = n3_poly, res = 200000) plot(st_geometry(g)) plot(st_geometry(n3_poly), border = "red", add = TRUE)
library(sf) g <- create_grid(x = n3_poly, res = 200000) plot(st_geometry(g)) plot(st_geometry(n3_poly), border = "red", add = TRUE)
This function creates a distance matrix between two spatial objects.
create_matrix(x, y, checksize = TRUE, longlat = FALSE)
create_matrix(x, y, checksize = TRUE, longlat = FALSE)
x |
an sf object (POINT), rows of the distance matrix, row names are used as row names of the matrix. |
y |
an sf object (POINT), columns of the distance matrix, row names are used as column names of the matrix. |
checksize |
if FALSE, bypass the distance matrix size control (see Details). |
longlat |
if FALSE, the Euclidean distance is used, if TRUE Great Circle (WGS84 ellipsoid) distance is used. |
The function returns a full matrix of distances in meters. If the matrix to compute is too large (more than 100,000,000 cells, more than 10,000,000 origins or more than 10,000,000 destinations) the function may sends a message to warn users about the amount of RAM mobilized.
A distance matrix, row names are x
row names, column
names are y
row names.
g <- create_grid(x = n3_poly, res = 200000) mat <- create_matrix(x = n3_pt, y = g) mat[1:5, 1:5]
g <- create_grid(x = n3_poly, res = 200000) mat <- create_matrix(x = n3_pt, y = g) mat[1:5, 1:5]
This function creates polygons of equipotential from a regular grid of potential points.
equipotential(x, var, nclass = 8, breaks, mask, buffer, xcoords, ycoords)
equipotential(x, var, nclass = 8, breaks, mask, buffer, xcoords, ycoords)
x |
an sf object of regularly spaced points. |
var |
name of the variable to use in |
nclass |
a number of class. |
breaks |
a vector of break values. |
mask |
an sf object of polygons or multipolygons. |
buffer |
if set, a buffer is added to the mask in order to
reach more precisely the number of breaks. The buffer is defined in
|
xcoords |
not used. |
ycoords |
not used. |
The output is an sf object (POLYGONS). The data frame contains four fields: id (id of each polygon), min and max (minimum and maximum breaks of the polygon) and center (central values of classes).
library(sf) y <- create_grid(x = n3_poly, res = 200000) d <- create_matrix(n3_pt, y) pot <- potential( x = n3_pt, y = y, d = d, var = "POP19", fun = "e", span = 200000, beta = 2 ) y$OUTPUT <- pot equipot <- equipotential(y, var = "OUTPUT", mask = n3_poly) plot(equipot["center"], pal = hcl.colors(nrow(equipot), "cividis"))
library(sf) y <- create_grid(x = n3_poly, res = 200000) d <- create_matrix(n3_pt, y) pot <- potential( x = n3_pt, y = y, d = d, var = "POP19", fun = "e", span = 200000, beta = 2 ) y$OUTPUT <- pot equipot <- equipotential(y, var = "OUTPUT", mask = n3_poly) plot(equipot["center"], pal = hcl.colors(nrow(equipot), "cividis"))
This function computes the potential model with a cutoff distance and parallel computation.
mcpotential(x, y, var, fun, span, beta, limit = 3 * span, ncl, size = 500)
mcpotential(x, y, var, fun, span, beta, limit = 3 * span, ncl, size = 500)
x |
an sf object (POINT), the set of known observations to estimate the potentials from. |
y |
an sf object (POINT), the set of unknown units for which the function computes the estimates. |
var |
names of the variables in |
fun |
spatial interaction function. Options are "p"
(pareto, power law) or "e" (exponential).
For pareto the interaction is defined as: (1 + alpha * mDistance) ^ (-beta).
For "exponential" the interaction is defined as:
exp(- alpha * mDistance ^ beta).
The alpha parameter is computed from parameters given by the user
( |
span |
distance where the density of probability of the spatial interaction function equals 0.5. |
beta |
impedance factor for the spatial interaction function. |
limit |
maximum distance used to retrieve |
ncl |
number of clusters. |
size |
|
If only one variable is computed a vector is returned, if more than one variable is computed a matrix is returned.
library(sf) g <- create_grid(x = n3_poly, res = 20000) pot <- mcpotential( x = n3_pt, y = g, var = "POP19", fun = "e", span = 75000, beta = 2, limit = 300000, ncl = 2 ) g$OUTPUT <- pot equipot <- equipotential(g, var = "OUTPUT", mask = n3_poly) plot(equipot["center"], pal = hcl.colors(nrow(equipot), "cividis"))
library(sf) g <- create_grid(x = n3_poly, res = 20000) pot <- mcpotential( x = n3_pt, y = g, var = "POP19", fun = "e", span = 75000, beta = 2, limit = 300000, ncl = 2 ) g$OUTPUT <- pot equipot <- equipotential(g, var = "OUTPUT", mask = n3_poly) plot(equipot["center"], pal = hcl.colors(nrow(equipot), "cividis"))
n3_pt (POINTS) and n3_poly (MULTIPOLYGONS) are sf objects of 1506 NUTS3 statistical units of continental Europe.
Population dataset (2019 an 2018 total population) downloaded on the Eurostat website (05/10/2020) from the "demo_r_pjanaggr3" dataset (last update: 16/06/2020).
Geometries are downloaded from the GISCO website (NUTS3 - 2016 - 1:60 Million)
When data from this packgage is used in any printed or electronic publication, in addition to any other provisions applicable to the whole Eurostat website, data source will have to be acknowledged in the legend of the map and in the introductory page of the publication with the following copyright notice: "© EuroGeographics for the administrative boundaries and © Eurostat for data".
data(nuts3)
data(nuts3)
An object of class sf
(inherits from data.frame
) with 1506 rows and 4 columns.
n3_pt (POINTS) and n3_poly (MULTIPOLYGONS) are sf objects of 1506 NUTS3 statistical units of continental Europe.
Population dataset (2019 an 2018 total population) downloaded on the Eurostat website (05/10/2020) from the "demo_r_pjanaggr3" dataset (last update: 16/06/2020).
Geometries are downloaded from the GISCO website (NUTS3 - 2016 - 1:60 Million)
When data from this package is used in any printed or electronic publication, in addition to any other provisions applicable to the whole Eurostat website, data source will have to be acknowledged in the legend of the map and in the introductory page of the publication with the following copyright notice: "© EuroGeographics for the administrative boundaries and © Eurostat for data".
data(nuts3)
data(nuts3)
An object of class sf
(inherits from data.frame
) with 1506 rows and 4 columns.
Display a spatial interaction function.
plot_inter(fun = "e", span, beta, limit = span * 5)
plot_inter(fun = "e", span, beta, limit = span * 5)
fun |
spatial interaction function. Options are "p"
(pareto, power law) or "e" (exponential).
For pareto the interaction is defined as: (1 + alpha * mDistance) ^ (-beta).
For "exponential" the interaction is defined as:
exp(- alpha * mDistance ^ beta).
The alpha parameter is computed from parameters given by the user
( |
span |
distance where the density of probability of the spatial interaction function equals 0.5. |
beta |
impedance factor for the spatial interaction function. |
limit |
maximum distance used to retrieved |
a plot
plot_inter(fun = "e", span = 2000, beta = 2, limit = 4000) plot_inter(fun = "p", span = 2000, beta = 2, limit = 20000)
plot_inter(fun = "e", span = 2000, beta = 2, limit = 4000) plot_inter(fun = "p", span = 2000, beta = 2, limit = 20000)
This function computes the potential model as defined by J.Q. Stewart (1941).
potential(x, y, d, var, fun, span, beta)
potential(x, y, d, var, fun, span, beta)
x |
an sf object (POINT), the set of known observations to estimate the potentials from. |
y |
an sf object (POINT), the set of unknown units for which the function computes the estimates. |
d |
a distance matrix between known observations and unknown
units for which the function computes the estimates. Row names match the row
names of |
var |
names of the variables in |
fun |
spatial interaction function. Options are "p"
(pareto, power law) or "e" (exponential).
For pareto the interaction is defined as: (1 + alpha * mDistance) ^ (-beta).
For "exponential" the interaction is defined as:
exp(- alpha * mDistance ^ beta).
The alpha parameter is computed from parameters given by the user
( |
span |
distance where the density of probability of the spatial interaction function equals 0.5. |
beta |
impedance factor for the spatial interaction function. |
If only one variable is computed a vector is returned, if more than one variable is computed a matrix is returned.
STEWART, JOHN Q. 1941. "An Inverse Distance Variation for Certain Social Influences." Science 93 (2404): 89–90. doi:10.1126/science.93.2404.89.
library(sf) y <- create_grid(x = n3_poly, res = 200000) d <- create_matrix(n3_pt, y) pot <- potential( x = n3_pt, y = y, d = d, var = "POP19", fun = "e", span = 200000, beta = 2 ) y$OUTPUT <- pot equipot <- equipotential(y, var = "OUTPUT", mask = n3_poly) plot(equipot["center"], pal = hcl.colors(nrow(equipot), "cividis"))
library(sf) y <- create_grid(x = n3_poly, res = 200000) d <- create_matrix(n3_pt, y) pot <- potential( x = n3_pt, y = y, d = d, var = "POP19", fun = "e", span = 200000, beta = 2 ) y$OUTPUT <- pot equipot <- equipotential(y, var = "OUTPUT", mask = n3_poly) plot(equipot["center"], pal = hcl.colors(nrow(equipot), "cividis"))