R/apply_gravity_measure.R

Defines functions try_to_convert_to_num apply_gravity_measure

apply_gravity_measure <- function(data, decay_function, travel_cost) {
  .cost_colname <- travel_cost

  # the decay function can come in two "formats"
  # - a function that returns a numeric vector
  # - a function that returns a list of numeric vectors
  # we have first to figure out which function we're dealing with, and then use
  # it accordingly

  decay_fn_output <- decay_function(1)

  is_list_length_1 <- is.list(decay_fn_output) && length(decay_fn_output) == 1
  is_numeric_like <- is.numeric(decay_fn_output) || is.integer(decay_fn_output)

  if (is_numeric_like || is_list_length_1) {
    data[, opp_weight := decay_function(get(.cost_colname))]

    access <- data
  } else {
    opp_weights <- decay_function(data[[travel_cost]])

    access <- lapply(
      opp_weights,
      function(opp_weight) cbind(data, opp_weight)
    )
    access <- data.table::rbindlist(access, idcol = "decay_function_arg")
    access[, decay_function_arg := try_to_convert_to_num(decay_function_arg)]
  }

  return(access[])
}


try_to_convert_to_num <- function(x) {
  result <- tryCatch(
    as.numeric(x),
    warning = function(cnd) cnd
  )

  if (inherits(result, "warning")) return(x)

  return(result)
}

Try the accessibility package in your browser

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

accessibility documentation built on May 29, 2024, 7:29 a.m.