使用 R 的 dygraph 仅按年份绘制 xts 时间序列?
Use dygraph for R to plot xts time series by year only?
我正在尝试使用 R 库的新 dygraphs 来绘制每年波士顿马拉松比赛中男性和女性的获胜时间。我有一个以秒为单位的获胜时间数据框,这是其中的一部分:
winners <- data.frame(year=1966:1971, mensec=c(8231, 8145, 8537, 8029, 7830, 8325), womensec=c(12100, 12437, 12600, 12166, 11107, 11310))
但我不知道如何从中创建 xts 对象。我可以从每一列创建一个规则的时间序列,并在单独的图表中使用 dygraph 绘制每个图表
men <- ts(winners$mensec, frequency = 1, start=winners$year[1])
dygraph(men)
women <- ts(winners$womensec, frequency = 1, start=winners$year[1])
dygraph(women)
如果我尝试 cbind 时间序列,它将在 dygraph 中不起作用
both <- cbind(men, women)
dygraph(both)
错误信息是
xts 错误(x.mat,order.by = order.by,频率 = 频率(x),...):
NROW(x) 必须匹配长度(order.by)
有什么建议吗?谢谢
这看起来像是 as.xts.ts
中的错误。它使用 length(x)
创建索引的日期序列,其中 returns 矩阵的元素数(不是行数)。
您可以通过在 ts 对象上调用 cbind
之前使用 as.xts
来解决它。
both <- cbind(men=as.xts(men), women=as.xts(women))
看来约书亚回答了问题。这是完整的答案,代码略有不同,还带有年份 x 轴格式化程序。
library(xts)
library(dygraphs)
winners <- data.frame(
year=1966:1971
, mensec=c(8231, 8145, 8537, 8029, 7830, 8325)
, womensec=c(12100, 12437, 12600, 12166, 11107, 11310)
)
winners_xts <- as.xts(
winners[-1]
, order.by = as.Date(
paste0(winners$year,"-01-01",format="%Y-01-01")
)
)
dygraph( winners_xts ) %>%
dyAxis(
name="x"
,axisLabelFormatter = "function(d){ return d.getFullYear() }"
)
# using the original data here is a way to merge
# merge will work just like cbind
# but need to convert to xts first
men <- ts(winners$mensec, frequency = 1, start=winners$year[1])
women <- ts(winners$womensec, frequency = 1, start=winners$year[1])
do.call(merge,Map(as.xts,list(men=men,women=women)))
我正在尝试使用 R 库的新 dygraphs 来绘制每年波士顿马拉松比赛中男性和女性的获胜时间。我有一个以秒为单位的获胜时间数据框,这是其中的一部分:
winners <- data.frame(year=1966:1971, mensec=c(8231, 8145, 8537, 8029, 7830, 8325), womensec=c(12100, 12437, 12600, 12166, 11107, 11310))
但我不知道如何从中创建 xts 对象。我可以从每一列创建一个规则的时间序列,并在单独的图表中使用 dygraph 绘制每个图表
men <- ts(winners$mensec, frequency = 1, start=winners$year[1])
dygraph(men)
women <- ts(winners$womensec, frequency = 1, start=winners$year[1])
dygraph(women)
如果我尝试 cbind 时间序列,它将在 dygraph 中不起作用
both <- cbind(men, women)
dygraph(both)
错误信息是
xts 错误(x.mat,order.by = order.by,频率 = 频率(x),...): NROW(x) 必须匹配长度(order.by)
有什么建议吗?谢谢
这看起来像是 as.xts.ts
中的错误。它使用 length(x)
创建索引的日期序列,其中 returns 矩阵的元素数(不是行数)。
您可以通过在 ts 对象上调用 cbind
之前使用 as.xts
来解决它。
both <- cbind(men=as.xts(men), women=as.xts(women))
看来约书亚回答了问题。这是完整的答案,代码略有不同,还带有年份 x 轴格式化程序。
library(xts)
library(dygraphs)
winners <- data.frame(
year=1966:1971
, mensec=c(8231, 8145, 8537, 8029, 7830, 8325)
, womensec=c(12100, 12437, 12600, 12166, 11107, 11310)
)
winners_xts <- as.xts(
winners[-1]
, order.by = as.Date(
paste0(winners$year,"-01-01",format="%Y-01-01")
)
)
dygraph( winners_xts ) %>%
dyAxis(
name="x"
,axisLabelFormatter = "function(d){ return d.getFullYear() }"
)
# using the original data here is a way to merge
# merge will work just like cbind
# but need to convert to xts first
men <- ts(winners$mensec, frequency = 1, start=winners$year[1])
women <- ts(winners$womensec, frequency = 1, start=winners$year[1])
do.call(merge,Map(as.xts,list(men=men,women=women)))