R/location_createID.R

Defines functions location_createID

Documented in location_createID

#'
#' @title Create one or more unique locationIDs
#' @description A unique locationID is created for each incoming
#' `longitude` and `latitude`. 
#' 
#' See [MazamaCoreUtils::createLocationID()] for details.
#' 
#' At `precision = 10`, this results in a maximum error of 0.6 meters which 
#' is more than precise enough for environmental monitoring studies making use
#' of this package.
#' 
#' An excellent way to become familiar with geohash is through the 
#' [GeoHash Explorer](https://geohash.softeng.co).
#' 
#' @note The `"digest"` algorithm is deprecated but provided for backwards 
#' compatibility with databases that were built using locationIDs generated
#' with this algorithm.
#' 
#' @param longitude Vector of longitudes in decimal degrees E.
#' @param latitude Vector of latitudes in decimal degrees N.
#' @param algorithm Algorithm to use -- either `"geohash"` or `"digest"`.
#' @param precision `precision` argument used when encoding with `"geohash"`.
#' 
#' @return Vector of character locationIDs.
#' 
#' @examples
#' library(MazamaLocationUtils)
#' 
#' # Wenatchee
#' lon <- -120.325278
#' lat <- 47.423333
#' locationID <- location_createID(lon, lat)
#' print(locationID)
#' 
#' location_createID(lon, lat, algorithm = "geohash")
#' location_createID(lon, lat, algorithm = "geohash", precision = 7)
#' 
#' @references \url{https://en.wikipedia.org/wiki/Decimal_degrees}
#' @references \url{https://www.johndcook.com/blog/2017/01/10/probability-of-secure-hash-collisions/}
#' @rdname location_createID
#' @export 
#' 
location_createID <- function(
  longitude = NULL,
  latitude = NULL,
  algorithm = c("geohash", "digest"),
  precision = 10
) {
  
  algorithm <- match.arg(algorithm)
  
  returnVal <- 
    MazamaCoreUtils::createLocationID(
      longitude = longitude, 
      latitude = latitude, 
      algorithm = algorithm,
      precision = precision,
      invalidID = as.character(NA)
    )
  
  return(returnVal)
  
}

Try the MazamaLocationUtils package in your browser

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

MazamaLocationUtils documentation built on April 20, 2026, 1:06 a.m.