Title: | Spatial Dependence for Simple Features |
---|---|
Description: | An interface to 'spdep' to integrate with 'sf' objects and the 'tidyverse'. |
Authors: | Josiah Parry [aut] , Dexter Locke [aut, cre] |
Maintainer: | Dexter Locke <[email protected]> |
License: | GPL-3 |
Version: | 0.2.4.9000 |
Built: | 2025-01-03 04:44:26 UTC |
Source: | https://github.com/josiahparry/sfdep |
From a spacetime
object, activate either the data or geometry contexts. The active object will then become available for manipulation.
active(.data) activate(.data, what)
active(.data) activate(.data, what)
.data |
a spacetime object |
what |
default NULL. Determines which context to activate. Valid argument values
are |
A spacetime
object contains both a data frame and an sf object. The
data frame represents geographies over one or more time periods and the sf
object contains the geographic information for those locations.
For activate()
an object of class spacetime with the specified context activated. active()
returns a scalar character with the active context can be either "goemetry" or "data".
df_fp <- system.file("extdata", "bos-ecometric.csv", package = "sfdep") geo_fp <- system.file("extdata", "bos-ecometric.geojson", package = "sfdep") # read in data df <- read.csv( df_fp, colClasses = c("character", "character", "integer", "double", "Date") ) geo <- sf::st_read(geo_fp) # Create spacetime object called `bos` bos <- spacetime(df, geo, .loc_col = ".region_id", .time_col = "time_period") active(bos) activate(bos, "geometry")
df_fp <- system.file("extdata", "bos-ecometric.csv", package = "sfdep") geo_fp <- system.file("extdata", "bos-ecometric.geojson", package = "sfdep") # read in data df <- read.csv( df_fp, colClasses = c("character", "character", "integer", "double", "Date") ) geo <- sf::st_read(geo_fp) # Create spacetime object called `bos` bos <- spacetime(df, geo, .loc_col = ".region_id", .time_col = "time_period") active(bos) activate(bos, "geometry")
spacetime
and sf
classesCast between spacetime
and sf
classes
Convert sf object to spacetime
as_sf(x, ...) as_spacetime(x, .loc_col, .time_col, ...) ## S3 method for class 'sf' as_spacetime(x, .loc_col, .time_col, ...)
as_sf(x, ...) as_spacetime(x, .loc_col, .time_col, ...) ## S3 method for class 'sf' as_spacetime(x, .loc_col, .time_col, ...)
x |
for |
... |
arguments passed to merge. |
.loc_col |
the quoted name of the column containing unique location identifiers. |
.time_col |
the quoted name of the column containing time periods. |
For as_spacetime()
returns a spacetime object. For as_sf()
, an sf object.
if (require(dplyr, quietly = TRUE)) { df_fp <- system.file("extdata", "bos-ecometric.csv", package = "sfdep") geo_fp <- system.file("extdata", "bos-ecometric.geojson", package = "sfdep") # read in data df <- read.csv( df_fp, colClasses = c("character", "character", "integer", "double", "Date") ) geo <- sf::st_read(geo_fp) # Create spacetime object called `bos` bos <- spacetime(df, geo, .loc_col = ".region_id", .time_col = "time_period") as_sf(bos) if (require("dplyr", quietly=TRUE)) { as_spacetime(as_sf(bos) , ".region_id", "year") } }
if (require(dplyr, quietly = TRUE)) { df_fp <- system.file("extdata", "bos-ecometric.csv", package = "sfdep") geo_fp <- system.file("extdata", "bos-ecometric.geojson", package = "sfdep") # read in data df <- read.csv( df_fp, colClasses = c("character", "character", "integer", "double", "Date") ) geo <- sf::st_read(geo_fp) # Create spacetime object called `bos` bos <- spacetime(df, geo, .loc_col = ".region_id", .time_col = "time_period") as_sf(bos) if (require("dplyr", quietly=TRUE)) { as_spacetime(as_sf(bos) , ".region_id", "year") } }
Given an sfc object containing points, calculate a measure of central tendency.
center_mean(geometry, weights = NULL) center_median(geometry) euclidean_median(geometry, tolerance = 1e-09)
center_mean(geometry, weights = NULL) center_median(geometry) euclidean_median(geometry, tolerance = 1e-09)
geometry |
an sfc object. If a polygon, uses |
weights |
an optional vector of weights to apply to the coordinates before calculation. |
tolerance |
a tolerance level to terminate the process. This is passed to |
center_mean()
calculates the mean center of a point pattern
euclidean_median()
calculates the euclidean median center of a point pattern using the pracma
package
center_median()
calculates the median center it is recommended to use the euclidean median over the this function.
an sfc POINT object
Other point-pattern:
std_distance()
Other point-pattern:
std_distance()
if (requireNamespace("pracma")) { # Make a grid to sample from grd <- sf::st_make_grid(n = c(1, 1), cellsize = c(100, 100), offset = c(0,0)) # sample 100 points pnts <- sf::st_sample(grd, 100) cm <- center_mean(pnts) em <- euclidean_median(pnts) cmed <- center_median(pnts) plot(pnts) plot(cm, col = "red", add = TRUE) plot(em, col = "blue", add = TRUE) plot(cmed, col = "green", add = TRUE) }
if (requireNamespace("pracma")) { # Make a grid to sample from grd <- sf::st_make_grid(n = c(1, 1), cellsize = c(100, 100), offset = c(0,0)) # sample 100 points pnts <- sf::st_sample(grd, 100) cm <- center_mean(pnts) em <- euclidean_median(pnts) cmed <- center_median(pnts) plot(pnts) plot(cm, col = "red", add = TRUE) plot(em, col = "blue", add = TRUE) plot(cmed, col = "green", add = TRUE) }
Given a spacetime object, convert it to a spacetime cube. A spacetime cube ensures that there is a regular time-series for each geometry present.
complete_spacetime_cube(x, ...)
complete_spacetime_cube(x, ...)
x |
a spacetime object. |
... |
unused |
If observations are missing for a time period and location combination, columns will be populated with NAs.
See is_spacetime_cube()
for more details on spacetime cubes.
A spacetime object that meets the criteria of spacetime cube.
df_fp <- system.file("extdata", "bos-ecometric.csv", package = "sfdep") geo_fp <- system.file("extdata", "bos-ecometric.geojson", package = "sfdep") # read in data df <- read.csv(df_fp, colClasses = c("character", "character", "integer", "double", "Date")) geo <- sf::st_read(geo_fp) # Create spacetime object called `bos` bos <- spacetime(df, geo, .loc_col = ".region_id", .time_col = "time_period") # create a sample of data set.seed(0) sample_index <- sample(1:nrow(bos), nrow(bos) * 0.95) incomplete_spt <- bos[sample_index,] # check to see if is spacetime cube is_spacetime_cube(incomplete_spt) # complete it again complete_spacetime_cube(incomplete_spt)
df_fp <- system.file("extdata", "bos-ecometric.csv", package = "sfdep") geo_fp <- system.file("extdata", "bos-ecometric.geojson", package = "sfdep") # read in data df <- read.csv(df_fp, colClasses = c("character", "character", "integer", "double", "Date")) geo <- sf::st_read(geo_fp) # Create spacetime object called `bos` bos <- spacetime(df, geo, .loc_col = ".region_id", .time_col = "time_period") # create a sample of data set.seed(0) sample_index <- sample(1:nrow(bos), nrow(bos) * 0.95) incomplete_spt <- bos[sample_index,] # check to see if is spacetime cube is_spacetime_cube(incomplete_spt) # complete it again complete_spacetime_cube(incomplete_spt)
Creates a conditional permutation of neighbors list holding i fixed and shuffling it's neighbors.
cond_permute_nb(nb, seed = NULL)
cond_permute_nb(nb, seed = NULL)
nb |
a neighbor list. |
seed |
default null. A value to pass to |
A list of class nb
where each element contains a random sample of neighbors excluding the observed region.
nb <- st_contiguity(guerry) nb[1:5] # conditionally permute neighbors perm_nb <- cond_permute_nb(nb) perm_nb[1:5]
nb <- st_contiguity(guerry) nb[1:5] # conditionally permute neighbors perm_nb <- cond_permute_nb(nb) perm_nb[1:5]
Identifies the minimum distance in which each observation will have at least one neighbor.
critical_threshold(geometry, k = 1)
critical_threshold(geometry, k = 1)
geometry |
an sf geometry column |
k |
the minimum number of neighbors to check for |
a numeric scalar value.
critical_threshold(sf::st_geometry(guerry))
critical_threshold(sf::st_geometry(guerry))
Generate an ellipse from center coordinates, major and minor axis radii, and angle rotation.
ellipse(x = 0, y = 0, sx = 2, sy = 1, rotation = 0, n = 100) st_ellipse(geometry, sx, sy, rotation = 0, n = 100)
ellipse(x = 0, y = 0, sx = 2, sy = 1, rotation = 0, n = 100) st_ellipse(geometry, sx, sy, rotation = 0, n = 100)
x |
longitude of center point |
y |
latitude of center point |
sx |
radius of major axis |
sy |
radius of minor axis |
rotation |
the degree of rotation of the ellipse |
n |
the number of coordinates to generate for the ellipse |
geometry |
an sf |
ellipse()
returns a matrix of point locations defining the ellipse. st_ellipse()
returns an sf object with LINE geography of the ellipse. Increasing n increases the number of points generated to define the ellipse shape.
ellipse()
function is adapted from ggVennDiagram
.
an sf object
ellipse(n = 10) st_ellipse(sf::st_point(c(0, 0)), sx = 10, sy = 10)
ellipse(n = 10) st_ellipse(sf::st_point(c(0, 0)), sx = 10, sy = 10)
Emerging Hot Spot Analysis identifies trends in spatial clustering over a period of time. Emerging hot spot analysis combines the Getis-Ord Gi* statistic with the Mann-Kendall trend test to determine if there is a temporal trend associated with local clustering of hot and cold spots.
emerging_hotspot_analysis( x, .var, k = 1, include_gi = FALSE, nb_col = NULL, wt_col = NULL, nsim = 199, threshold = 0.01, ... )
emerging_hotspot_analysis( x, .var, k = 1, include_gi = FALSE, nb_col = NULL, wt_col = NULL, nsim = 199, threshold = 0.01, ... )
x |
a spacetime object and must be a spacetime cube see details for more. |
.var |
a numeric vector in the spacetime cube with no missing values. |
k |
default |
include_gi |
default |
nb_col |
Optional. Default |
wt_col |
Optional. Default |
nsim |
default |
threshold |
default |
... |
unused. |
Emerging Hot Spot Analysis is a somewhat simple process. It works by first calculating the Gi* statistic for each location in each time period (time-slice). Next, for each location across all time-periods, the Mann-Kendall trend test is done to identify any temporal trend in Gi* values over all time periods. Additionally, each location is classified into one of seventeen categories based on ESRI's emerging hot spot classification criteria.
The Mann-Kendall trend test is done using Kendall::MannKendall()
. Kendall
is not installed with sfdep and should be installed prior to use.
If you would like to use your own neighbors and weights, they must be created
in the geometry
context of a spacetime object. The arguments nb_col
and wt_col
must both be populated in order to use your own neighbor and weights
definitions.
In addition to identifying neighbors in space, emerging hotspot analysis also
incorporates the same observations from k
periods ago-called a time lag. If
the time lag k is 1 and the unit of time is month, the neighbors for the
calculation of Gi* would include the spatial neighbors' values at time t
and the same spatial neighbors' values at time t-1
. If k = 2
, it would include
t
, t-1
, and t-2
.
Presently, there is no method of missing value handling. If there are missing values, the emerging hot spot analysis will fail. Be sure to fill or omit time-slices with missing values prior to using emerging hot spot analysis.
Returns a data.frame.
How Emerging Hot Spot Analysis works, Emerging Hot Spot Analysis (Space Time Pattern Mining), and the video Spatial Data Mining II: A Deep Dive into Space-Time Analysis by ESRI.
if (requireNamespace("Kendall")) { df_fp <- system.file("extdata", "bos-ecometric.csv", package = "sfdep") geo_fp <- system.file("extdata", "bos-ecometric.geojson", package = "sfdep") # read in data df <- read.csv(df_fp, colClasses = c("character", "character", "integer", "double", "Date")) geo <- sf::st_read(geo_fp) # Create spacetime object called `bos` bos <- spacetime(df, geo, .loc_col = ".region_id", .time_col = "time_period") # conduct EHSA ehsa <- emerging_hotspot_analysis( x = bos, .var = "value", k = 1, nsim = 9 ) ehsa }
if (requireNamespace("Kendall")) { df_fp <- system.file("extdata", "bos-ecometric.csv", package = "sfdep") geo_fp <- system.file("extdata", "bos-ecometric.geojson", package = "sfdep") # read in data df <- read.csv(df_fp, colClasses = c("character", "character", "integer", "double", "Date")) geo <- sf::st_read(geo_fp) # Create spacetime object called `bos` bos <- spacetime(df, geo, .loc_col = ".region_id", .time_col = "time_period") # conduct EHSA ehsa <- emerging_hotspot_analysis( x = bos, .var = "value", k = 1, nsim = 9 ) ehsa }
Find xj
values given a numeric vector, x
, and neighbors list, nb
.
find_xj(x, nb)
find_xj(x, nb)
x |
a vector of any class |
nb |
a |
A list of length x
where each element is a numeric vector with the same length as the corresponding element in nb
.
nb <- st_contiguity(sf::st_geometry(guerry)) xj <- find_xj(guerry$crime_prop, nb) xj[1:3]
nb <- st_contiguity(sf::st_geometry(guerry)) xj <- find_xj(guerry$crime_prop, nb) xj[1:3]
Compute Geary's C
global_c(x, nb, wt, allow_zero = NULL)
global_c(x, nb, wt, allow_zero = NULL)
x |
A numeric vector. |
nb |
a neighbor list object for example as created by |
wt |
a weights list as created by |
allow_zero |
If |
a list with two names elements C
and K
returning the value of Geary's C and sample kurtosis respectively.
Other global_c:
global_c_perm()
,
global_c_test()
nb <- guerry_nb$nb wt <- guerry_nb$wt x <- guerry_nb$crime_pers global_c(x, nb, wt)
nb <- guerry_nb$nb wt <- guerry_nb$wt x <- guerry_nb$crime_pers global_c(x, nb, wt)
Global C Permutation Test
global_c_perm( x, nb, wt, nsim = 499, alternative = "greater", allow_zero = NULL, ... )
global_c_perm( x, nb, wt, nsim = 499, alternative = "greater", allow_zero = NULL, ... )
x |
A numeric vector. |
nb |
a neighbor list object for example as created by |
wt |
a weights list as created by |
nsim |
number of simulations to run. |
alternative |
default |
allow_zero |
If |
... |
additional arguments passed to |
an object of classes htest
and mc.sim
Other global_c:
global_c()
,
global_c_test()
geo <- sf::st_geometry(guerry) nb <- st_contiguity(geo) wt <- st_weights(nb) x <- guerry$crime_pers global_c_perm(x, nb, wt)
geo <- sf::st_geometry(guerry) nb <- st_contiguity(geo) wt <- st_weights(nb) x <- guerry$crime_pers global_c_perm(x, nb, wt)
Global C Test
global_c_test(x, nb, wt, randomization = TRUE, allow_zero = NULL, ...)
global_c_test(x, nb, wt, randomization = TRUE, allow_zero = NULL, ...)
x |
A numeric vector. |
nb |
a neighbor list object for example as created by |
wt |
a weights list as created by |
randomization |
default |
allow_zero |
If |
... |
additional arguments passed to |
an htest
object
Other global_c:
global_c()
,
global_c_perm()
geo <- sf::st_geometry(guerry) nb <- st_contiguity(geo) wt <- st_weights(nb) x <- guerry$crime_pers global_c_test(x, nb, wt)
geo <- sf::st_geometry(guerry) nb <- st_contiguity(geo) wt <- st_weights(nb) x <- guerry$crime_pers global_c_test(x, nb, wt)
Calculate the Global Colocation Quotient (CLQ) for a categorical variable using simulation based significance testing.
global_colocation(A, nb, nsim = 99)
global_colocation(A, nb, nsim = 99)
A |
a character or factor vector. |
nb |
a neighbors list e.g. created by |
nsim |
default |
The CLQ is defined as . The numerator identifies the observed proportion of same-category neighbors while the denominator contains the expected proportion of same-category neighbors under the assumption of no spatial association. Thus the CLQ is just a ratio of observed to expected.
Inference is done using conditional permutation as suggested by Anselin 1995 where a number of replicates are created. The observed values are compared to the replicates and a the simulated p-value is the proportion of cases where the observed is more extreme as compared to replicate. The simulated p-value returns the lower p-value of either tail.
Given that the CLQ is a ratio of the observed to expected, we interpret values larger than one to mean that there is more colocation than to be expected under the null hypothesis of no spatial association. When the value is smaller than 0, we interpret it to mean that there is less colocation than expected under the null.
A list of two elements CLQ
and p_sim
containing the observed colocation quotient and the simulated p-value respectively.
Leslie, T.F. and Kronenfeld, B.J. (2011), The Colocation Quotient: A New Measure of Spatial Association Between Categorical Subsets of Points. Geographical Analysis, 43: 306-326. doi:10.1111/j.1538-4632.2011.00821.x
A <- guerry$main_city nb <- st_contiguity(sf::st_geometry(guerry)) global_colocation(A, nb, 49)
A <- guerry$main_city nb <- st_contiguity(sf::st_geometry(guerry)) global_colocation(A, nb, 49)
Getis-Ord Global G
global_g_test(x, nb, wt, alternative = "greater", allow_zero = NULL, ...)
global_g_test(x, nb, wt, alternative = "greater", allow_zero = NULL, ...)
x |
A numeric vector. |
nb |
a neighbor list object for example as created by |
wt |
a weights list as created by |
alternative |
default |
allow_zero |
If |
... |
additional methods passed to |
an htest
object
geo <- sf::st_geometry(guerry) nb <- st_contiguity(geo) wt <- st_weights(nb, style = "B") x <- guerry$crime_pers global_g_test(x, nb, wt)
geo <- sf::st_geometry(guerry) nb <- st_contiguity(geo) wt <- st_weights(nb, style = "B") x <- guerry$crime_pers global_g_test(x, nb, wt)
Calculate global join count measure for a categorical variable.
global_jc_perm( fx, nb, wt, alternative = "greater", nsim = 499, allow_zero = FALSE, ... ) global_jc_test(fx, nb, wt, alternative = "greater", allow_zero = NULL, ...) tally_jc(fx, nb, wt, allow_zero = TRUE, ...)
global_jc_perm( fx, nb, wt, alternative = "greater", nsim = 499, allow_zero = FALSE, ... ) global_jc_test(fx, nb, wt, alternative = "greater", allow_zero = NULL, ...) tally_jc(fx, nb, wt, allow_zero = TRUE, ...)
fx |
a factor or character vector of the same length as nb. |
nb |
a neighbor list object for example as created by |
wt |
a weights list as created by |
alternative |
default |
nsim |
number of simulations to run. |
allow_zero |
If |
... |
additional arguments passed to methods |
global_jc_perm()
implements the monte-carlo based join count using spdep::joincount.mc()
global_jc_test()
implements the traditional BB join count statistic using spdep::joincount.test()
tally_jc()
calculated join counts for a variable fx
and returns a data.frame using spdep::joincount.multi()
an object of class jclist
which is a list where each element is of class htest
and mc.sim
.
geo <- sf::st_geometry(guerry) nb <- st_contiguity(geo) wt <- st_weights(nb, style = "B") fx <- guerry$region global_jc_perm(fx, nb, wt) global_jc_test(fx, nb, wt) tally_jc(fx, nb, wt)
geo <- sf::st_geometry(guerry) nb <- st_contiguity(geo) wt <- st_weights(nb, style = "B") fx <- guerry$region global_jc_perm(fx, nb, wt) global_jc_test(fx, nb, wt) tally_jc(fx, nb, wt)
Calculate Global Moran's I
global_moran(x, nb, wt, na_ok = FALSE, ...)
global_moran(x, nb, wt, na_ok = FALSE, ...)
x |
A numeric vector. |
nb |
a neighbor list object for example as created by |
wt |
a weights list as created by |
na_ok |
default |
... |
additional arguments passed to |
an htest
object
Other global_moran:
global_moran_bv()
,
global_moran_perm()
,
global_moran_test()
,
local_moran_bv()
nb <- guerry_nb$nb wt <- guerry_nb$wt x <- guerry_nb$crime_pers moran <- global_moran(x, nb, wt)
nb <- guerry_nb$nb wt <- guerry_nb$wt x <- guerry_nb$crime_pers moran <- global_moran(x, nb, wt)
Given two continuous numeric variables, calculate the bivariate Moran's I. See details for more.
global_moran_bv(x, y, nb, wt, nsim = 99, scale = TRUE)
global_moran_bv(x, y, nb, wt, nsim = 99, scale = TRUE)
x |
a numeric vector of same length as |
y |
a numeric vector of same length as |
nb |
a neighbor list object for example as created by |
wt |
a weights list as created by |
nsim |
the number of simulations to run. |
scale |
default |
The Global Bivariate Moran is defined as
It is important to note that this is a measure of autocorrelation of X with the spatial lag of Y. As such, the resultant measure may overestimate the amount of spatial autocorrelation which may be a product of the inherent correlation of X and Y.
an object of class boot
Other global_moran:
global_moran()
,
global_moran_perm()
,
global_moran_test()
,
local_moran_bv()
x <- guerry_nb$crime_pers y <- guerry_nb$wealth nb <- guerry_nb$nb wt <- guerry_nb$wt global_moran_bv(x, y, nb, wt)
x <- guerry_nb$crime_pers y <- guerry_nb$wealth nb <- guerry_nb$nb wt <- guerry_nb$wt global_moran_bv(x, y, nb, wt)
Global Moran Permutation Test
global_moran_perm(x, nb, wt, alternative = "two.sided", nsim = 499, ...)
global_moran_perm(x, nb, wt, alternative = "two.sided", nsim = 499, ...)
x |
A numeric vector. |
nb |
a neighbor list object for example as created by |
wt |
a weights list as created by |
alternative |
default |
nsim |
number of simulations to run. |
... |
additional arguments passed to |
an object of classes htest
, and mc.sim
.
Other global_moran:
global_moran()
,
global_moran_bv()
,
global_moran_test()
,
local_moran_bv()
nb <- guerry_nb$nb wt <- guerry_nb$wt x <- guerry_nb$crime_pers moran <- global_moran_perm(x, nb, wt) moran
nb <- guerry_nb$nb wt <- guerry_nb$wt x <- guerry_nb$crime_pers moran <- global_moran_perm(x, nb, wt) moran
Global Moran Test
global_moran_test( x, nb, wt, alternative = "greater", randomization = TRUE, ... )
global_moran_test( x, nb, wt, alternative = "greater", randomization = TRUE, ... )
x |
A numeric vector. |
nb |
a neighbor list object for example as created by |
wt |
a weights list as created by |
alternative |
default |
randomization |
default |
... |
additional arguments passed to |
an object of class htest
Other global_moran:
global_moran()
,
global_moran_bv()
,
global_moran_perm()
,
local_moran_bv()
nb <- guerry_nb$nb wt <- guerry_nb$wt x <- guerry_nb$crime_pers global_moran_test(x, nb, wt)
nb <- guerry_nb$nb wt <- guerry_nb$wt x <- guerry_nb$crime_pers global_moran_test(x, nb, wt)
This dataset has been widely used to demonstrate geospatial methods and techniques. As such it is useful for inclusion to this R package for the purposes of example. The dataset in this package is modified from Guerry by Michael Friendly.
guerry guerry_nb
guerry guerry_nb
An object of class sf
(inherits from tbl_df
, tbl
, data.frame
) with 85 rows and 27 columns.
guerry
an sf object with 85 observations and 27 variables. guerry_nb
has 2 additional variables created by sfdep
.
guerry
and guerry_nb
objects are sf class objects. These are polygons of the boundaries of France (excluding Corsica) as they were in 1830.
Guerry::gfrance85
Includes observed region in list of own neighbors. For some neighbor lists, it is important to include the ith observation (or self) in the neighbors list, particularly for kernel weights.
include_self(nb) remove_self(nb)
include_self(nb) remove_self(nb)
nb |
an object of class |
An object of class nb
.
nb <- st_contiguity(guerry) self_included <- include_self(nb) self_included remove_self(self_included)
nb <- st_contiguity(guerry) self_included <- include_self(nb) self_included remove_self(self_included)
Given an object with class spacetime
, determine if it is a spacetime cube.
If the time-series is is irregular a warning is emitted
(see validate_spacetime()
for more on the restrictions on the time column.
is_spacetime_cube(x, ...)
is_spacetime_cube(x, ...)
x |
a spacetime object |
... |
unused |
A spacetime object is a spacetime cube when it contains a regular time-series representation of each geometry. That is, only one observation for at each time period per geography is present.
The number of rows in a spacetime cube is the number of geographies multiplied by the number of time periods. For example if there are 10 locations and 20 time periods, the number of rows must be 200.
A logical scalar.
is_spacetime_cube()
runs a number of checks that to ensure that the provided
object is in fact a spacetime cube. It checks that:
the number of rows is equal to the number of locations multiplied by the number of time periods
each time period has an equal number of observations
each location has an equal number of observations
each combination of time period and location has only one observation
that the time-series is regular
if (requireNamespace("zoo", quietly = TRUE)) { df_fp <- system.file("extdata", "bos-ecometric.csv", package = "sfdep") geo_fp <- system.file("extdata", "bos-ecometric.geojson", package = "sfdep") # read in data df <- read.csv( df_fp, colClasses = c("character", "character", "integer", "double", "Date") ) geo <- sf::st_read(geo_fp) # Create spacetime object called `bos` bos <- spacetime(df, geo, .loc_col = ".region_id", .time_col = "time_period") is_spacetime_cube(bos) is_spacetime_cube(bos[round(runif(1000, 0, nrow(bos))),]) is_spacetime_cube(guerry) }
if (requireNamespace("zoo", quietly = TRUE)) { df_fp <- system.file("extdata", "bos-ecometric.csv", package = "sfdep") geo_fp <- system.file("extdata", "bos-ecometric.geojson", package = "sfdep") # read in data df <- read.csv( df_fp, colClasses = c("character", "character", "integer", "double", "Date") ) geo <- sf::st_read(geo_fp) # Create spacetime object called `bos` bos <- spacetime(df, geo, .loc_col = ".region_id", .time_col = "time_period") is_spacetime_cube(bos) is_spacetime_cube(bos[round(runif(1000, 0, nrow(bos))),]) is_spacetime_cube(guerry) }
The Local Geary is a local adaptation of Geary's C statistic of spatial autocorrelation. The Local Geary uses squared differences to measure dissimilarity unlike the Local Moran. Low values of the Local Geary indicate positive spatial autocorrelation and large refers to negative spatial autocorrelation. Inference for the Local Geary is based on a permutation approach which compares the observed value to the reference distribution under spatial randomness. The Local Geary creates a pseudo p-value. This is not an analytical p-value and is based on the number of permutations and as such should be used with care.
local_c(x, nb, wt, ...) local_c_perm(x, nb, wt, nsim = 499, alternative = "two.sided", ...)
local_c(x, nb, wt, ...) local_c_perm(x, nb, wt, nsim = 499, alternative = "two.sided", ...)
x |
a numeric vector, or list of numeric vectors of equal length. |
nb |
a neighbor list |
wt |
a weights list |
... |
other arguments passed to |
nsim |
The number of simulations used to generate reference distribution. |
alternative |
A character defining the alternative hypothesis. Must be one of "two.sided", "less" or "greater". |
The Local Geary can be extended to a multivariate context. When x
is a numeric vector, the univariate Local Geary will be calculated. To calculate the multivariate Local Moran provide either a list or a matrix. When x
is a list, each element must be a numeric vector of the same length and of the same length as the neighbours in listw
. In the case that x
is a matrix the number of rows must be the same as the length of the neighbours in listw
.
While not required in the univariate context, the standardized Local Geary is calculated. The multivariate Local Geary is always standardized.
The univariate Local Geary is calculated as and the multivariate Local Geary is calculated as
as described in Anselin (2019).
These functions are based on the implementations of the local Geary statistic in the development version of spdep. They are based on spdep::localC and spdep::localC_perm.
spdep::localC_perm and thus local_c_perm utilize a conditional permutation approach to approximate a reference distribution where each observation i
is held fixed, randomly samples neighbors, and calculated the local C statistic for that tuple (ci
). This is repeated nsim
times. From the simulations 3 different types of p-values are calculated—all of which have their potential flaws. So be extra judicious with using p-values to make conclusions.
p_ci
: utilizes the sample mean and standard deviation. The p-value is then calculated using pnorm()
–assuming a normal distribution which isn't always true.
p_ci_sim
: uses the rank of the observed statistic.
p_folded_sim
: follows the pysal implementation where p-values are in the range of [0, 0.5]. This excludes 1/2 of all p-values and should be used with caution.
a data.frame
with columns
ci
: Local Geary statistic
e_ci
: expected value of the Local Geary based on permutations
z_ci
: standard deviation based on permutations
var_ci
: variance based on permutations
p_ci
: p-value based on permutation sample standard deviation and means
p_ci_sim
: p-value based on rank of observed statistic
p_folded_sim
: p-value based on the implementation of Pysal which always assumes a two-sided test taking the minimum possible p-value
skewness
: sample skewness
kurtosis
: sample kurtosis
Josiah Parry, [email protected]
Anselin, L. (1995), Local Indicators of Spatial Association—LISA. Geographical Analysis, 27: 93-115. doi:10.1111/j.1538-4632.1995.tb00338.x
Anselin, L. (2019), A Local Indicator of Multivariate Spatial Association: Extending Geary's c. Geogr Anal, 51: 133-150. doi:10.1111/gean.12164
local_c_perm(guerry_nb$crime_pers, guerry_nb$nb, guerry_nb$wt)
local_c_perm(guerry_nb$crime_pers, guerry_nb$nb, guerry_nb$wt)
The local indicator of the colocation quotient (LCLQ) is a Local Indicator of Spatial Association (LISA) that evaluates if a given observation's subcategory in A is colocated with subcategories in B. Like the CLQ, the LCLQ provides insight into the asymmetric relationships between subcategories of A and B (where B can also equal A) but at the local level.
The LCLQ is defined using Gaussian kernel weights and an adaptive bandwidth (see st_kernel_weights()
). However, any type of weights list can be used. Kernel weights are used to introduce a decay into the calculation of the CLQ. This ensures that points nearer to the focal point have more influence than those that are more distant.
local_colocation(A, B, nb, wt, nsim)
local_colocation(A, B, nb, wt, nsim)
A |
a character or factor vector. |
B |
a character or factor vector. |
nb |
a neighbors list e.g. created by |
wt |
a weights list. Recommended that it is a Gaussian kernel weights list using an adaptive bandwidth e.g. created by |
nsim |
default |
The LCLQ is defined as where
. And the weights matrix, wij, uses adaptive bandwidth Gaussian kernel weights.
LCLQ is only calculated for those subcategories which are present in the neighbor list. If a subcategory is not present, then the resultant LCLQ and simulated p-value will be NA
.
a data frame with as many rows as observations in A and two times as many columns as unique values in B. Columns contain each unique value of B as well as the simulated p-value for each value of B.
Fahui Wang, Yujie Hu, Shuai Wang & Xiaojuan Li (2017) Local Indicator of Colocation Quotient with a Statistical Significance Test: Examining Spatial Association of Crime and Facilities, The Professional Geographer, 69:1, 22-31, doi:10.1080/00330124.2016.1157498
A <- guerry$main_city B <- guerry$region geo <- sf::st_centroid(sf::st_geometry(guerry)) nb <- include_self(st_knn(geo, 5)) wt <- st_kernel_weights(nb, geo, "gaussian", adaptive = TRUE) res <- local_colocation(A, B, nb, wt, 9) tail(res)
A <- guerry$main_city B <- guerry$region geo <- sf::st_centroid(sf::st_geometry(guerry)) nb <- include_self(st_knn(geo, 5)) wt <- st_kernel_weights(nb, geo, "gaussian", adaptive = TRUE) res <- local_colocation(A, B, nb, wt, 9) tail(res)
Calculate the local Geary statistic for a given variable.
local_g(x, nb, wt, alternative = "two.sided", ...) local_g_perm(x, nb, wt, nsim = 499, alternative = "two.sided", ...)
local_g(x, nb, wt, alternative = "two.sided", ...) local_g_perm(x, nb, wt, nsim = 499, alternative = "two.sided", ...)
x |
A numeric vector. |
nb |
a neighbor list object for example as created by |
wt |
a weights list as created by |
alternative |
default |
... |
methods passed to |
nsim |
The number of simulations to run. |
a data.frame
with columns:
gi
: the observed statistic
cluster
: factor variable with two levels classification high or low
e_gi
: the permutation sample mean
var_gi
: the permutation sample variance
std_dev
: standard deviation of the Gi statistic
p_value
: the p-value using sample mean and standard deviation
p_folded_sim
: p-value based on the implementation of Pysal which always assumes a two-sided test taking the minimum possible p-value
skewness
: sample skewness
kurtosis
: sample kurtosis
x <- guerry$crime_pers nb <- st_contiguity(guerry) wt <- st_weights(nb) res <- local_g_perm(x, nb, wt) head(res)
x <- guerry$crime_pers nb <- st_contiguity(guerry) wt <- st_weights(nb) res <- local_g_perm(x, nb, wt) head(res)
Calculate the local Gi* statistic.
local_gstar(x, nb, wt, alternative = "two.sided", ...) local_gstar_perm(x, nb, wt, nsim = 499, alternative = "two.sided", ...)
local_gstar(x, nb, wt, alternative = "two.sided", ...) local_gstar_perm(x, nb, wt, nsim = 499, alternative = "two.sided", ...)
x |
A numeric vector. |
nb |
a neighbor list object for example as created by |
wt |
a weights list as created by |
alternative |
default |
... |
methods passed to |
nsim |
The number of simulations to run. |
a data.frame
with columns:
gi
: the observed statistic
e_gi
: the permutation sample mean
var_gi
: the permutation sample variance
p_value
: the p-value using sample mean and standard deviation
p_folded_sim
: p-value based on the implementation of Pysal which always assumes a two-sided test taking the minimum possible p-value
skewness
: sample skewness
kurtosis
: sample kurtosis
nb <- st_contiguity(guerry) wt <- st_weights(nb) x <- guerry$crime_pers res <- local_gstar_perm(x, nb, wt) head(res) res <- local_gstar(x, nb, wt) head(res)
nb <- st_contiguity(guerry) wt <- st_weights(nb) x <- guerry$crime_pers res <- local_gstar_perm(x, nb, wt) head(res) res <- local_gstar(x, nb, wt) head(res)
Bivariate local join count
local_jc_bv(x, z, nb, wt, nsim = 499)
local_jc_bv(x, z, nb, wt, nsim = 499)
x |
a binary variable either numeric or logical |
z |
a binary variable either numeric or logical |
nb |
a neighbors list object. |
wt |
default |
nsim |
the number of conditional permutation simulations |
a data.frame
with two columns join_count
and p_sim
and number of rows equal to the length of arguments x
, z
, nb
, and wt
.
x <- as.integer(guerry$infants > 23574) z <- as.integer(guerry$donations > 10973) nb <- st_contiguity(guerry) wt <- st_weights(nb, style = "B") local_jc_bv(x, z, nb, wt)
x <- as.integer(guerry$infants > 23574) z <- as.integer(guerry$donations > 10973) nb <- st_contiguity(guerry) wt <- st_weights(nb, style = "B") local_jc_bv(x, z, nb, wt)
The univariate local join count statistic is used to identify clusters of rarely occurring binary variables. The binary variable of interest should occur less than half of the time.
local_jc_uni( fx, chosen, nb, wt = st_weights(nb, style = "B"), nsim = 499, alternative = "two.sided", iseed = NULL )
local_jc_uni( fx, chosen, nb, wt = st_weights(nb, style = "B"), nsim = 499, alternative = "two.sided", iseed = NULL )
fx |
a binary variable either numeric or logical |
chosen |
a scalar character containing the level of |
nb |
a neighbors list object. |
wt |
default |
nsim |
the number of conditional permutation simulations |
alternative |
default |
iseed |
default NULL, used to set the seed; the output will only be reproducible if the count of CPU cores across which computation is distributed is the same |
The local join count statistic requires a binary weights list which can be generated with st_weights(nb, style = "B")
. Additionally, ensure that the binary variable of interest is rarely occurring in no more than half of observations.
P-values are estimated using a conditional permutation approach. This creates a reference distribution from which the observed statistic is compared. For more see Geoda Glossary.
Calls spdep::local_joincount_uni()
.
a data.frame
with two columns join_count
and p_sim
and number of rows equal to the length of arguments x
, nb
, and wt
.
if (requireNamespace("dplyr", quietly = TRUE)) { res <- dplyr::transmute( guerry, top_crime = as.factor(crime_prop > 9000), nb = st_contiguity(geometry), wt = st_weights(nb, style = "B"), jc = local_jc_uni(top_crime, "TRUE", nb, wt)) tidyr::unnest(res, jc) }
if (requireNamespace("dplyr", quietly = TRUE)) { res <- dplyr::transmute( guerry, top_crime = as.factor(crime_prop > 9000), nb = st_contiguity(geometry), wt = st_weights(nb, style = "B"), jc = local_jc_uni(top_crime, "TRUE", nb, wt)) tidyr::unnest(res, jc) }
Moran's I is calculated for each polygon based on the neighbor and weight lists.
local_moran(x, nb, wt, alternative = "two.sided", nsim = 499, ...)
local_moran(x, nb, wt, alternative = "two.sided", nsim = 499, ...)
x |
A numeric vector. |
nb |
a neighbor list object for example as created by |
wt |
a weights list as created by |
alternative |
default |
nsim |
The number of simulations to run. |
... |
See |
local_moran()
calls spdep::localmoran_perm()
and calculates the Moran I for each polygon. As well as provide simulated p-values.
a data.frame
containing the columns ii
, eii
, var_ii
, z_ii
, p_ii
, p_ii_sim
, and p_folded_sim
. For more details please see spdep::localmoran_perm()
.
Other stats:
st_lag()
local_moran(guerry_nb$crime_pers, guerry_nb$nb, guerry_nb$wt)
local_moran(guerry_nb$crime_pers, guerry_nb$nb, guerry_nb$wt)
Given two continuous numeric variables, calculate the bivariate Local Moran's I.
local_moran_bv(x, y, nb, wt, nsim = 499)
local_moran_bv(x, y, nb, wt, nsim = 499)
x |
a numeric vector of same length as |
y |
a numeric vector of same length as |
nb |
a neighbor list object for example as created by |
wt |
a weights list as created by |
nsim |
the number of simulations to run. |
The Bivariate Local Moran, like its global counterpart, evaluates the value of x at observation i with its spatial neighbors' value of y. The value of
is just xi * Wyi. Or, in simpler words the local bivariate Moran is the result of multiplying x by the spatial lag of y. Formally it is defined as
a data.frame
containing two columns Ib
and p_sim
containing the local bivariate Moran's I and simulated p-values respectively.
Local Spatial Autocorrelation (3): Multivariate Local Spatial Autocorrelation, Luc Anselin
Other global_moran:
global_moran()
,
global_moran_bv()
,
global_moran_perm()
,
global_moran_test()
x <- guerry_nb$crime_pers y <- guerry_nb$wealth nb <- guerry_nb$nb wt <- guerry_nb$wt local_moran_bv(x, y, nb, wt)
x <- guerry_nb$crime_pers y <- guerry_nb$wealth nb <- guerry_nb$nb wt <- guerry_nb$wt local_moran_bv(x, y, nb, wt)
Local spatial heteroscedacity
losh(x, nb, wt, a = 2, ...) losh_perm(x, nb, wt, a = 2, nsim = 499, ...)
losh(x, nb, wt, a = 2, ...) losh_perm(x, nb, wt, a = 2, nsim = 499, ...)
x |
a numeric vector. |
nb |
a neighbor list for example created by |
wt |
a weights list for example created by |
a |
the exponent applied to the local residuals |
... |
methods passed to spdep::LOSH |
nsim |
number of simulations to run |
a data.frame
with columns
hi
: the observed statistic
e_hi
: the sample average
var_hi
: the sample variance
z_hi
the approximately Chi-square distributed test statistic
x_bar_i
: the local spatially weight mean for observation i
ei
: residuals
nb <- st_contiguity(guerry) wt <- st_weights(nb) x <- guerry$crime_pers losh(x, nb, wt) losh(x, nb, wt, var_hi = FALSE) losh_perm(x, nb, wt, nsim = 49)
nb <- st_contiguity(guerry) wt <- st_weights(nb) x <- guerry$crime_pers losh(x, nb, wt) losh(x, nb, wt, var_hi = FALSE) losh_perm(x, nb, wt, nsim = 49)
Implements the Local Neighbor Match Test as described in Tobler's Law in a Multivariate World (Anselin and Li, 2020).
nb_match_test( x, nb, wt = st_weights(nb), k = 10, nsim = 499, scale = TRUE, .method = "euclidian", .p = 2 )
nb_match_test( x, nb, wt = st_weights(nb), k = 10, nsim = 499, scale = TRUE, .method = "euclidian", .p = 2 )
x |
a numeric vector or a list of numeric vectors of equal length. |
nb |
a neighbor list object for example as created by |
wt |
a weights list as created by |
k |
the number of neighbors to identify in attribute space. Should be the same as number of neighbors provided in st_knn. |
nsim |
the number of simulations to run for calculating the simulated p-value. |
scale |
default |
.method |
default |
.p |
default 2. The power of Minkowski distance passed to the |
a data.frame
with columns
n_shared
(integer): the number of shared neighbors between geographic and attribute space
nb_matches
(list): matched neighbor indexes. Each element is an integer vector of same length as the ith observation of n_shared
knn_nb
(list): the neighbors in attribute space
probability
(numeric): the geometric probability of observing the number of matches
p_sim
(numeric): a folded simulated p-value
if (requireNamespace("dplyr", quietly = TRUE)) { library(magrittr) guerry %>% dplyr::transmute(nb = st_knn(geometry, k = 10), nmt = nb_match_test(list(crime_pers, literacy, suicides), nb, nsim = 999)) %>% tidyr::unnest(nmt) }
if (requireNamespace("dplyr", quietly = TRUE)) { library(magrittr) guerry %>% dplyr::transmute(nb = st_knn(geometry, k = 10), nmt = nb_match_test(list(crime_pers, literacy, suicides), nb, nsim = 999)) %>% tidyr::unnest(nmt) }
Perform set operations element-wise on two lists of equal length.
nb_union(x, y) nb_intersect(x, y) nb_setdiff(x, y)
nb_union(x, y) nb_intersect(x, y) nb_setdiff(x, y)
x |
list of class |
y |
list of class |
nb_union()
returns the union of elements in each element of x and y
nb_intersect()
returns the intersection of elements in each element of x and y
nb_setdiff()
returns the difference of elements in each element of x and y
A list of class nb
nb <- st_contiguity(guerry$geometry) nb_knn <- st_knn(guerry$geometry, k = 3) nb_setdiff(nb, nb_knn) nb_union(nb, nb_knn) nb_intersect(nb, nb_knn)
nb <- st_contiguity(guerry$geometry) nb_knn <- st_knn(guerry$geometry, k = 3) nb_setdiff(nb, nb_knn) nb_union(nb, nb_knn) nb_intersect(nb, nb_knn)
Given a tidygraph object, create a list column of edge data for each node in the node context.
node_get_nbs() node_get_edge_list() node_get_edge_col(edges, .var)
node_get_nbs() node_get_edge_list() node_get_edge_col(edges, .var)
edges |
an edge list as created by |
.var |
the quoted name of a column in the edge context. |
node_get_nbs()
: creates a neighbor list in the nodes context based on the adjacency list. This returns a nb
class object with the neighboring nodes.
Uses igraph::get.adjlist()
node_get_edge_list()
: creates an edge list. The edge list contains the row index of the edge relationships in the edge context for each node.
Uses igraph::get.adjedgelist()
.
node_get_edge_col()
: creates a list column containing edge attributes as a list column in the node context (much like find_xj()
).
Uses igraph::get.edge.attribute()
A list column
if (interactive()) { net <- sfnetworks::as_sfnetwork( sfnetworks::roxel ) dplyr::mutate( net, nb = node_get_nbs(), edges = node_get_edge_list(), types = node_get_edge_col(edges, "type") ) }
if (interactive()) { net <- sfnetworks::as_sfnetwork( sfnetworks::roxel ) dplyr::mutate( net, nb = node_get_nbs(), edges = node_get_edge_list(), types = node_get_edge_col(edges, "type") ) }
Calculate the pairwise colocation quotient (CLQ) for two categorical variables using conditional permutation.
pairwise_colocation(A, B, nb, nsim = 99)
pairwise_colocation(A, B, nb, nsim = 99)
A |
a character or factor vector. |
B |
a character or factor vector. |
nb |
a neighbors list e.g. created by |
nsim |
default |
The pairwise CLQ is used to test if there is a spatial directional association between subcategories of two vectors A
and B
. Compared to the cross-K metric and the join count statistic, the pairwise CLQ can elucidate the presence of an asymmetric relationship between subcategories of A and B. A and B can either be separate categorical vectors or the same categorical vector.
"The null hypothesis for a CLQ-based analysis is 'given the clustering of the joint population, there is no spatial association between pairs of categorical subsets.'"
The pairwise colocation quotient is defined as "the ratio of observed to expected proportions of B among A's nearest neighbors. Formally this is given by
" where
.
Inference is done using conditional permutation as suggested by Anselin 1995 where a number of replicates are created. The observed values are compared to the replicates and a the simulated p-value is the proportion of cases where the observed is more extreme as compared to replicate. The simulated p-value returns the lower p-value of either tail.
Given that the CLQ is a ratio of the observed to expected, we interpret values larger than one to mean that there is more colocation than to be expected under the null hypothesis of no spatial association. When the value is smaller than 0, we interpret it to mean that there is less colocation than expected under the null.
A matrix where the rownames are the unique values of A and the column names are the unique values of B and their simulated p-values in the form of p_sim_{B}
.
A <- guerry$main_city B <- guerry$region nb <- st_knn(sf::st_geometry(guerry), 5) pairwise_colocation(B, A, nb) pairwise_colocation(B, B, nb, 199)
A <- guerry$main_city B <- guerry$region nb <- st_knn(sf::st_geometry(guerry), 5) pairwise_colocation(B, A, nb) pairwise_colocation(B, B, nb, 199)
Calculate the percentage of non-zero neighbors in a neighbor list.
pct_nonzero(nb)
pct_nonzero(nb)
nb |
a neighbor list object |
a scalar double
nb <- st_contiguity(guerry) pct_nonzero(nb)
nb <- st_contiguity(guerry) pct_nonzero(nb)
Given a neighbor and weight list, create a listw
object.
recreate_listw(nb, wt)
recreate_listw(nb, wt)
nb |
a neighbor list object for example as created by |
wt |
a weights list as created by |
a listw
object
recreate_listw(guerry_nb$nb, guerry_nb$wt)
recreate_listw(guerry_nb$nb, guerry_nb$wt)
geometry
to data
Set a column from the geometry
context of a spacetime object to the data
context.
set_col(x, .from_geo, .to_data = .from_geo) set_wts(x, .wt_col = "wt") set_nbs(x, .nb_col = "nb")
set_col(x, .from_geo, .to_data = .from_geo) set_wts(x, .wt_col = "wt") set_nbs(x, .nb_col = "nb")
x |
a spacetime object |
.from_geo |
the name of the column in the |
.to_data |
the name of the new variable to create in the |
.wt_col |
the name of the weights column in the |
.nb_col |
the name of neighbor column in the |
These functions will reorder the spacetime object to ensure that it is ordered
correctly based on the location time columns in the geometry
context defined
by the loc_col
and time_col
attributes respectively.
set_wts()
and set_nbs()
create a new column in the data context with the
same name as the column in the geometry context. If a different name is desired
use set_col()
A spacetime object with an active data context and a new column from the geometry context.
if (interactive()) { df_fp <- system.file("extdata", "bos-ecometric.csv", package = "sfdep") geo_fp <- system.file("extdata", "bos-ecometric.geojson", package = "sfdep") # read in data df <- read.csv( df_fp, colClasses = c("character", "character", "integer", "double", "Date") ) geo <- sf::st_read(geo_fp) # Create spacetime object called `bos` bos <- spacetime(df, geo, .loc_col = ".region_id", .time_col = "time_period") bos <- activate(bos, "geometry") bos$nb <- st_contiguity(bos) bos$wt <- st_weights(bos$nb) bos$card <- st_cardinalties(bos$nb) set_nbs(bos) set_wts(bos) set_col(bos, "card") set_col(bos, "card", "cardinalities") }
if (interactive()) { df_fp <- system.file("extdata", "bos-ecometric.csv", package = "sfdep") geo_fp <- system.file("extdata", "bos-ecometric.geojson", package = "sfdep") # read in data df <- read.csv( df_fp, colClasses = c("character", "character", "integer", "double", "Date") ) geo <- sf::st_read(geo_fp) # Create spacetime object called `bos` bos <- spacetime(df, geo, .loc_col = ".region_id", .time_col = "time_period") bos <- activate(bos, "geometry") bos$nb <- st_contiguity(bos) bos$wt <- st_weights(bos$nb) bos$card <- st_cardinalties(bos$nb) set_nbs(bos) set_wts(bos) set_col(bos, "card") set_col(bos, "card", "cardinalities") }
spacetime
objectA spacetime object is a collection of a linked data frame and an sf objects. It can be thought of as geography linked to a table that represents those geographies over one or more time periods.
spacetime(.data, .geometry, .loc_col, .time_col, active = "data") new_spacetime(.data, .geometry, .loc_col, .time_col, active = "data") validate_spacetime(.data, .geometry, .loc_col, .time_col) is_spacetime(x, ...) is.spacetime(x, ...)
spacetime(.data, .geometry, .loc_col, .time_col, active = "data") new_spacetime(.data, .geometry, .loc_col, .time_col, active = "data") validate_spacetime(.data, .geometry, .loc_col, .time_col) is_spacetime(x, ...) is.spacetime(x, ...)
.data |
an object with base class |
.geometry |
an |
.loc_col |
the quoted name of the column containing unique location identifiers. Must be present in both |
.time_col |
the quoted name of the column containing time periods must be present |
active |
default |
x |
an object to test |
... |
unused |
Create a spacetime representation of vector data from a data.frame
and an
sf
object with spacetime()
.time_col
must be able to be sorted. As such, .time_col
cannot be a character vector. It must have a base type of (typeof()
) either
double
or integer
—the case in dates or factors respectively. An edge case
exists with POSIXlt
class objects as these can be sorted appropriately but
have a base type of list
.
spacetime()
is a wrapper around new_spacetime()
. Spacetimes are
validated before creation with validate_spacetime()
.
Check if an object is a spacetime object with is_spacetime()
or
is.spacetime()
.
spacetime()
and new_spacetime()
construct spacetime clss objects
validate_spacetime()
returns nothing but will elicit a warning or error if the spacetime object is not validly constructed
is_spacetime()
and is.spacetime()
return a logical scalar indicating if an object inherits the spacetime class
validate_spacetime()
checks both .data
and .geometry
to ensure that
the constructed spacetime object meets minimum requirements.:
.data
inherits the data.frame
class
.geometry
is an sf
object
ensures that .time_col
is of the proper class
ensures there are no missing geometries in .geometry
checks for duplicate geometries
ensures .loc_col
are the same type in .data
and .geometry
lastly informs of missing values in additional columns in .data
df_fp <- system.file("extdata", "bos-ecometric.csv", package = "sfdep") geo_fp <- system.file("extdata", "bos-ecometric.geojson", package = "sfdep") # read in data df <- read.csv( df_fp, colClasses = c("character", "character", "integer", "double", "Date") ) geo <- sf::st_read(geo_fp) bos <- spacetime(df, geo, ".region_id", "year") is_spacetime(bos) bos
df_fp <- system.file("extdata", "bos-ecometric.csv", package = "sfdep") geo_fp <- system.file("extdata", "bos-ecometric.geojson", package = "sfdep") # read in data df <- read.csv( df_fp, colClasses = c("character", "character", "integer", "double", "Date") ) geo <- sf::st_read(geo_fp) bos <- spacetime(df, geo, ".region_id", "year") is_spacetime(bos) bos
Calculates the spatial Gini index for a given numeric vector and neighbor list. Based on the formula provided Rey and Smith (2013).
spatial_gini(x, nb)
spatial_gini(x, nb)
x |
a numeric vector without missing values |
nb |
a neighbor list, for example created with |
The Gini index is a global measure of inequality based on the Lorenz curve. It ranges between 0 and 1 where 0 is perfect equality and 1 is perfect inequality.
The spatial Gini index decomposes the Gini coefficient based on spatial neighbors.
A data frame with columns:
G
: the Gini index
NBG
: the neighbor composition of the Gini coefficient
NG
: the non-neighbor composition of the Gini coefficient
SG
: the Spatial Gini which is equal to
nb <- st_contiguity(guerry) x <- guerry$wealth spatial_gini(x, nb)
nb <- st_contiguity(guerry) x <- guerry$wealth spatial_gini(x, nb)
Update's a spacetime object's number of locations and time periods.
A spacetime object's attributes are sticky and will not change if subsetted
for example by using dplyr::filter()
or dplyr::slice()
. Update the
locations and times of a spacetime object.
spt_update(x, ...)
spt_update(x, ...)
x |
a spacetime object |
... |
unused |
an object of class spacetime with updated attributes
Given geometry and neighbor and weights lists, create an edge list sf
object.
st_as_edges(x, nb, wt) ## S3 method for class 'sf' st_as_edges(x, nb, wt) ## S3 method for class 'sfc' st_as_edges(x, nb, wt)
st_as_edges(x, nb, wt) ## S3 method for class 'sf' st_as_edges(x, nb, wt) ## S3 method for class 'sfc' st_as_edges(x, nb, wt)
x |
object of class |
nb |
a neighbor list. If |
wt |
optional. A weights list as generated by |
Creating an edge list creates a column for each i
position and j
between an observation and their neighbors. You can recreate these values by expanding the nb
and wt
list columns.
library(magrittr) guerry_nb %>% tibble::as_tibble() %>% dplyr::select(nb, wt) %>% dplyr::mutate(i = dplyr::row_number(), .before = 1) %>% tidyr::unnest(c(nb, wt)) #> # A tibble: 420 x 3 #> i nb wt #> <int> <int> <dbl> #> 1 1 36 0.25 #> 2 1 37 0.25 #> 3 1 67 0.25 #> 4 1 69 0.25 #> 5 2 7 0.167 #> 6 2 49 0.167 #> 7 2 57 0.167 #> 8 2 58 0.167 #> 9 2 73 0.167 #> 10 2 76 0.167 #> # i 410 more rows
Returns an sf
object with edges represented as a LINESTRING
.
from
: node index. This is the row position of x
.
to
: node index. This is the neighbor value stored in nb
.
i
: node index. This is the row position of x
.
j
: node index. This is the neighbor value stored in nb
.
wt
: the weight value of j
stored in wt
.
if (requireNamespace("dplyr", quietly = TRUE)) { library(magrittr) guerry %>% dplyr::mutate(nb = st_contiguity(geometry), wt = st_weights(nb)) %>% st_as_edges(nb, wt) }
if (requireNamespace("dplyr", quietly = TRUE)) { library(magrittr) guerry %>% dplyr::mutate(nb = st_contiguity(geometry), wt = st_weights(nb)) %>% st_as_edges(nb, wt) }
Given an sf
or sfc
object and neighbor and weights lists, create an sfnetwork
object.
st_as_graph(x, nb, wt) ## S3 method for class 'sf' st_as_graph(x, nb, wt) ## S3 method for class 'sfc' st_as_graph(x, nb, wt)
st_as_graph(x, nb, wt) ## S3 method for class 'sf' st_as_graph(x, nb, wt) ## S3 method for class 'sfc' st_as_graph(x, nb, wt)
x |
object of class |
nb |
a neighbor list. If |
wt |
optional. A weights list as generated by |
an sfnetwork
object
st_as_nodes()
and st_as_edges()
if (requireNamespace("dplyr", quietly = TRUE)) { library(magrittr) guerry_nb %>% st_as_graph(nb, wt) }
if (requireNamespace("dplyr", quietly = TRUE)) { library(magrittr) guerry_nb %>% st_as_graph(nb, wt) }
Given geometry and a neighbor list, creates an sf
object to be used as nodes in an sfnetworks::sfnetwork()
. If the provided geometry is a polygon, sf::st_point_on_surface()
will be used to create the node point.
st_as_nodes(x, nb) ## S3 method for class 'sf' st_as_nodes(x, nb) ## S3 method for class 'sfc' st_as_nodes(x, nb)
st_as_nodes(x, nb) ## S3 method for class 'sf' st_as_nodes(x, nb) ## S3 method for class 'sfc' st_as_nodes(x, nb)
x |
object of class |
nb |
a neighbor list. If |
st_as_node()
adds a row i
based on the attribute "region.id"
in the nb
object. If the nb
object is created with sfdep
, then the values will always be row indexes.
An object of class sf
with POINT
geometry.
if (requireNamespace("dplyr", quitly = TRUE)) { library(magrittr) guerry %>% dplyr::transmute(nb = st_contiguity(geometry)) %>% st_as_nodes(nb) }
if (requireNamespace("dplyr", quitly = TRUE)) { library(magrittr) guerry %>% dplyr::transmute(nb = st_contiguity(geometry)) %>% st_as_nodes(nb) }
libpysal write that "block contiguity structures are relevant when defining neighbor relations based on membership in a regime. For example, all counties belonging to the same state could be defined as neighbors, in an analysis of all counties in the US."
Source: libpysal
st_block_nb(regime, id = 1:length(regime), diag = FALSE)
st_block_nb(regime, id = 1:length(regime), diag = FALSE)
regime |
a column identifying which spatial regime each element of |
id |
a column identifying unique observations |
diag |
default |
An object of class nb
. When diag = TRUE
the attribute self.included = TRUE
.
id <- guerry$code_dept regime <- guerry$region st_block_nb(regime, id)
id <- guerry$code_dept regime <- guerry$region st_block_nb(regime, id)
Identify the cardinality of a neighbor object. Utilizes spdep::card()
for objects with class nb
, otherwise returns lengths(nb)
.
st_cardinalties(nb)
st_cardinalties(nb)
nb |
A neighbor list object as created by |
an integer vector with the same length as nb
.
Other other:
st_nb_lag()
,
st_nb_lag_cumul()
nb <- st_contiguity(sf::st_geometry(guerry)) st_cardinalties(nb)
nb <- st_contiguity(sf::st_geometry(guerry)) st_cardinalties(nb)
Create a neighbors list where every element is related to every other element. This creates a complete graph.
st_complete_nb(n_elements, diag = FALSE)
st_complete_nb(n_elements, diag = FALSE)
n_elements |
the number of observations to create a neighbors list for |
diag |
default |
A neighbors list representing a complete graph.
st_complete_nb(5)
st_complete_nb(5)
Given an sf geometry of type POLYGON
or MULTIPOLYGON
identify contiguity based neighbors.
st_contiguity(geometry, queen = TRUE, ...)
st_contiguity(geometry, queen = TRUE, ...)
geometry |
an sf or sfc object. |
queen |
default |
... |
additional arguments passed to |
Utilizes spdep::poly2nb()
a list of class nb
Other neighbors:
st_dist_band()
,
st_knn()
# on basic polygons geo <- sf::st_geometry(guerry) st_contiguity(geo) if (requireNamespace("dplyr", quietyl = TRUE)) { # in a pipe library(magrittr) guerry %>% dplyr::mutate(nb = st_contiguity(geometry), .before = 1) }
# on basic polygons geo <- sf::st_geometry(guerry) st_contiguity(geo) if (requireNamespace("dplyr", quietyl = TRUE)) { # in a pipe library(magrittr) guerry %>% dplyr::mutate(nb = st_contiguity(geometry), .before = 1) }
Creates neighbors based on a distance band. By default, creates a distance band with the maximum distance of k-nearest neighbors where k = 1 (the critical threshold) to ensure that there are no regions that are missing neighbors.
st_dist_band(geometry, lower = 0, upper = critical_threshold(geometry), ...)
st_dist_band(geometry, lower = 0, upper = critical_threshold(geometry), ...)
geometry |
An sf or sfc object. |
lower |
The lower threshold of the distance band. It is recommended to keep this as 0. |
upper |
The upper threshold of the distance band. By default is set to a critical threshold using |
... |
Passed to |
a list of class nb
Other neighbors:
st_contiguity()
,
st_knn()
geo <- sf::st_geometry(guerry) st_dist_band(geo, upper = critical_threshold(geo))
geo <- sf::st_geometry(guerry) st_dist_band(geo, upper = critical_threshold(geo))
From a neighbor list and sf geometry column, calculate inverse distance weight.
st_inverse_distance(nb, geometry, scale = 100, alpha = 1)
st_inverse_distance(nb, geometry, scale = 100, alpha = 1)
nb |
a neighbors list object e.g. created by |
geometry |
sf geometry |
scale |
default |
alpha |
default 1. Set to 2 for gravity weights. |
The inverse distance formula is
a list where each element is a numeric vector
Other weights:
st_kernel_weights()
,
st_nb_dists()
,
st_weights()
geo <- sf::st_geometry(guerry) nb <- st_contiguity(geo) wts <- st_inverse_distance(nb, geo) head(wts, 3) wts <- st_inverse_distance(nb, geo, scale = 10000) head(wts, 3)
geo <- sf::st_geometry(guerry) nb <- st_contiguity(geo) wts <- st_inverse_distance(nb, geo) head(wts, 3) wts <- st_inverse_distance(nb, geo, scale = 10000) head(wts, 3)
Create a weights list using a kernel function.
st_kernel_weights( nb, geometry, kernel = "uniform", threshold = critical_threshold(geometry), adaptive = FALSE, self_kernel = FALSE )
st_kernel_weights( nb, geometry, kernel = "uniform", threshold = critical_threshold(geometry), adaptive = FALSE, self_kernel = FALSE )
nb |
an object of class |
geometry |
the geometry an sf object. |
kernel |
One of "uniform", "gaussian", "triangular", "epanechnikov", or "quartic". See kernels for more. |
threshold |
a scaling threshold to be used in calculating |
adaptive |
default |
self_kernel |
default |
By default st_kernel_weight()
utilizes a critical threshold of the maximum neighbor distance using critical_threshold()
. If desired, the critical threshold can be specified manually. The threshold
will be passed to the underlying kernel.
a list where each element is a numeric vector.
Other weights:
st_inverse_distance()
,
st_nb_dists()
,
st_weights()
geometry <- sf::st_geometry(guerry) nb <- st_contiguity(geometry) nb <- include_self(nb) res <- st_kernel_weights(nb, geometry) head(res, 3)
geometry <- sf::st_geometry(guerry) nb <- st_contiguity(geometry) nb <- include_self(nb) res <- st_kernel_weights(nb, geometry) head(res, 3)
Identifies the k
nearest neighbors for given point geometry. If polygon geometry is provided, the centroids of the polygon will be used and a warning will be emitted.
st_knn(geometry, k = 1, symmetric = FALSE, ...)
st_knn(geometry, k = 1, symmetric = FALSE, ...)
geometry |
an sf or sfc object. |
k |
number of nearest neighbours to be returned |
symmetric |
default |
... |
additional arguments to be passed to |
This function utilizes spdep::knearneigh()
and spdep::knn2nb()
.
a list of class nb
Other neighbors:
st_contiguity()
,
st_dist_band()
st_knn(sf::st_geometry(guerry), k = 8)
st_knn(sf::st_geometry(guerry), k = 8)
Calculates the spatial lag of a numeric variable given a neighbor and weights list.
st_lag(x, nb, wt, na_ok = FALSE, allow_zero = NULL, ...)
st_lag(x, nb, wt, na_ok = FALSE, allow_zero = NULL, ...)
x |
A numeric vector |
nb |
A neighbor list object as created by |
wt |
A weights list as created by |
na_ok |
Default |
allow_zero |
If |
... |
See |
a numeric vector with same length as x
Other stats:
local_moran()
geo <- sf::st_geometry(guerry) nb <- st_contiguity(geo) wt <- st_weights(nb) st_lag(guerry$crime_pers, nb, wt)
geo <- sf::st_geometry(guerry) nb <- st_contiguity(geo) wt <- st_weights(nb) st_lag(guerry$crime_pers, nb, wt)
Sometimes one may want to create custom lag variables or create some other neighborhood level metric that may not be defined yet. This st_nb_apply()
enables you to apply a function to each observation's (xi) neighbors (xij).
st_nb_apply(x, nb, wt, .f, suffix = "dbl", ...)
st_nb_apply(x, nb, wt, .f, suffix = "dbl", ...)
x |
A vector that will be used for neighbor xij values. |
nb |
A neighbor list object as created by |
wt |
A weights list as created by |
.f |
A function definition. There are three default objects that can be used inside of the function definition:
If any of these three function arguments are omitted from |
suffix |
The |
... |
arguments to pass to |
The below example calculates the spatial lag using st_nb_apply()
and st_lag()
to illustrate how we can apply functions to neighbors.
Currently questioning the use case. find_xj()
is now exported and may negate the need for this function.
a vector or list of with same length as x
.
if (requireNamespace("dplyr", quietly = TRUE)) { library(magrittr) guerry %>% dplyr::transmute( nb = st_contiguity(geometry), wt = st_weights(nb), lag_apply = st_nb_apply( crime_pers, nb, wt, .f = function(.xij, .wt, ...) sum(.xij *.wt) ), lag = st_lag(crime_pers, nb, wt) ) }
if (requireNamespace("dplyr", quietly = TRUE)) { library(magrittr) guerry %>% dplyr::transmute( nb = st_contiguity(geometry), wt = st_weights(nb), lag_apply = st_nb_apply( crime_pers, nb, wt, .f = function(.xij, .wt, ...) sum(.xij *.wt) ), lag = st_lag(crime_pers, nb, wt) ) }
Create graph based neighbors on a set of points.
st_nb_delaunay(geometry, .id = NULL) st_nb_gabriel(geometry, .nnmult = 3) st_nb_relative(geometry, .nnmult = 3)
st_nb_delaunay(geometry, .id = NULL) st_nb_gabriel(geometry, .nnmult = 3) st_nb_relative(geometry, .nnmult = 3)
geometry |
an object of class sfc. If polygons are used, points are generated using |
.id |
default |
.nnmult |
default 3. Used for memory scalling. See |
st_nb_delaunay()
uses spdep::tri2nb()
st_nb_gabriel()
uses spdep::gabrielneigh()
and spdep::graph2nb()
st_nb_relative()
uses spdep::relativeneigh()
and spdep::graph2nb()
st_nb_delaunay()
implements Delaunay triangulation via spdep
and thus via deldir
. Delaunay triangulation creates a mesh of triangles that connects all points in a set. It ensures that no point is in in the circumcircle of an triangle in the triangulation. As a result, Delaunay triangulation maximizes the minimum angle in each triangle consequently avoiding skinny triangles.
The Gabriel graph is a subgraph of the Delaunay triangulation. Edges are created when the closed disc between two points p, and q, contain no other points besides themselves.
The relative neighborhood graph (RNG) is based on the Delaunay triangulation. It connects two points when there are no other closer points to each of them. The RNG is a subgraph of the Delaunay triangulation.
Note that Delaunay triangulation assumes a plane and thus uses Euclidean distances.
See spdep::gabrielneigh()
for further descriptions of the graph neighbor implementations.
an object of class nb
geometry <- sf::st_centroid(sf::st_geometry(guerry)) st_nb_delaunay(geometry) st_nb_gabriel(geometry) st_nb_relative(geometry)
geometry <- sf::st_centroid(sf::st_geometry(guerry)) st_nb_delaunay(geometry) st_nb_gabriel(geometry) st_nb_relative(geometry)
From an nb list and point geometry, return a list of distances for each observation's neighbors list.
st_nb_dists(x, nb, longlat = NULL)
st_nb_dists(x, nb, longlat = NULL)
x |
an object of class |
nb |
a neighbor list for example created by |
longlat |
|
Utilizes spdep::nbdists()
for distance calculation.
a list where each element is a numeric vector.
Other weights:
st_inverse_distance()
,
st_kernel_weights()
,
st_weights()
geo <- sf::st_geometry(guerry) nb <- st_contiguity(geo) dists <- st_nb_dists(geo, nb) head(dists)
geo <- sf::st_geometry(guerry) nb <- st_contiguity(geo) dists <- st_nb_dists(geo, nb) head(dists)
Identify higher order neighbors from a neighbor list. order
must be greater than 1. When order equals 2 then the neighbors of the neighbors list is returned and so forth. See Anselin's book was: "https://spatial.uchicago.edu" "/sites/spatial.uchicago.edu/files/1_introandreview_reducedsize.pdf" for an example.
st_nb_lag(nb, order)
st_nb_lag(nb, order)
nb |
A neighbor list object as created by |
order |
The order of neighbors. |
Utilizes spdep::nblag()
a list of class nb
Other other:
st_cardinalties()
,
st_nb_lag_cumul()
nb <- st_contiguity(sf::st_geometry(guerry)) st_nb_lag(nb, 3)
nb <- st_contiguity(sf::st_geometry(guerry)) st_nb_lag(nb, 3)
Creates an encompassing neighbor list of the order specified. For example, if the order is 2 the result contains both 1st and 2nd order neighbors.
st_nb_lag_cumul(nb, order)
st_nb_lag_cumul(nb, order)
nb |
A neighbor list object as created by |
order |
The order of neighbors. |
Utilizes spdep::nblag_cumul()
a list of class nb
Other other:
st_cardinalties()
,
st_nb_lag()
nb <- st_contiguity(sf::st_geometry(guerry)) st_nb_lag_cumul(nb, 3)
nb <- st_contiguity(sf::st_geometry(guerry)) st_nb_lag_cumul(nb, 3)
Calculate polygon spatial weights from a nb
list. See spdep::nb2listw()
for further details.
st_weights(nb, style = "W", allow_zero = NULL, ...)
st_weights(nb, style = "W", allow_zero = NULL, ...)
nb |
A neighbor list object as created by |
style |
Default |
allow_zero |
If |
... |
additional arguments passed to |
Under the hood, st_weights()
creates a listw
object and then extracts the weights elements from it as the neighbours
element is already–presumably–already existent in the neighbors list you've already created. listw
objects are recreated using recreate_listw()
when calculating other statistics.
a list where each element is a numeric vector
Other weights:
st_inverse_distance()
,
st_kernel_weights()
,
st_nb_dists()
if (requireNamespace("dplyr", quietly = TRUE)) { library(magrittr) guerry %>% dplyr::mutate(nb = st_contiguity(geometry), wt = st_weights(nb), .before = 1) } # using geometry column directly nb <- st_contiguity(guerry$geometry) wt <- st_weights(nb) wt[1:3]
if (requireNamespace("dplyr", quietly = TRUE)) { library(magrittr) guerry %>% dplyr::mutate(nb = st_contiguity(geometry), wt = st_weights(nb), .before = 1) } # using geometry column directly nb <- st_contiguity(guerry$geometry) wt <- st_weights(nb) wt[1:3]
From an sf object containing points, calculate the standard deviational ellipse.
std_dev_ellipse(geometry)
std_dev_ellipse(geometry)
geometry |
an sfc object. If a polygon, uses |
The bulk of this function is derived from the archived CRAN package aspace version 3.2.0.
An sf object with three columns
sx
: major axis radius in CRS units,
sy
: minor axis radius in CRS units,
theta
: degree rotation of the ellipse.
sf object's geometry is the center mean point.
#' # Make a grid to sample from grd <- sf::st_make_grid(n = c(1, 1), cellsize = c(100, 100), offset = c(0,0)) # sample 100 points pnts <- sf::st_sample(grd, 100) std_dev_ellipse(pnts)
#' # Make a grid to sample from grd <- sf::st_make_grid(n = c(1, 1), cellsize = c(100, 100), offset = c(0,0)) # sample 100 points pnts <- sf::st_sample(grd, 100) std_dev_ellipse(pnts)
The standard distance of a point pattern is a measure of central tendency. Standard distance measures distance away from the mean center of the point pattern similar to standard deviations.
std_distance(geometry)
std_distance(geometry)
geometry |
an sfc object. If a polygon, uses |
A numeric scalar.
Other point-pattern:
center_mean()
# Make a grid to sample from grd <- sf::st_make_grid(n = c(1, 1), cellsize = c(100, 100), offset = c(0,0)) # sample 100 points pnts <- sf::st_sample(grd, 100) # plot points plot(pnts) # calculate standard distance std_distance(pnts)
# Make a grid to sample from grd <- sf::st_make_grid(n = c(1, 1), cellsize = c(100, 100), offset = c(0,0)) # sample 100 points pnts <- sf::st_sample(grd, 100) # plot points plot(pnts) # calculate standard distance std_distance(pnts)
Calculate the global sum of weights
szero(wt)
szero(wt)
wt |
a weights list—i.e. created by |
a scalar numeric
nb <- st_contiguity(guerry) wt <- st_weights(nb) szero(wt)
nb <- st_contiguity(guerry) wt <- st_weights(nb) szero(wt)
dplyr methods for spacetime objects.
group_by.spacetime(.data, ...) mutate.spacetime(.data, ...) ungroup.spacetime(.data, ...)
group_by.spacetime(.data, ...) mutate.spacetime(.data, ...) ungroup.spacetime(.data, ...)
.data |
a data frame |
... |
additional arguments |
a spacetime object
Given a nb
list or weights list, convert them to a matrix.
wt_as_matrix(nb, wt) nb_as_matrix(nb)
wt_as_matrix(nb, wt) nb_as_matrix(nb)
nb |
a neighbor list—i.e. as created by |
wt |
a weights list—i.e. as created by |
Returns a n x n matrix
# make a grid g <- sf::st_make_grid( cellsize = c(10, 10), offset = c(0, 0), n = c(2, 2) ) # create neighbors nb <- st_contiguity(g) # cast to matrix nb_as_matrix(nb) # create weights wt <- st_weights(nb) # cast as matrix wt_as_matrix(nb, wt)
# make a grid g <- sf::st_make_grid( cellsize = c(10, 10), offset = c(0, 0), n = c(2, 2) ) # create neighbors nb <- st_contiguity(g) # cast to matrix nb_as_matrix(nb) # create weights wt <- st_weights(nb) # cast as matrix wt_as_matrix(nb, wt)