Как создать полигоны Тиссена из точек, используя пакеты R? - PullRequest
8 голосов
/ 23 февраля 2012

У меня есть несколько наборов точек (для разных лет ~ 20)

Я хочу сгенерировать полигоны thiessen для каждого набора точек, используя r пространственных пакетов.

Я знаю, что это можно сделатьиспользуя ГИС, но, поскольку я хочу, чтобы пакетный процесс что-то в R был бы

полезным.

Ответы [ 2 ]

18 голосов
/ 23 февраля 2012

Вы не предоставили нам доступ к вашим данным, но вот пример для точек, представляющих города мира, используя подход, описанный Карсоном Фармером в его блоге .Надеюсь, это поможет вам начать работу ...

# Carson's Voronoi polygons function
voronoipolygons <- function(x) {
  require(deldir)
  require(sp)
  if (.hasSlot(x, 'coords')) {
    crds <- x@coords  
  } else crds <- x
  z <- deldir(crds[,1], crds[,2])
  w <- tile.list(z)
  polys <- vector(mode='list', length=length(w))
  for (i in seq(along=polys)) {
    pcrds <- cbind(w[[i]]$x, w[[i]]$y)
    pcrds <- rbind(pcrds, pcrds[1,])
    polys[[i]] <- Polygons(list(Polygon(pcrds)), ID=as.character(i))
  }
  SP <- SpatialPolygons(polys)
  voronoi <- SpatialPolygonsDataFrame(SP, data=data.frame(x=crds[,1],
    y=crds[,2], row.names=sapply(slot(SP, 'polygons'), 
    function(x) slot(x, 'ID'))))
}

Пример 1: входные данные - это SpatialPointsDataFrame:

# Read in a point shapefile to be converted to a Voronoi diagram
library(rgdal)
dsn <- system.file("vectors", package = "rgdal")[1]
cities <- readOGR(dsn=dsn, layer="cities")

v <- voronoipolygons(cities)

plot(v)

Voronoi diagram of cities

Пример 2: Вводимые данные - это координаты x, y:

dat <- data.frame(x=runif(100), y=runif(100))
v2 <- voronoipolygons(dat)
plot(v2)

Another voronoi diagram

2 голосов
/ 02 ноября 2017

Тот же принцип, что и в jbaums, но более простой код:

library(dismo)
library(rgdal)
cities <- shapefile(file.path(system.file("vectors", package = "rgdal")[1], "cities"))

v <- voronoi(cities)
plot(v)
...