gpt4 book ai didi

r - 我总是丢失 R 中的时间索引——我该怎么办?

转载 作者:行者123 更新时间:2023-12-04 10:15:32 27 4
gpt4 key购买 nike

或者换一种说法:我怎样才能保持我的 ts 索引?
大多数情况下,我在计算中使用时间序列,它不再是 ts 对象。写函数返回ts对象并保留索引信息时应该遵循什么策略?

例如。:

#standard Hodrick Prescott Filter
hpfilter <- function(x,lambda=1600){
eye <- diag(length(x))
result <- solve(eye+lambda*crossprod(diff(eye,lag=1,d=2)),x)

### this is what I am talking about :)
### intuitively i´d maybe add something like this
result <- ts(result,start=start(x),end=end(x),frequency=frequency(x))
###

return(result)
}

但是,我觉得这样既笨拙又笨重。有没有更优雅的方法来做到这一点(也许我应该上课..)?

最佳答案

对于时间序列,子集化和其他一些函数会导致转换为矩阵或向量。不用重建时间序列,直接转移原ts的属性即可结果。

hpfilter <- function(x,lambda=1600){
eye <- diag(length(x))
result <-
solve(eye+lambda*crossprod(diff(eye,lag=1,d=2)),x)

attributes(result) <- attributes(x)
return(result)
}

您也可以使用子集来更改(但不附加)时间序列中的值:
hpfilter <- function(x,lambda=1600){
eye <- diag(length(x))
x[] <-
solve(eye+lambda*crossprod(diff(eye,lag=1,d=2)),x)

return(x)
}

关于r - 我总是丢失 R 中的时间索引——我该怎么办?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5674714/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com