2012 年 9 月 17 日更新
这是一段使用自包含数据的代码,可以重现我的问题:
请记住,我拥有的实际数据维度是巨大的......
尺寸:3105、7025、21812625、12(nrow、ncol、ncell、nlayers)
我需要的是每一行的最大值的索引,列在图层上。所有 NA 应返回 NA 并且多个最大副本应返回第一个最大索引(或其他内容,必须一致)
# Create a test RasterStack
require(raster)
a <- raster(matrix(c(11,11,11,
NA,11,11,
11,11,13),nrow=3))
b <- raster(matrix(c(12,12,12,
NA,12,12,
40,12,13),nrow=3))
c <- raster(matrix(c(13,9,13,
NA,13,13,
13,NA,13),nrow=3))
d <- raster(matrix(c(10,10,10,
NA,10,10,
10,10,10),nrow=3))
corr_max <- raster(matrix(c(13,12,13,
NA,13,13,
40,12,13),nrow=3))
stack <- stack(a,b,c,d)
which.max2 <- function(x, ...)which.max(x)
# stackApply method
max_v_sApp <- stackApply(stack,rep(1,4),which.max2,na.rm=NULL)
# calc method
max_v_calc <- calc(stack,which.max)
希望这提供了足够的信息。
更新:
这可能有效......现在测试:
which.max2 <- function(x, ...){
max_idx <- which.max(x) # Get the max
ifelse(length(max_idx)==0,return(NA),return(max_idx))
}