View source: R/Sim_Community.R
| sim_thomas_coords | R Documentation | 
Add clumped (aggregated) positions to a species abundance distribution. Clumping is simulated using a Thomas cluster process, also known as Poisson cluster process (Morlon et al. 2008, Wiegand & Moloney 2014)
sim_thomas_coords(
  abund_vec,
  sigma = 0.02,
  mother_points = NA,
  xmother = NA,
  ymother = NA,
  cluster_points = NA,
  xrange = c(0, 1),
  yrange = c(0, 1),
  seed = NULL
)
| abund_vec | Species abundance vector (integer) | 
| sigma | Mean displacement (along each coordinate axes) of a point from
its mother point (= cluster centre).  | 
| mother_points | Number of mother points (= cluster centres).
If this is a single value, all species have the same number of clusters.
For example  | 
| xmother | List of length equal to the number of species. Each list element is a vector of x coordinates for every mother points. If one element is NA, the the corresponding species is not clustered. | 
| ymother | List of length equal to the number of species. Each list element is a vector of y coordinates for every mother points. If one element is NA, the the corresponding species is not clustered. | 
| cluster_points | Mean number of points per cluster. If this is
a single value, species have the same average number of points per cluster.
If this is a vector of the same length as  | 
| xrange | Extent of the community in x-direction. If this a numeric vector
of length 2, all species share the same range. To specify different x ranges for
all species,  | 
| yrange | Extent of the community in y-direction. If this a numeric vector
of length 2, all species share the same range. To specify different y ranges for
all species,  | 
| seed | Integer. Any integer passed to  | 
To generate a Thomas cluster process of a single species this
function uses a C++ re-implementation of the function
rThomas in the package
spatstat.random.
There is an inherent link between the parameters abund_vec,
mother_points, and cluster_points. For every species the
abundance has to be equal to the number of clusters
(mother_points) times the number of points per cluster
(cluster_points).
abundance = mother_points * cluster_points
Accordingly, if one of the parameters is provided, the other one is directly
calculated from the abundance. Values for mother_points override values
for cluster_points. If none of the parameters is specified, it is assumed
that for every species there is a similar number of clusters and of points
per cluster.
mother_points = cluster_points = \sqrt(abundance),
In this case rare species have few clusters with few points per cluster, while abundant species have many clusters with many points per cluster.
A community object as defined by community.
Felix May, Alban Sagouis
Morlon et al. 2008. A general framework for the distance-decay of similarity in ecological communities. Ecology Letters 11, 904-917.
Wiegand and Moloney 2014. Handbook of Spatial Point-Pattern Analysis in Ecology. CRC Press
rThomas
abund <- c(10,20,50,100)
sim1 <- sim_thomas_coords(abund, sigma = 0.02)
plot(sim1)
# Simulate species "ranges"
sim2 <- sim_thomas_coords(abund, sigma = 0.02, mother_points = 1)
plot(sim2)
# Equal numbers of points per cluster
sim3 <- sim_thomas_coords(abund, sigma = 0.02, cluster_points = 5)
plot(sim3)
# With large sigma the distribution will be essentially random (see Details)
sim4 <- sim_thomas_coords(abund, sigma = 10)
plot(sim4)
# Some random and some clustered species with different numbers of mother points.
mother_points <- sample(0:3, length(abund), replace = TRUE)
sim5 <- sim_thomas_coords(abund, mother_points = mother_points, sigma=0.01)
plot(sim5)
# Specifying mother point coordinates or no-clustering (\code{NA}).
mother_points <- sample(1:3, length(abund), replace = TRUE)
xmother <- lapply(1:length(abund), function(i) runif(mother_points[i], 0, 1))
ymother <- lapply(1:length(abund), function(i) runif(mother_points[i], 0, 1))
xmother[[1]] <- NA
ymother[[1]] <- NA
sim6 <- sim_thomas_coords(abund, xmother=xmother, ymother=ymother, sigma=0.01)
plot(sim6)
# Species having different ranges.
xrange <- data.frame(t(sapply(1:length(abund), function(i) sort(runif(2, 0, 1)))))
yrange <- data.frame(t(sapply(1:length(abund), function(i) sort(runif(2, 0, 1)))))
sim7 <- sim_thomas_coords(abund, mother_points=1, sigma=1, xrange=xrange, yrange=yrange)
plot(sim7)
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.