[英]R apply.weekly() returns incorrect period when converting from daily to weekly time-series
我正在使用時間序列數據,並遇到apply.weekly()
的問題。 似乎在某個日期之后,幾周無法正確匯總。
library(xts)
value <- c(46.40269, 47.27100 ,47.73311, 46.12858, 44.54989 ,42.79287, 41.70017 ,41.22373, 40.16180, 38.48705 ,37.02111 ,35.95312, 37.47187, 42.59649 ,49.22880, 53.96820, 57.97346, 61.22755,61.79824, 65.05720, 65.30233 ,61.86191,58.03687, 55.17815, 52.88933, 51.47876, 50.31402, 48.91674, 47.47042)
DATE <- as.Date(c("2038-01-03", "2038-01-04", "2038-01-05", "2038-01-06", "2038-01-07" ,"2038-01-08", "2038-01-09", "2038-01-10", "2038-01-11", "2038-01-12", "2038-01-13" ,"2038-01-14", "2038-01-15" ,"2038-01-16" ,"2038-01-17", "2038-01-18", "2038-01-19", "2038-01-20", "2038-01-21", "2038-01-22", "2038-01-23", "2038-01-24" ,"2038-01-25", "2038-01-26", "2038-01-27", "2038-01-28", "2038-01-29", "2038-01-30", "2038-01-31"))
DF <- data.frame(DATE, value)
DF_daily <- xts(DF$value, order.by = DF$DATE)
DF_weekly <- apply.weekly(DF_daily, FUN=sum)
print(DF_weekly)
這將產生以下輸出:
[,1]
2038-01-03 46.40269
2038-01-10 311.39935
2038-01-16 231.69144
2038-01-31 840.70198
請注意,最后期限是15天。 現在,如果我改用2010年的日期,則可以完全滿足您的期望。 也就是說,使用
DATE <- as.Date(c("2010-01-03", "2010-01-04", "2010-01-05", "2010-01-06", "2010-01-07" ,"2010-01-08" ,"2010-01-09" ,"2010-01-10", "2010-01-11", "2010-01-12" ,"2010-01-13" ,"2010-01-14" ,"2010-01-15" ,"2010-01-16", "2010-01-17", "2010-01-18", "2010-01-19" ,"2010-01-20" ,"2010-01-21" ,"2010-01-22", "2010-01-23", "2010-01-24", "2010-01-25" ,"2010-01-26","2010-01-27" ,"2010-01-28" ,"2010-01-29" ,"2010-01-30", "2010-01-31"))
在上面的代碼中生成輸出:
[,1]
2010-01-03 46.40269
2010-01-10 311.39935
2010-01-17 280.92024
2010-01-24 427.18889
2010-01-31 364.28429
我不知道2038年是否有些奇怪?
我在64位Windows 7 Enterprise上運行此代碼, sessionInfo()
返回以下輸出
R version 3.2.3 (2015-12-10)
Platform: x86_64-w64-mingw32/x64 (64-bit)
Running under: Windows 7 x64 (build 7601) Service Pack 1
locale:
[1] LC_COLLATE=English_United States.1252 LC_CTYPE=English_United States.1252 LC_MONETARY=English_United States.1252
[4] LC_NUMERIC=C LC_TIME=English_United States.1252
attached base packages:
[1] stats graphics grDevices utils datasets methods base
other attached packages:
[1] xts_0.9-7 zoo_1.7-12
loaded via a namespace (and not attached):
[1] tools_3.2.3 grid_3.2.3 lattice_0.20-33
2038年1月19日是一個特殊的日期:凌晨3:14:08,一個32位的unix紀元(計算自1970年1月1日午夜以來的秒數)將溢出。 在處理時間戳時可能存在一個錯誤,導致此日期的計數器中斷。 許多數字存儲為帶符號的32位整數,最大值為2,147,483,647。
這被稱為“ 2038年問題” ,類似於Y2K問題。
但是, R Date
類型是從Unix Epoch開始的天數 ,而不是秒數 。 對我來說,這表明xts
軟件包存在問題。
在這個問題上您並不孤單( 這是有關郵件列表的2012年討論 ),並且似乎該錯誤來自系統日期處理和R日期處理之間的錯誤傳遞。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.