st_hull function

Concave and convex hulls for LAS objects

Concave and convex hulls for LAS objects

Concave and convex hulls for LAS objects. st_convex_hull extends sf::st_convex_hull for LAS objects. Both functions return a sfc_POLYGON. concaveman is very a fast 2D concave hull algorithm for a set of points.

st_concave_hull(x, method = "concaveman", ...) ## S3 method for class 'LAS' st_convex_hull(x) concaveman(x, y = NULL, concavity = 2, length_threshold = 0)

Arguments

  • x, y: An object of class LAS or XY coordinates of points in case of concaveman. This can be specified as two vectors x and y, a 2-column matrix x, a list with two components, etc.
  • method: string. currently supports "concaveman".
  • ...: Propagate to the method.
  • concavity: numeric a relative measure of concavity. 1 results in a relatively detailed shape, Infinity results in a convex hull. You can use values lower than 1, but they can produce pretty crazy shapes.
  • length_threshold: numeric. When a segment length is below this threshold, it stops being considered for further detailed processing. Higher values result in simpler shapes.

Returns

A sfc_POLYGON from sf or a data.frame in the case of concaveman

Details

The concaveman algorithm is based on ideas from Park and Oh (2012). A first implementation in JavaScript was proposed by Vladimir Agafonkin in mapbox. This implementation dramatically improved performance over the one stated in the paper using a spatial index. The algorithm was then ported to R by Joël Gombin in the R package concaveman that runs the JavaScript implementation proposed by Vladimir Agafonkin. Later, a C++ version of Vladimir Agafonkin's JavaScript implementation was proposed by Stanislaw Adaszewski in concaveman-cpp. This concaveman function uses Stanislaw Adaszewski's C++ code making the concaveman algorithm an order of magnitude (up to 50 times) faster than the Javascript version.

Examples

x <- runif(35) y <- runif(35) hull <- concaveman(x,y) plot(x,y, asp = 1) lines(hull, lwd = 3, col = "red") LASfile <- system.file("extdata", "Megaplot.laz", package="lidR") las = readLAS(LASfile, filter = "-drop_z_below 1") hull = st_concave_hull(las, length_threshold = 10) plot(hull)

References

Park, J.-S & Oh, S.-J. (2013). A New Concave Hull Algorithm and Concaveness Measure for n-dimensional Datasets. Journal of Information Science and Engineering. 29. 379-392.

  • Maintainer: Jean-Romain Roussel
  • License: GPL-3
  • Last published: 2024-07-09