3 * 3邻域的示例,其中总和乘以中心值" center"。
library(raster)
r <- raster(ncol=10, nrow=10)
r[] <- 1:100
f<-function(x,center) {sum(x)*center}
r.f <- focal(r, w=matrix(1,3,3),fun=f}
答案 0 :(得分:2)
library(raster)
r <- raster(ncol=10, nrow=10)
r[] <- 1:100
r.f <- focal(r, w=matrix(1,3,3)) * r
答案 1 :(得分:1)
有趣。由于参数fun
必须接受多个值,因此可能应该使用
f <-function(x) {
y = sum(x)/x[5]
return(y)
}
因为你总是提供一个3x3矩阵的x
,所以第五个元素将是中心元素。
我正在使用的机器上没有R
,因此我无法验证: - (