【发布时间】:2013-09-29 11:18:33
【问题描述】:
我有平均空间时间序列和每日平均观测数据。
如何以最简单的方式计算季节性平均值?季节应遵循 DJF(=冬季:12 月、1 月、2 月)、MAM、JJA 和 SON 的气象命名法。
这意味着 12 月的值来自 x-1 年。
这里很好地展示了每月平均值的计算: How to calculate a monthly mean?
在计算季节性平均值时可以遵循这个想法。但是,有几个注意事项使它不是很透明,必须小心!
我还在以前的帖子中处理过这个问题的一小部分:How to switch rows in R?
现在是完整的故事:
0:制作随机时间序列
ts.pdsi <- data.frame(date = seq(
from=as.Date("1901-01-01"),
to=as.Date("2009-12-31"),
by="day"))
ts.pdsi$scPDSI <- rnorm(dim(ts.foo)[1], mean=1, sd=1) # add some data
第一个:使用 seas 包并将季节添加到您的时间序列中,必须将其格式化为 data.frame。
library(seas)
# add moth/seasons
ts.pdsi$month <- mkseas(ts.pdsi,"mon") # add months
ts.pdsi$seas <- mkseas(ts.pdsi,"DJF") # add seasons
ts.pdsi$seasyear <- paste(format(ts.pdsi[,1],"%Y"),
ts.pdsi$seas ,sep="") # add seasyears, e.g. 1950DJF
这给了
> head(ts.pdsi)
date scPDSI month seas seasyear
1 1901-01-01 -0.10881074 Jan DJF 1901DJF
2 1901-02-01 -0.22287750 Feb DJF 1901DJF
3 1901-03-01 -0.12233192 Mär MAM 1901MAM
4 1901-04-01 -0.04440915 Apr MAM 1901MAM
5 1901-05-01 -0.36334082 Mai MAM 1901MAM
6 1901-06-01 -0.52079030 Jun JJA 1901JJA
第二次:然后您可以按照上述方法使用 $seasyear 列计算季节性平均值
> MEAN <- tapply(pdsi$scPDSI, ts.pdsi$seasyear, mean, na.rm = T)
> head(MEAN)
1901DJF 1901JJA 1901MAM 1901SON 1902DJF 1902JJA
-0.45451556 -0.72922229 -0.17669396 -1.12095590 -0.86523850 -0.04031273
注意:春季 (MAM) 和夏季 (JJA) 因严格的字母排序而切换。
第三次:切换回来
foo <- MEAN
for(i in 1:length(MEAN)) {
if (mod (i,4) == 2) {
foo[i+1] <- foo[i] #switch 2nd 3rd row (JJA <-> MAM)
foo[i] <- MEAN[i+1]
}
}
# and generate new names for the array
d <- data.frame(date=seq(from=as.Date("1901-01-01"), to=as.Date("2009-12-31"), by="+3 month"))
d$seas <- mkseas(d,"DJF")
d$seasyear <- paste(format(d[,1],"%Y"), d$seas ,sep="")
names(foo)<-d$seasyear # add right order colnames
MEAN <-foo
最后,这会产生季节性均值的时间序列。好吧,我觉得它太复杂了,我想周围有更简单的解决方案。
此外,这个解决方案在冬季 DJF 中还有一个非常大的问题:12 月到目前为止还没有从前一年中选择。这很容易解决(我猜),但使给定的方式更加复杂。
我真的希望周围有更好的想法!
【问题讨论】:
-
此代码 sn-p 可能会有所帮助:
dd <- c(Sys.Date(), as.Date(c("2013-11-30", "2013-12-01"))); season_year <- as.numeric(format(dd + 31, "%Y")). -
好点,snipplet 可能会有所帮助
-
为了解决冬季的问题(在DJF中,D应该是n-1年的D),一个想法是创建一个“假”的年份列,其中包含当前年份的值每个月,除了 12 月,您使用 n+1。
标签: r time-series mean