Determines the heading between spatial points.
heading(from, to)
The heading between the points, in degrees.
library(terra)
origDTThreads <- data.table::setDTthreads(2L)
origNcpus <- options(Ncpus = 2L)
N <- 10L # number of agents
x1 <- stats::runif(N, -50, 50) # previous X location
y1 <- stats::runif(N, -50, 50) # previous Y location
x0 <- stats::rnorm(N, x1, 5) # current X location
y0 <- stats::rnorm(N, y1, 5) # current Y location
# using SpatVector
prev <- terra::vect(cbind(x = x1, y = y1))
curr <- terra::vect(cbind(x = x0, y = y0))
heading(prev, curr)
#> [1] 68.1044117 299.0604445 283.5799498 136.3961662 0.8301849 94.1958646
#> [7] 289.9510656 83.4063205 103.9784559 342.2722599
# using matrix
prev <- matrix(c(x1, y1), ncol = 2, dimnames = list(NULL, c("x","y")))
curr <- matrix(c(x0, y0), ncol = 2, dimnames = list(NULL, c("x","y")))
heading(prev, curr)
#> [1] 68.1044117 299.0604445 283.5799498 136.3961662 0.8301849 94.1958646
#> [7] 289.9510656 83.4063205 103.9784559 342.2722599
#using both
prev <- terra::vect(cbind(x = x1, y = y1))
curr <- matrix(c(x0, y0), ncol = 2, dimnames = list(NULL, c("x","y")))
heading(prev, curr)
#> [1] 68.1044117 299.0604445 283.5799498 136.3961662 0.8301849 94.1958646
#> [7] 289.9510656 83.4063205 103.9784559 342.2722599
prev <- matrix(c(x1, y1), ncol = 2, dimnames = list(NULL, c("x","y")))
curr <- terra::vect(cbind(x = x0, y = y0))
heading(prev, curr)
#> [1] 68.1044117 299.0604445 283.5799498 136.3961662 0.8301849 94.1958646
#> [7] 289.9510656 83.4063205 103.9784559 342.2722599
# clean up
data.table::setDTthreads(origDTThreads)
options(Ncpus = origNcpus)