R/add_pathlength.R

Defines functions add_pathlength.hy add_pathlength.data.frame add_pathlength

Documented in add_pathlength add_pathlength.data.frame add_pathlength.hy

#' Add Path Length
#' @description Generates the main path length to a basin's terminal path.
#' @inheritParams add_levelpaths
#' @name add_pathlength
#' @export
#' @returns data.frame containing pathlength_km
#' @examples
#' x <- sf::read_sf(system.file("extdata/new_hope.gpkg", package = "hydroloom"))
#'
#' x <- add_toids(x)
#'
#' x <- add_pathlength(x)
#'
#' plot(x["Pathlength"])
#'
add_pathlength <- function(x) {

  UseMethod("add_pathlength")

}

#' @name add_pathlength
#' @export
add_pathlength.data.frame <- function(x) {

  x <- hy(x)

  x <- add_pathlength(x)

  hy_reverse(x)
}

#' @name add_pathlength
#' @export
add_pathlength.hy <- function(x) {

  check_names(x, c(id, toid, length_km), "add_pathlength")

  orig_order <- select(x, id)

  x <- sort_network(st_drop_geometry(x))[nrow(x):1, ]

  x$pathlength_km <- rep(0, nrow(x))

  toids <- match(x$toid, x$id)

  for(i in seq_len(length(x$id))) {
    if((tid <- x$toid[i]) != get_outlet_value(x)) {

      x$pathlength_km[i] <- x$length_km[toids[i]] + x$pathlength_km[toids[i]]

    }
  }

  left_join(orig_order, x, by = id)
}

Try the hydroloom package in your browser

Any scripts or data that you put into this service are public.

hydroloom documentation built on May 29, 2024, 2:46 a.m.