This session is concerned with summary statistics for interpoint correlation (i.e. dependence between points). The lecturer’s R script is available here (right click and save).
The swedishpines
dataset was recorded in a study plot in a large forest. We shall assume the pattern is stationary.
Before we begin, we plot the data:
plot(swedishpines, main = "")
Calculate the estimate of the K-function using Kest
.
The estimation is done with:
K <- Kest(swedishpines)
Plot the estimate of K(r) against r
To plot the K-function, we do:
plot(K, main = "K-function")
Plot the estimate of K(r)−πr2 against r.
The estimated K-function subtracted πr2 can be done via the fmla
(formula) interface:
plot(K, . - pi*r^2 ~ r, main = "Normalized K-function",
legendpos = "bottomright")
Calculate the estimate of the L-function and plot it against r.
Like the K-function, we estimate the L-function in the same manner:
L <- Lest(swedishpines)
plot(L, main = "L-function")
Plot the estimate of L(r)−r against r.
Like before:
plot(L, . - r ~ r, main = "L-function")
Calculate and plot an estimate of the pair correlation function using pcf
.
The pair-correlation is also compute straight-forwardly:
pcorf <- pcf(swedishpines)
plot(pcorf)
Draw tentative conclusions from these plots about interpoint interaction in the data.
Assuming a homogeneous point pattern, both the L- and K-function are less what is expected under the Poisson process the data. Thus they indicate a comparatively regular point pattern. Similarly, the pair-correlation function also suggests this.
Generate Fry Plots for the Swedish Pines data using the two commands
fryplot(swedishpines)
fryplot(swedishpines, width=50)
OK,
par(mar=rep(0,4), mfrow=c(1,2))
fryplot(swedishpines)
fryplot(swedishpines, width=50)
What can you interpret from these plots?
The leftmost plot is somewhat misleading as the limiting observation window come into play. That the density tapers off here is effectively an edge effect. Looking at the rightmost plot, we see a slight dip in density of points near the center. This again indicate a regular point pattern, however, the data is somewhat sparse in the latter plot.
The japanesepines
dataset is believed to exhibit spatial inhomogeneity. The question is whether, after allowing for inhomogeneity, there is still evidence of interpoint interaction. We will use the inhomogeneous K-function.
Compute the inhomogeneous K function using the default estimate of intensity (a leave-one-out kernel smoother) with heavy smoothing:
KiS <- Kinhom(japanesepines, sigma=0.1)
plot(KiS)
We compute the estimate (with the default smoother) by not specifying sigma
as follows:
KiS <- Kinhom(japanesepines)
plot(KiS)
Fit a parametric trend to the data, and use this to compute the inhomogeneous K function:
fit <- ppm(japanesepines ~ polynom(x,y,2))
lambda <- predict(fit, type="trend")
KiP <- Kinhom(japanesepines, lambda)
plot(KiP)
OK,
fit <- ppm(japanesepines ~ polynom(x,y,2))
lambda <- predict(fit, type = "trend")
KiP <- Kinhom(japanesepines, lambda)
plot(KiP)
Plot corresponding estimates of the inhomogeneous L function, using either Linhom
or
plot(KiS, sqrt(./pi) ~ r)
and similarly for KiP
.
We use the inhomogenous L-function:
par(mfrow=c(1,2))
LiS <- Linhom(japanesepines)
plot(LiS)
LiP <- Kinhom(japanesepines, lambda)
plot(LiP)
Draw tentative conclusions about interpoint interaction.
There seems to be no good evidence for any difference between the L-function under the Poisson model and the japanesepines
point pattern.
To understand the difficulties with the K-function when the point pattern is not spatially homogeneous, try the following experiment.
Generate a simulated realisation of an inhomogeneous Poisson process, e.g.
X <- rpoispp(function(x,y){ 200 * exp(-3 * x) })
OK,
X <- rpoispp(function(x,y){ 200 * exp(-3 * x) })
plot(X, main = "")
Plot the K-function or L-function. It will most likely appear to show evidence of clustering.
par(mfrow=c(1,2))
plot(Kest(X))
plot(Lest(X))
The cell process (rcell
) has the same theoretical K-function as the uniform Poisson process.
Read the help file
OK, help("rcell")
.
Generate a simulated realisation of the cell process with a 10x10 grid of cells and plot it.
The data is simulated (and plotted) with the rcell
function and the following arguments:
X <- rcell(win=square(1), nx = 10, nsim = 1)
plot(X, main = "")
Plot the K or L-function for this pattern, and determine whether it is distinguishable from a Poisson process.
We simulate 19 poisson processes and plot these.
lambda <- intensity(X)
Y <- rpoispp(lambda, win = Window(X), nsim = 19)
Y[[20]] <- X
plot(Y, main = "")
Next, we compute the K and L functions and plot these:
par(mfrow=c(1,2))
plot(Kest(Y[[20]]), iso ~ r, col = "red")
tmp <- sapply(lapply(Y[-20], Kest), plot, iso ~ r, add = TRUE, col="lightgrey")
plot(Lest(Y[[20]]), iso ~ r, col = "red")
tmp <- sapply(lapply(Y[-20], Lest), plot, iso ~ r, add = TRUE, col="lightgrey")
Alternatively, one can simply do
par(mfrow=c(1,2))
plot(envelope(X, Kest))
## Generating 99 simulations of CSR ...
## 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38,
## 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76,
## 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99.
##
## Done.
plot(envelope(X, Lest))
## Generating 99 simulations of CSR ...
## 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38,
## 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76,
## 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99.
##
## Done.