- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我使用 quantmod 包下载了 MSFT 历史每日股票数据。我得到的是 xts/zoo 对象。我想将它转换为 ts 对象,以便我可以使用 forecast 包进行每日价格预测。
library(quantmod)
library(forecast)
library(xts)
library(zoo)
start <- as.Date('2018-01-01')
end <- as.Date('2018-08-14')
getSymbols('MSFT', src='yahoo', from=start, to=end)
#msft is xts/zoo object
msft <- MSFT[, 'MSFT.Close']
#convert msft to ts object
msft.ts <-ts(as.numeric(msft),
start=c(2018, yday(start(msft))),
frequency = 365)
msft(xts 对象)的索引如下所示。它们是缺少周末的每周数据。显然股票只在工作日交易。
[1] "2018-01-02" "2018-01-03" "2018-01-04" "2018-01-05" "2018-01-08"
[6] "2018-01-09" "2018-01-10" "2018-01-11" "2018-01-12" "2018-01-16"
[11] "2018-01-17" "2018-01-18" "2018-01-19" "2018-01-22" "2018-01-23"
msft.ts(ts 对象)的索引如下所示:
[1] 2018.003 2018.005 2018.008 2018.011 2018.014 2018.016 2018.019 2018.022
[9] 2018.025 2018.027 2018.030 2018.033 2018.036 2018.038 2018.041 2018.044
[17] 2018.047 2018.049 2018.052 2018.055 2018.058 2018.060 2018.063 2018.066
我对这些索引的含义感到困惑。 2018.之后的数字是天数吗?那些好像都不对。我猜可能不是因为我将频率设置为 365
,但实际上周末没有数据。遇到这种情况,我该怎么办? 我用谷歌搜索并发现 ts
仅适用于均匀间隔的数据。但是为了使用预测包,我需要提供 ts
对象,尽管看起来我在从 xts
转换后丢失了所有日期信息至 ts
目的。 如果有人能就此澄清我,我真的很感激。正确的做法是什么?我真的很困惑。我想使用预测包制作预测模型。非常感谢。
最佳答案
您要做的是保留 MSFT 时间序列中的日期并添加到其中。您可以为此使用包 timetk。或者,如果您愿意,扫描包,直到整洁的预测包寓言可用。 timetk 与 tidyquant 配合得很好。您可以使用 tk_tbl 将时间序列转换为小标题。
library(quantmod)
library(forecast)
start <- as.Date('2018-01-01')
end <- as.Date('2018-08-14')
getSymbols('MSFT', src='yahoo', from=start, to=end)
# forecast
my_aa <- auto.arima(Cl(MSFT))
my_forecast = forecast(my_aa, h = 10, level = 95)
library(timetk)
time_index <- tk_index(MSFT)
# future days need to be the same as used in the forecast, but because we don't want weekends we
# need to make sure we have enough records so 30 should cover it.
time_index_future <- tk_make_future_timeseries(time_index, n_future = 30, inspect_weekdays = T)
my_fc_future <- cbind(forecast = my_forecast$mean, forecast_low = my_forecast$lower, forecast_high = my_forecast$upper)
# select the needed number of records from the index
my_xts_future <- xts(my_fc_future , time_index_future[1:nrow(my_fc_future)])
my_xts_future
forecast forecast_low forecast_high
2018-08-14 108.6679 105.8490 111.4868
2018-08-15 108.8136 105.3287 112.2985
2018-08-16 108.9593 104.9167 113.0019
2018-08-17 109.1050 104.5728 113.6372
2018-08-20 109.2507 104.2768 114.2246
2018-08-21 109.3964 104.0170 114.7758
2018-08-22 109.5421 103.7857 115.2985
2018-08-23 109.6878 103.5776 115.7980
2018-08-24 109.8335 103.3889 116.2781
2018-08-27 109.9792 103.2168 116.7417
# merge forecast data with stock data
MSFT2 <- merge(MSFT, my_xts_future)
tail(MSFT2, 12)
MSFT.Open MSFT.High MSFT.Low MSFT.Close MSFT.Volume MSFT.Adjusted forecast forecast_low forecast_high
2018-08-10 109.42 109.69 108.38 109.00 18183700 108.5821 NA NA NA
2018-08-13 109.24 109.58 108.10 108.21 18472500 107.7952 NA NA NA
2018-08-14 NA NA NA NA NA NA 108.6679 105.8490 111.4868
2018-08-15 NA NA NA NA NA NA 108.8136 105.3287 112.2985
2018-08-16 NA NA NA NA NA NA 108.9593 104.9167 113.0019
2018-08-17 NA NA NA NA NA NA 109.1050 104.5728 113.6372
2018-08-20 NA NA NA NA NA NA 109.2507 104.2768 114.2246
2018-08-21 NA NA NA NA NA NA 109.3964 104.0170 114.7758
2018-08-22 NA NA NA NA NA NA 109.5421 103.7857 115.2985
2018-08-23 NA NA NA NA NA NA 109.6878 103.5776 115.7980
2018-08-24 NA NA NA NA NA NA 109.8335 103.3889 116.2781
2018-08-27 NA NA NA NA NA NA 109.9792 103.2168 116.7417
关于r - 将每日股票数据转换为时间序列对象时的问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51886160/
我正在阅读 Python 文档以真正深入了解 Python 语言,并遇到了 filter 和 map 函数。我以前使用过过滤器,但从未使用过映射,尽管我在 SO 上的各种 Python 问题中都见过这
当我尝试打印 BST 的级别顺序时,这个问题提示了我。 这是一个 Pre-Order Sequence: 4, 1, 2, 3, 5, 6, 7, 8 In_order Sequence : 1, 2
我的代码在 main(序列测试;)的第一行出现错误,指出它是对 sequence::sequence() 的 undefined reference 。我无法更改 main 中的代码。有谁知道我该如何
这可能很简单,但我在通常的 latex 指南中找不到任何相关内容。在这句话中: {\em hello\/} “\/”的目的是什么? 最佳答案 这就是所谓的斜体校正。其目的是确保斜体文本后有适当的间距。
当我从 Postgresql 表中删除所有记录,然后尝试重置序列以在插入时开始一个编号为 1 的新记录时,我得到不同的结果: SELECT setval('tblname_id_seq', (SELE
在版本10.0.3中,MariaDB引入了一种称为序列的存储引擎。 其ad hoc为操作生成整数序列,然后终止。 该序列包含正整数,以降序或升序排列,并使用起始,结束和递增值。 它不允许在多个查询中
如何在 Groovy 中获取给定数字的序列,例如: def number = 169 // need a method in groovy to find the consecutive number
基本上,如果这是 .NET,它看起来像这样: ISomething { string A { get; } int B { get; } } var somethings = new List
说以下代码部分(同一块): A <= 1 A <= 2 变量 A 总是被赋值为 2 吗?还是会出现竞争条件并分配 1 或 2? 我对非阻塞赋值的理解是,由硬件在 future 分配变量 A,因此它可能
在运行 WiX 设置时,我正在寻找操作列表及其顺序。不知何故,官方网站似乎没有提供任何信息。 基本问题是我想正确安排我的自定义操作。通常我需要使用 regsvr32.exe 注册一个 DLL,而这只能
F#初学者在这里 我想创建一个类型,它是具有至少一个元素的另一种具体类型(事件)的序列。任何其他元素都可以在以后随时添加。通常在 C# 中,我会创建一个具有私有(private) List 和公共(p
作为构建过程和不断发展的数据库的一部分,我试图创建一个脚本,该脚本将删除用户的所有表和序列。我不想重新创建用户,因为这将需要比所允许的更多的权限。 我的脚本创建了一个过程来删除表/序列,执行该过程,然
我想恢复两个向量的第一个日期和相同向量的第二个日期之间的日期序列,.... 这是一个例子: dates1 = as.Date(c('2015-10-01', '2015-03-27', '2015-0
这个问题已经有答案了: sql ORDER BY multiple values in specific order? (12 个回答) 已关闭 9 年前。 我有一个 sql 语句,我想要ORDER
我想恢复两个向量的第一个日期和相同向量的第二个日期之间的日期序列,.... 这是一个例子: dates1 = as.Date(c('2015-10-01', '2015-03-27', '2015-0
在用java编写代码时,我需要用“],[”分割字符串。下面是我的代码。 try (BufferedReader reader = new BufferedReader(new InputStreamR
这个问题已经有答案了: Project Euler Question 14 (Collatz Problem) (8 个回答) 已关闭 9 年前。 我正在尝试查找数字的 Collatz 序列。以下
我有一个例程函数process_letter_location(const char& c, string &word)。 在我的 main 中,我声明了一系列字符串变量,如下所示: string s
我需要找到最长的多米诺骨牌链,给定一组 12 个随机挑选的多米诺骨牌。我已经递归地生成了多米诺骨牌的所有可能性(使用 0 到 12 的面值有 91 种可能性)。多米诺骨牌由一 block “砖 blo
我有这个数据结构 Seq,它继承了类 vector 但有一些额外的功能。使用这个数据结构 Seq 我有这个预定义的数据结构: typedef Seq > MxInt2d; 我现在想要一个包含多个 Mx
我是一名优秀的程序员,十分优秀!