R语言 如何计算Map半径内的平均度量

mm9b1k5b  于 2022-12-24  发布在  其他
关注(0)|答案(1)|浏览(137)

我正在处理一个问题,它使用的数据类似于下面的代码片段:

name = c('A', 'B', 'C', 'D', 'E','F','G','H','I','J')
lat = runif(10,min=37,max=39)
lon = runif(10,min=-91,max=-89)
metric = runif(10,min=0,250)

df = as.data.frame(cbind(name,lat,lon,metric))

我希望能够选择一个半径为X千米的半径,在本例中假设半径为15千米,然后使用该半径首先计算数据中每一行在该范围内的观测值的数量,其中每一行都有一个转弯作为半径的中心,然后,我希望取半径内所有观测值的平均值。
理想情况下,最终数据集应如下所示:

name lat  lon    metric count avg_metric
A    37.1 -91.1  44     6     34.33    
B    37.2 -90.2  24     3     23.35 
C    37.3 -90.3  37     2     19.93

这些数字是虚构的,但看起来像这样的东西是我的目标。
我发现了一些代码,这种做什么,我正在寻找下面:

library(spatialrisk)

# Stores 
stores <- data.frame(store_id = 1:3,
                     lat = c(40.7505, 40.7502, 40.6045),
                     long = c(-73.8456, -73.8453, -73.8012))

# My location
me <- data.frame(lat = 40.7504, long = -73.8456)
spatialrisk::points_in_circle(stores, me$long[1], me$lat[1], radius = 100, lon = long)

然而,这并不是我想要的。有人能帮我指出正确的方向吗?任何帮助都将不胜感激!谢谢!

vuktfyat

vuktfyat1#

下面是一个使用sf库的例子,我转换到一个可以理解米的坐标系,然后使用st_buffer画圆,st_within计算重叠,然后使用sapply计算计数和平均度量。

library(sf)
library(dplyr)

name <- c('A', 'B', 'C', 'D', 'E','F','G','H','I','J')
lat <- runif(10,min=37,max=39)
lon <- runif(10,min=-91,max=-89)
metric <- runif(10,min=0,250)

df <- as.data.frame(cbind(name,lat,lon,metric))

# make a spatial data frame
df_sf <- st_as_sf(df, coords = c('lon', 'lat'), crs=4326)

# transform to a coordinate system which understands metres 
# the original data is near St Louis, so UTM 15 is appropriate
df_sf_transformed <- st_transform(df_sf, crs = 32615)

# make circles of radius 15km around each point
df_sf_buffers <- st_buffer(df_sf_transformed, dist = 15000) %>% st_geometry()

# work out which point is within each circle
overlaps <- st_within(y = df_sf_buffers, x = df_sf_transformed)

# count the number of overlaps for each circle
# the sapply function is like a for loop that iterates over each 
# row in the overlaps object and calls the length function to 
# calculate the length of each row
counts <- data.frame(count = sapply(overlaps, length))

# a custom function to sum the metrics for selected points
find_avg_metric <- function(sf_df, indices) {
    entries <- sf_df[indices, ]
    result <- sum(as.numeric(entries$metric))
    result
}

# iterate over the overlaps object and use the indices found to access 
# the relevant rows of the original data frame to sum up the metric column
metrics <- data.frame(avg_metric = sapply(overlaps, function(index) find_avg_metric(df_sf_transformed, index)))

# The final answer
final_result <- df %>% bind_cols(counts) %>% bind_cols(metrics)
final_result
#name              lat               lon           metric count avg_metric
#1     A 37.9383664987981  -90.567177023273 30.6012906949036     1   30.60129
#2     B 37.8796539758332 -89.6363721224479 139.638845692389     1  139.63885
#3     C 37.9519012323581 -90.8471902268939 106.271727592684     1  106.27173
#4     D 38.3774091359228 -89.1159357768483 186.965031607542     1  186.96503
#5     E 37.3993454128504 -89.7444549454376 29.5921949436888     2  194.88581
#6     F 38.6436389596201 -89.0847784169018 150.506012840196     1  150.50601
#7     G 38.4185414239764 -90.1974869910628 162.634110951331     1  162.63411
#8     H 38.2770276684314 -90.4734013564885 69.9945208616555     1   69.99452
#9     I 37.3666391288862 -89.6443270738237 165.293618629221     2  194.88581
#10    J  38.659956720192 -89.7836953452788 123.549888376147     1  123.54989

相关问题