gpt4 book ai didi

r - `dist`中的 `st_buffer`参数默认设置为什么单位?

转载 作者:行者123 更新时间:2023-12-04 05:03:28 25 4
gpt4 key购买 nike

我有以下墨西哥 map 。它显示了所有市政当局和大约400个气象站。

Mexico

我想在每个车站周围创建一个10公里的缓冲区,并最终将每个市政当局与位于每个半径内的车站相关联。

map 和测站存储在单独的sf对象上。我累了以下几点:

buffers <- st_buffer(stations, dist = 1)

我以为 dist参数设置为km,所以尝试了 dist = 10。不幸的是,这为每个工作站返回了 巨大的缓冲区。这就是为什么我使用 dist = 1,但是即使这些缓冲区也和状态一样大! This question,建议我将电台转换为爱尔兰网格,但无法复制已接受的答案。我现在想知道 dist参数设置为什么单位。

根据前面提到的问题,我认为将其设置为度。如何在每个站周围设置10公里的缓冲区?

附加信息:

在两个对象(墨西哥 map 和测站)上,我的CRS都设置为4326。

这是我的 stations数据:
> dput(head(stations))
structure(list(station_number = c(1004L, 1005L, 1008L, 1012L,
1017L, 1018L), station_alt = c(1925, 1844, 2323, 1589, 2172,
2053), month = c(9L, 9L, 9L, 9L, 9L, 9L), Mean_min = c(11.6,
12.75, 12.25, 13.9666666666667, 12.9, 12.6833333333333), Mean_max = c(26.9333333333333,
26.85, 24.0833333333333, 29.0333333333333, 24.8666666666667,
26.1333333333333), months_observed = c(5L, 5L, 5L, 5L, 5L, 5L
), geometry = structure(list(structure(c(-102.199, 22.001), class = c("XY",
"POINT", "sfg")), structure(c(-102.372, 21.781), class = c("XY",
"POINT", "sfg")), structure(c(-102.135, 22.203), class = c("XY",
"POINT", "sfg")), structure(c(-102.802, 21.794), class = c("XY",
"POINT", "sfg")), structure(c(-102.444, 22.233), class = c("XY",
"POINT", "sfg")), structure(c(-102.415, 22.141), class = c("XY",
"POINT", "sfg"))), class = c("sfc_POINT", "sfc"), precision = 0, bbox = structure(c(xmin = -102.802,
ymin = 21.781, xmax = -102.135, ymax = 22.233), class = "bbox"), crs = structure(list(
epsg = NA_integer_, proj4string = NA_character_), class = "crs"), n_empty = 0L)), sf_column = "geometry", agr = structure(c(station_number = NA_integer_,
station_alt = NA_integer_, month = NA_integer_, Mean_min = NA_integer_,
Mean_max = NA_integer_, months_observed = NA_integer_), .Label = c("constant",
"aggregate", "identity"), class = "factor"), row.names = c(NA,
6L), class = c("sf", "data.frame"))

最佳答案

您的座标是长/纬度,因此距离将以度为单位。您应该首先以米为单位投影到空间引用,然后占用10000米。
st_buffer手册说明了dist参数:

in case dist is a units object, it should be convertible to arc_degree if x has geographic coordinates, and to st_crs(x)$units otherwise



如果您将坐标留在4326,则应该可以像0.1一样取东西,对于墨西哥来说应该是11公里,但是您会看到一条警告消息:

In st_buffer.sfc(st_geometry(x), dist, nQuadSegs, endCapStyle = endCapStyle, : st_buffer does not correctly buffer longitude/latitude data



因此,首先转换为另一个投影(以米为单位),然后输入以米为单位的距离。这应该可以使用 EPSG 7801:
library(sf)

pois <- st_as_sf(stations)
st_crs(pois) <- 4326
pois <- st_transform(pois, crs = 7801)
plot(st_geometry(pois))

buff <- st_buffer(pois, dist = 10000)
plot(st_geometry(buff), add = TRUE)

用传单和测量工具进行控制:
buff <- st_transform(buff, crs = 4326)

library(leaflet)

leaflet() %>%
addTiles() %>%
addMeasure(primaryLengthUnit = "meters") %>%
addMarkers(data = pois) %>%
addPolygons(data = buff)

关于r - `dist`中的 `st_buffer`参数默认设置为什么单位?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54754277/

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