Generally useful for model development purposes. Primarily used internally
in e.g., crw if torus = TRUE.
wrap(X, bounds, withHeading = FALSE)Object of the same class as X, but with coordinates updated to reflect the wrapping.
If withHeading used, then X must be an sf or SpatVector object
that contains two columns, x1 and y1, with the immediately
previous agent locations.
origDTThreads <- data.table::setDTthreads(2L)
origNcpus <- options(Ncpus = 2L)
xrange <- yrange <- c(-50, 50)
hab <- terra::rast(terra::ext(c(xrange, yrange)))
hab[] <- 0
# initialize agents
N <- 10
# previous points
x1 <- y1 <- rep(0, N)
# initial points
starts <- cbind(x = stats::runif(N, xrange[1], xrange[2]),
y = stats::runif(N, yrange[1], yrange[2]))
# create the agent object # the x1 and y1 are needed for "previous location"
agent <- terra::vect(data.frame(x1, y1, starts), geom = c("x", "y"))
ln <- rlnorm(N, 1, 0.02) # log normal step length
sd <- 30 # could be specified globally in params
if (interactive()) {
# clearPlot()
terra::plot(hab, col = "white")
}
for (i in 1:10) {
agent <- crw(agent = agent, extent = terra::ext(hab), stepLength = ln,
stddev = sd, lonlat = FALSE, torus = FALSE) # don't wrap
if (interactive()) terra::plot(agent[, 1], add = TRUE, col = 1:10)
}
terra::crds(agent) # many are "off" the map, i.e., beyond the extent of hab
#> x y
#> [1,] -72.30760 -25.73176
#> [2,] -22.94533 -22.09094
#> [3,] 49.06816 -40.57450
#> [4,] 40.68249 -20.71148
#> [5,] -20.91130 -16.42135
#> [6,] -42.74352 -43.82055
#> [7,] -41.18622 -10.59485
#> [8,] -32.32124 -15.21391
#> [9,] -25.03427 -45.58835
#> [10,] -42.38495 50.08976
agent <- SpaDES.tools::wrap(agent, bounds = terra::ext(hab))
terra::plot(agent, add = TRUE, col = 1:10) # now inside the extent of hab
#> Error in graphics::plot.xy(list(x = g[, 3], y = g[, 4]), type = "p", pch = pch, col = col, cex = cex, ...): plot.new has not been called yet
# clean up
data.table::setDTthreads(origDTThreads)
options(Ncpus = origNcpus)