gpt4 book ai didi

r - 执行 st_union() 操作后如何将多多边形几何体分成多个多边形对象?

转载 作者:行者123 更新时间:2023-12-02 04:25:20 27 4
gpt4 key购买 nike

我有一组多边形,其中一些多边形相交和/或接触(公共(public)边界)。我正在使用 R 的 sf 包对多边形执行操作。到目前为止,我的方法是使用 sf::st_union() ,它可以根据需要连接相邻和相交的多边形,但它也将所有多边形组合成一个 MULTIPOLYGON 几何图形。我希望将每个多边形分隔为 sf(data.frame) 类,其中每个多边形对象在 data.frame

中显示为一行

我在下面展示了一个例子。我首先创建一个示例数据集:

    # Creating four example polygons, of which two (two squares) are neighbors:

p1 <- rbind(c(0,0), c(1,0), c(3,2), c(2,4), c(1,4), c(0,0))
pol1 <-st_polygon(list(p1))
p2 <- rbind(c(3,0), c(4,0), c(4,1), c(3,1), c(3,0))
pol2 <-st_polygon(list(p2))
p3 <- rbind(c(4,0), c(4,1), c(5,1), c(5,0),c(4,0))
pol3 <-st_polygon(list(p3))
p4 <- rbind(c(3,3), c(4,2), c(4,3), c(3,3))
pol4 <-st_polygon(list(p4))

d = data.frame(some_attribute = 1:4)
d$geometry = st_sfc(pol1,pol2,pol3,pol4)
df = st_as_sf(d)

class(df)
#[1] "sf" "data.frame"

df
# Simple feature collection with 4 features and 1 field
# geometry type: POLYGON
# dimension: XY
# bbox: xmin: 0 ymin: 0 xmax: 5 ymax: 4
# epsg (SRID): NA
# proj4string: NA
# some_attribute geometry
# 1 1 POLYGON((0 0, 1 0, 3 2, 2 4...
# 2 2 POLYGON((3 0, 4 0, 4 1, 3 1...
# 3 3 POLYGON((4 0, 4 1, 5 1, 5 0...
# 4 4 POLYGON((3 3, 4 2, 4 3, 3 3))

plot(df) 给出:

plot(df)

然后,我执行 st_union() 操作,将所有相交或接触的多边形几何图形(上面的两个正方形)合并为一个:

    df_union <- df %>% st_union() 
df_union
# Geometry set for 1 feature
# geometry type: MULTIPOLYGON
# dimension: XY
# bbox: xmin: 0 ymin: 0 xmax: 5 ymax: 4
# epsg (SRID): NA
# proj4string: NA
# MULTIPOLYGON(((3 3, 4 3, 4 2, 3 3)), ((4 0, 3 0...

plot(df_union) 结果:

plot(df_union)

如上所示,df_union 的结果是一个只有一行的 MULTIPOLYGON 几何图形。我想执行一个操作,将每个多边形分成一个几何图形,如上图所示,但会产生多个多边形对象,与此等效:

    # Simple feature collection with 4 features and 1 field
# geometry type: MULTIPOLYGON
# dimension: XY
# bbox: xmin: 0 ymin: 0 xmax: 5 ymax: 4
# epsg (SRID): NA
# proj4string: NA
# some_attribute geometry
# 1 1 POLYGON((0 0, 1 0, 3 2, 2 4...
# 2 2 POLYGON((3 0, 4 0, 5 1, 5 0...
# 3 3 POLYGON((3 3, 4 2, 4 3, 3 3))

如何使用 sf 包执行此操作?

最佳答案

感谢 Edzer 提供了答案并为我们提供了很棒的 sf 包!

正如 Edzer 所提到的,执行 st_cast 会将 MULTIPOLYGON 对象转换为多个 POLYGON 对象:

    df_union_cast <- st_cast(df_union, "POLYGON")
df_union_cast
# Geometry set for 3 features
# geometry type: POLYGON
# dimension: XY
# bbox: xmin: 0 ymin: 0 xmax: 5 ymax: 4
# epsg (SRID): NA
# proj4string: NA
# POLYGON((3 3, 4 3, 4 2, 3 3))
# POLYGON((4 0, 3 0, 3 1, 4 1, 5 1, 5 0, 4 0))
# POLYGON((0 0, 1 4, 2 4, 3 2, 1 0, 0 0))

关于r - 执行 st_union() 操作后如何将多多边形几何体分成多个多边形对象?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42512431/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com