Skip to content

Commit

Permalink
style: styler pass
Browse files Browse the repository at this point in the history
  • Loading branch information
rCarto committed Mar 30, 2023
1 parent 9e6bcd0 commit 53cfc94
Show file tree
Hide file tree
Showing 18 changed files with 940 additions and 767 deletions.
161 changes: 86 additions & 75 deletions R/osrmIsochrone.R
Original file line number Diff line number Diff line change
@@ -1,23 +1,23 @@
#' @name osrmIsochrone
#' @title Get Polygons of Isochrones
#' @description This function computes areas that are reachable within a
#' given time span from a point and returns the reachable regions as
#' @description This function computes areas that are reachable within a
#' given time span from a point and returns the reachable regions as
#' polygons. These areas of equal travel time are called isochrones.
#' @param loc origin point. \code{loc} can be: \itemize{
#' \item a vector of coordinates (longitude and latitude, WGS 84),
#' \item a vector of coordinates (longitude and latitude, WGS 84),
#' \item a data.frame of longitudes and latitudes (WGS 84),
#' \item a matrix of longitudes and latitudes (WGS 84),
#' \item an sfc object of type POINT,
#' \item an sf object of type POINT.
#'}
#' If \code{loc} is a data.frame, a matrix, an sfc object or an sf object then
#' }
#' If \code{loc} is a data.frame, a matrix, an sfc object or an sf object then
#' only the first row or element is considered.
#' @param breaks a numeric vector of break values to define isochrone areas,
#' @param breaks a numeric vector of break values to define isochrone areas,
#' in minutes.
#' @param exclude pass an optional "exclude" request option to the OSRM API.
#' @param res number of points used to compute isochrones, one side of the square
#' grid, the total number of points will be res*res. Increase res to obtain more
#' detailed isochrones.
#' detailed isochrones.
#' @param returnclass deprecated.
#' @param osrm.server the base URL of the routing server.
#' getOption("osrm.server") by default.
Expand All @@ -31,124 +31,137 @@
#' \item isomin, the minimum value of the isochrone polygon in minutes
#' \item isomax, the maximum value of the isochrone polygon in minutes
#' }
#' If loc is a vector, a data.frame or a matrix the coordinate
#' reference system (CRS) of the output is EPSG:4326 (WGS84).\cr
#' If loc is an sfc or sf object, the output has the same CRS
#' If loc is a vector, a data.frame or a matrix the coordinate
#' reference system (CRS) of the output is EPSG:4326 (WGS84).\cr
#' If loc is an sfc or sf object, the output has the same CRS
#' as loc.\cr
#' @importFrom sf st_as_sf st_crs st_transform st_convex_hull st_union
#' @importFrom sf st_as_sf st_crs st_transform st_convex_hull st_union
#' st_intersects st_bbox st_buffer st_distance st_make_grid st_sfc
#' @importFrom mapiso mapiso
#' @export
#' @examples
#' \dontrun{
#' library(sf)
#' apotheke.sf <- st_read(system.file("gpkg/apotheke.gpkg", package = "osrm"),
#' quiet = TRUE)
#' quiet = TRUE
#' )
#' # Get isochones with lon/lat coordinates
#' iso <- osrmIsochrone(loc = c(13.43,52.47), breaks = seq(0,12,2))
#' iso <- osrmIsochrone(loc = c(13.43, 52.47), breaks = seq(0, 12, 2))
#' # Map
#' plot(iso["isomax"], breaks = sort(unique(c(iso$isomin, iso$isomax))))
#'
#'
#' # Get isochones with an sf POINT
#' iso2 <- osrmIsochrone(loc = apotheke.sf[11,], breaks = seq(0,12,2))
#' iso2 <- osrmIsochrone(loc = apotheke.sf[11, ], breaks = seq(0, 12, 2))
#' # Map
#' if(require("mapsf")){
#' mapsf::mf_map(x = iso2, var = "isomin", type = "choro",
#' breaks = sort(unique(c(iso2$isomin, iso2$isomax))),
#' pal = "Burg", border = NA, leg_pos = "topleft",
#' leg_val_rnd = 0,
#' leg_frame = TRUE, leg_title = "Isochrones\n(min)")
#' if (require("mapsf")) {
#' mapsf::mf_map(
#' x = iso2, var = "isomin", type = "choro",
#' breaks = sort(unique(c(iso2$isomin, iso2$isomax))),
#' pal = "Burg", border = NA, leg_pos = "topleft",
#' leg_val_rnd = 0,
#' leg_frame = TRUE, leg_title = "Isochrones\n(min)"
#' )
#' }
#' }
osrmIsochrone <- function(loc, breaks = seq(from = 0,to = 60, length.out = 7),
osrmIsochrone <- function(loc, breaks = seq(from = 0, to = 60, length.out = 7),
exclude, res = 30, returnclass,
osrm.server = getOption("osrm.server"),
osrm.profile = getOption("osrm.profile")){

osrm.profile = getOption("osrm.profile")) {
opt <- options(error = NULL)
on.exit(options(opt), add=TRUE)
if(!missing(returnclass)){
on.exit(options(opt), add = TRUE)

if (!missing(returnclass)) {
warning('"returnclass" is deprecated.', call. = FALSE)
}

# input management
loc <- input_route(x = loc, id = "loc", single = TRUE)
oprj <- loc$oprj
loc <- st_as_sf(data.frame(lon = loc$lon, lat = loc$lat),
coords = c("lon","lat"), crs = 4326)
loc <- st_as_sf(data.frame(lon = loc$lon, lat = loc$lat),
coords = c("lon", "lat"), crs = 4326
)
loc <- st_transform(loc, "epsg:3857")

# max distance management to see how far to extend the grid to get measures
breaks <- unique(sort(breaks))
tmax <- max(breaks)
if(osrm.profile %in% c("foot", "walk")){
speed = 10 * 1000/60
if (osrm.profile %in% c("foot", "walk")) {
speed <- 10 * 1000 / 60
}
if(osrm.profile =="bike"){
speed = 20 * 1000/60
if (osrm.profile == "bike") {
speed <- 20 * 1000 / 60
}
if(osrm.profile %in% c("driving","car")){
speed = 120 * 1000/60
if (osrm.profile %in% c("driving", "car")) {
speed <- 120 * 1000 / 60
}
dmax <- tmax * speed


# gentle sleeptime & param for demo server
if(osrm.server != "https://routing.openstreetmap.de/"){
if (osrm.server != "https://routing.openstreetmap.de/") {
sleeptime <- 0
deco <- 450
}else{
} else {
sleeptime <- 1
deco <- 75
}

# create a grid to obtain measures
sgrid <- rgrid(loc = loc, dmax = dmax, res = res)
# slice the grid to make several API calls
lsgr <- nrow(sgrid)
niter <- lsgr %/% deco
nitersup <- lsgr %% deco
ltot <- niter + ifelse(nitersup>0, 1,0)
listDur <- listDest <- vector(mode = 'list', length = ltot)
ltot <- niter + ifelse(nitersup > 0, 1, 0)
listDur <- listDest <- vector(mode = "list", length = ltot)
# get measures and destinations points
if(niter > 0){
for (i in 1:niter){
dmat <- osrmTable(src = loc,
dst = sgrid[(((i-1) * deco) + 1):(i * deco),],
exclude = exclude,
osrm.server = osrm.server,
osrm.profile = osrm.profile)
if (niter > 0) {
for (i in 1:niter) {
dmat <- osrmTable(
src = loc,
dst = sgrid[(((i - 1) * deco) + 1):(i * deco), ],
exclude = exclude,
osrm.server = osrm.server,
osrm.profile = osrm.profile
)
listDur[[i]] <- dmat$durations
listDest[[i]] <- dmat$destinations
Sys.sleep(sleeptime)
}
}
if(nitersup > 0){
dmat <- osrmTable(src = loc,
dst = sgrid[((niter * deco)+1):lsgr,],
exclude = exclude,
osrm.server = osrm.server,
osrm.profile = osrm.profile)
if (nitersup > 0) {
dmat <- osrmTable(
src = loc,
dst = sgrid[((niter * deco) + 1):lsgr, ],
exclude = exclude,
osrm.server = osrm.server,
osrm.profile = osrm.profile
)
listDur[[ltot]] <- dmat$durations
listDest[[ltot]] <- dmat$destinations
}

measure <- do.call(c, listDur)
destinations <- do.call(rbind, listDest)
# for testing purpose
# return(list(destinations = destinations, measure = measure,
# return(list(destinations = destinations, measure = measure,
# sgrid = sgrid, res = res, tmax = tmax))

# assign values to the grid
sgrid <- fill_grid(destinations = destinations, measure = measure,
sgrid = sgrid, res = res, tmax = tmax)
if(min(sgrid$measure) >= tmax + 1){
warning(paste0("An empty object is returned. ",
"'loc' is too far from the OSRM network."),
call. = FALSE)
sgrid <- fill_grid(
destinations = destinations, measure = measure,
sgrid = sgrid, res = res, tmax = tmax
)
if (min(sgrid$measure) >= tmax + 1) {
warning(
paste0(
"An empty object is returned. ",
"'loc' is too far from the OSRM network."
),
call. = FALSE
)
empty_res <- st_sf(
crs = ifelse(is.na(oprj),4326,oprj),
crs = ifelse(is.na(oprj), 4326, oprj),
id = integer(),
isomin = numeric(),
isomax = numeric(),
Expand All @@ -159,18 +172,16 @@ osrmIsochrone <- function(loc, breaks = seq(from = 0,to = 60, length.out = 7),
# computes isopolygones
iso <- mapiso(x = sgrid, breaks = breaks, var = "measure")
# get rid of out of breaks polys
iso <- iso[-nrow(iso),]
iso <- iso[-nrow(iso), ]
# fisrt line always start at 0
iso[1,"isomin"] <- 0
iso[1, "isomin"] <- 0

# proj mgmnt
if (!is.na(oprj)){
if (!is.na(oprj)) {
iso <- st_transform(x = iso, oprj)
}else{
} else {
iso <- st_transform(x = iso, 4326)
}

return(iso)
}


Loading

0 comments on commit 53cfc94

Please sign in to comment.