gpt4 book ai didi

r - 如何根据另一个栅格网格单元值对栅格进行子集(分类)?

转载 作者:行者123 更新时间:2023-12-03 00:06:56 29 4
gpt4 key购买 nike

如何对栅格重新分类(子集)r1 (与 r2 具有相同的尺寸和范围)基于 r2 中的以下条件在给定的示例中。

条件:

  • 如果网格单元格值为 r2>0.5 ,保留>0.5中对应的值以及紧邻0.5个值的相邻2个网格单元(即将r2中值为r1的网格单元缓冲到周围各个方向上的两个网格)并将其他值更改为0。

即。我如何更改 r1 中的网格单元格值这样它就会给出对应于 >0.5 的值r2 中每个方向的值网格单元及其缓冲(包围)两个网格单元.

如果我只需要获取网格单元 >0.5我可以通过以下代码轻松获得,但是,我想提取 >0.5值以及周围 2 个网格单元的值。

示例计算代码为:

set.seed(150)
r1 <- raster(ncol=10, nrow=5) #Create rasters
values(r1) = round(runif(ncell(r1),5,25))
r2 <- raster(ncol=10, nrow=5)
values(r2) = round(runif(ncell(r2),0.1,1))

selfun <- function(x,y) {
ifelse( x >0.5, y,0)
} # It works only for >0.5 gridcells, i need this gridcells and its adjacent
#two gridcells in each direction.
# it's like buffering the >0.5 grid cells with adjacent two grids and retaining corresponding grid cells values.

r3<-overlay(r2,r1,fun=selfun)
plot(r3)

谢谢。

最佳答案

我们可以使用 focal 函数创建一个显示感兴趣像素的掩码,并使用 mask 函数检索值。

我将创建我的示例,因为您创建的示例栅格太小,无法演示。

# Create example raster r1
set.seed(150)
r1 <- raster(ncol = 100, nrow = 50)
values(r1) <- round(runif(ncell(r1), 5, 25))

r1 <- crop(r1, extent(-60, 60, -30, 30))

plot(r1)

enter image description here

# Create example raster r2
r2 <- raster(ncol = 100, nrow = 50)
values(r2) <- rnorm(ncell(r2), mean = -1)

r2 <- crop(r2, extent(-60, 60, -30, 30))

plot(r2)

enter image description here

第一步是处理 r2,将任何大于 0.5 的值替换为 1,将其他值替换为 NA

# Replace values > 0.5 to be 1, others to be NA
r2[r2 > 0.5] <- 1
r2[r2 <= 0.5] <- NA

plot(r2)

enter image description here

在使用focal函数之前,我们需要定义一个代表窗口的矩阵和一个函数。

# Define a matrix as the window
w <- matrix(c(NA, NA, 1, NA, NA,
NA, 1, 1, 1, NA,
1, 1, 1, 1, 1,
NA, 1, 1, 1, NA,
NA, NA, 1, NA, NA), ncol = 5)
# Define a function to populate the maximum values when w = 1
max_fun <- function(x, na.rm = TRUE) if (all(is.na(x))) NA else max(x, na.rm = na.rm)

然后我们可以应用focal函数。

r3 <- focal(r2, w = w, fun = max_fun, pad = TRUE)

plot(r3)

enter image description here

r3 是一个显示我们想要从 r1 获取值的像素的图层。我们现在可以使用 mask 函数来实现此目的。

# Use the mask function extract values in r1 based on r3
r4 <- mask(r1, r3)
# Replace NA with 0
r4[is.na(r4)] <- 0

plot(r4)

r4 是最终输出。

enter image description here

关于r - 如何根据另一个栅格网格单元值对栅格进行子集(分类)?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51716315/

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