【发布时间】:2018-08-06 22:12:09
【问题描述】:
如何根据给定示例中r2 中的以下条件重新分类(子集)栅格r1(与r2 具有相同的维度和范围)。
条件:
- 如果
r2的网格单元格值为>0.5,则保留对应的值和相邻的2个网格单元格旁边的0.5个值(即将r2中值为>0.5的网格单元格缓冲到周围的两个网格中所有方向)在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)
谢谢。
【问题讨论】:
标签: r raster r-raster rasterizing