This session is concerned with fitting non-Poisson point process models.
The lecturer’s R script is available here (right click and save).

Exercise 1

  1. Fit the Thomas model to the redwood data by the method of minimum contrast:

    fit <- kppm(redwood ~ 1, clusters="Thomas")
    fit
    plot(fit)
  2. Read off the parameters of the fitted model, and generate a simulated realisation of the fitted model using rThomas.

  3. Type plot(simulate(fit)) to generate a simulated realisation of the fitted model automatically.

  4. Generate and plot several simulated realisations of the fitted model, to assess whether it is plausible.

  5. Extract and plot the fitted pair correlation function by

    pcffit <- pcfmodel(fit)
    plot(pcffit, xlim = c(0, 0.3))
  6. Type plot(envelope(fit, Lest, nsim=39)) to generate simulation envelopes of the \(L\) function from this fitted model. Do they suggest the model is plausible?

Exercise 2

  1. Fit a Matern cluster process to the redwood data.

  2. Use vcov to estimate the covariance matrix of the parameter estimates.

  3. Compare with the covariance matrix obtained when fitting a homogeneous Poisson model.

Exercise 3

In this exercise we fit a Strauss point process model to the swedishpines data.

  1. We need a guess at the interaction distance \(R\). Compute and plot the \(L\)-function of the dataset and choose the value \(r\) which maximises the discrepancy \(|L(r)-r|\).

  2. Fit the stationary Strauss model with the chosen interaction distance using

    ppm(swedishpines ~ 1, Strauss(R))

    where R is your chosen value.

    1. Interpret the printout: how strong is the interaction?

    2. Plot the fitted pairwise interaction function using plot(fitin(fit)).

Exercise 4

For the Strauss model fitted in Exercise 3,

  1. Generate and plot a simulated realisation of the fitted model using simulate.

  2. Plot the \(L\)-function of the data along with the global simulation envelopes from 19 realisations of the fitted model.

Exercise 5

In Exercise 3 we guesstimated the Strauss interaction distance parameter. Alternatively this parameter could be estimated by profile pseudolikelihood.

  1. Look again at the plot of the \(L\)-function of swedishpines and determine a plausible range of possible values for the interaction distance.

  2. Generate a sequence of values equally spaced across this range, for example, if your range of plausible values was \([3, 15]\), then type

    rvals <- seq(3, 15, by=0.5)
  3. Construct a data frame, with one column named r (matching the argument name of Strauss), containing these values. For example

    D <- data.frame(r = rvals)
  4. Execute

    fitp <- profilepl(D, Strauss, swedishpines ~ 1)

    to find the maximum profile pseudolikelihood fit.

  5. Print and plot the object fitp.

  6. Compare the computed estimate of interaction distance \(r\) with your guesstimate. Compare the corresponding estimates of the Strauss interaction parameter \(\gamma\).

  7. Extract the fitted Gibbs point process model from the object fitp as

    bestfit <- as.ppm(fitp)