首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >计算多边形列表的整个重心/几何中心

计算多边形列表的整个重心/几何中心
EN

Stack Overflow用户
提问于 2014-10-24 00:08:22
回答 1查看 1.9K关注 0票数 2

我正在寻找一种方法来计算空间多边形列表中每个多边形的重心:

我以为用了一个循环,但他得到了我的第一个多边形,我不知道怎么做,我刚到R,有人能帮我密码吗:

代码语言:javascript
复制
for ( i in 1:length(polys1_T)) { 
  xx=mean(coordinates(polys1_T[[i]])[,1])
  yy=mean(coordinates(polys1_T[[i]])[,2])
  aa<-as.data.frame(cbind(xx,yy))
}

编辑:

代码:

代码语言:javascript
复制
 inter1 <- read.table("c:/inter1.csv", header=TRUE)

# add a category (required for later rasterizing/polygonizing)
inter1 <- cbind(inter1, 
                cat
                = rep(1L, nrow(inter1)), stringsAsFactors = FALSE)

# convert to spatial points
coordinates(inter1) <- ~long + lat

# gridify your set of points
gridded(inter1) <- TRUE

# convert to raster
r <- raster(inter1)

# convert raster to polygons
sp <- rasterToPolygons(r, dissolve = T)
plot(sp)
# addition transformation to distinguish well the set of polygons
polys <- slot(sp@polygons[[1]], "Polygons")
# plot
plot(sp, border = "gray", lwd = 2) # polygonize result

inter1.csv结果:

多边形是9个多边形的列表:是否可以计算每个多边形的重心?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-10-24 00:22:05

rgeos::gCentroid看一眼。你可以在很多方面应用它。如果您有一个SpatialPolygons对象,比方说,从对readOGR的调用中可以这样做:

代码语言:javascript
复制
map <- readOGR(dsn, layer)
centers <- data.frame(gCentroid(map, byid=TRUE))

把所有的质心从里面弄出来。

顺便说一句:虽然准确,但更常见的术语是“几何中心”/“质心”和“重心”。

编辑

对于普通的ol Polygons (“难”的方式,但稍微准确一点):

代码语言:javascript
复制
library(rgdal)
library(sp)
library(PBSmapping)
library(maptools)

do.call("rbind", lapply(polys, function(x) {
  calcCentroid(SpatialPolygons2PolySet(SpatialPolygons(list(Polygons(list(x), ID=1)))))
}))[,3:4]

##            X        Y
## 1  5.8108434 20.16466
## 2 -3.2619048 29.38095
## 3  5.5600000 34.72000
## 4  3.8000000 32.57037
## 5  6.3608108 32.49189
## 6 -2.2500000 31.60000
## 7 -8.1733333 27.61333
## 8  0.3082011 27.44444
## 9  8.6685714 26.78286

并且,用你的几乎等价的手工方法:

代码语言:javascript
复制
do.call("rbind", lapply(polys, function(x) {
  data.frame(mean(coordinates(x)[,1]), mean(coordinates(x)[,2]))  
}))

##   mean.coordinates.x....1.. mean.coordinates.x....2..
## 1                  5.819892                  20.15484
## 2                 -3.242593                  29.37778
## 3                  5.539474                  34.71579
## 4                  3.815517                  32.56552
## 5                  6.323034                  32.47191
## 6                 -2.230952                  31.60000
## 7                 -8.140476                  27.61905
## 8                  0.350000                  27.40885
## 9                  8.746825                  26.92063

每个方法都为每个list元素提供了质心(在您提供的示例中有9-而不是5)。

如果您有一个庞大的列表,可以考虑使用来自rbindlist包的data.table (更快+更有效的内存)。

票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/26539533

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档