簡體   English   中英

在R中將不規則時間序列更改為規則時間序列1分鍾

[英]Changing Irregular Time Series to Regular Time series by 1 minutes in R

我有一個稱為dts的時間序列,它是不規則的時間序列。

                Date| V1
1994-02-08 01:09:00 | 0.1
1994-02-08 01:18:00 | 0.1
1994-02-08 01:41:00 | 0.1
1994-02-08 01:46:00 | 0.1
1994-02-08 01:50:00 | 0.1
1994-02-08 01:57:00 | 0.1
1994-02-12 20:27:00 | 0.1
1994-02-12 20:28:00 | 0.1
1994-02-12 20:30:00 | 0.1
1994-02-12 20:30:00 | 0.1 

我想使其定期並每1分鍾安排一次。 所需的結果應該是:

                Date| V1
1994-02-08 01:09:00 | 0.1
1994-02-08 01:10:00 | 0.0
1994-02-08 01:11:00 | 0.0
1994-02-08 01:12:00 | 0.0
1994-02-08 01:13:00 | 0.0
1994-02-08 01:14:00 | 0.0
1994-02-08 01:15:00 | 0.0
1994-02-08 01:16:00 | 0.0
1994-02-08 01:17:00 | 0.0
1994-02-08 01:18:00 | 0.1 

我想使其規則化,以便在規則時間序列上應用移動平均函數。 任何幫助將不勝感激。 謝謝!

library(xts)

# Create evenly spaced timestamps at frequency you desire (keep it simple to 1 hour here):
ts.1min <- seq(as.POSIXct("2016-10-12 12:00:00"), as.POSIXct("2016-10-12 13:00:00"), by = paste0("60 s"))

# Generate your data for 10 random timestamps in the 1 hour interval:
set.seed(1)
x.toy <- xts(round(rnorm(10, mean = 0, sd = 0.2), 1), 
             ts.1min[sample(x = 1:length(ts.1min), size = 10, replace = FALSE)], dimnames = list(NULL, "V1"))

# > x.toy
# V1
# 2016-10-12 12:00:00  0.1
# 2016-10-12 12:07:00  0.3
# 2016-10-12 12:12:00  0.0
# 2016-10-12 12:15:00  0.1
# 2016-10-12 12:17:00 -0.1
# 2016-10-12 12:20:00  0.1
# 2016-10-12 12:21:00 -0.2
# 2016-10-12 12:38:00 -0.2
# 2016-10-12 12:46:00  0.1
# 2016-10-12 12:57:00 -0.1


# Fill timestamps with no value as 0:
x.res <- merge(x.toy, xts(, ts.1min), fill = 0)

# > head(x.res, 10)
# V1
# 2016-10-12 12:00:00 0.1
# 2016-10-12 12:01:00 0.0
# 2016-10-12 12:02:00 0.0
# 2016-10-12 12:03:00 0.0
# 2016-10-12 12:04:00 0.0
# 2016-10-12 12:05:00 0.0
# 2016-10-12 12:06:00 0.0
# 2016-10-12 12:07:00 0.3
# 2016-10-12 12:08:00 0.0
# 2016-10-12 12:09:00 0.0

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM