r根据预定义的时间步长进行栅格累积和计算

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了r根据预定义的时间步长进行栅格累积和计算相关的知识,希望对你有一定的参考价值。

我有一个10个每日栅格数据的时间序列,我需要根据参考栅格的像素值(=时间0)计算-5到+5时间步长累积和。

我能够计算年累积总和(以下称为'sum_YY')

步骤1创建每日10个栅格时间序列

require(raster)
idx <- seq(as.Date("2010/1/1"), as.Date("2011/12/31"), '10 days')
r <- raster(ncol=5, nrow=5)
s <- stack(lapply(1:length(idx), function(x) setValues(r, values = sample(x = c(-5:5),size = ncell(r), replace = T))))
s <- setZ(s, idx)

步骤2按年计算累计总和

Y <- unique(format(as.Date(getZ(s), format = "X%Y.%m.%d"), format = "%Y"))
sum_YY <- stack()
for (i in Y) {
  dates <- format(getZ(s), "%Y") == i
  t <- calc(subset(s, which(dates)), cumsum)
  sum_YY <- stack(sum_YY,t)
}

但这不是我要找的输出。我需要根据参考光栅'refer'使用cumsum。

步骤3创建参考栅格

refer <- raster(ncol=5, nrow=5)
refer <- setValues(refer,sample(x = c(15:25),size = ncell(refer), replace = T))

'refer'栅格像素值表示时间步长'X',我想计算每年的“堆栈”时间步长X-5到X + 5的累积总和

即如果'参考'像素值X = 20,我需要计算每年从15到25层的累积总和。 “引用”中其他像素的方法相同

我不知道如何在计算中引入参考栅格,任何帮助?

太感谢了!!!

答案

我想不出干净的方法。但这是一种方法:

rs <- stack(refer, s)
a <- calc(rs, fun=function(x) sum(x[(x[1]-4):(x[1]+6)]))

StackSelect是针对这样的问题而设计的,但我现在意识到它需要更多的灵活性。能够一次选择多个图层并应用函数会很高兴。但你可以这样做(可能效率低下)

x <- calc(refer, function(x) (x-5):(x+5), forceapply=T)
y <- stackSelect(s, x)
z <- sum(y)

以上是关于r根据预定义的时间步长进行栅格累积和计算的主要内容,如果未能解决你的问题,请参考以下文章

Terra R - 使用自定义函数加速栅格数据的聚合()

R中矩阵和栅格的相对计算负担

R中的多栅格随机森林

gis流量多大

根据 R 中的文件名读取栅格子集

R语言经验累积分布函数计算和绘制实战