如何在多个plot.zoo中添加多条直线

时间:2013-10-11 09:19:45

标签: r plot zoo

我有多个时间序列数据图,我需要在每个图中使用一条水平线,但水平值不同(第1个图:h=50,第2个图:h=48 ...)。< / p>

我尝试了abline(h=50...并在每个情节中得到了水平线。 我尝试了abline(h=c(50,48...并在每个情节中获得了多条水平线。

我无法弄清楚如何获取plot.zoo索引以便在第一个绘图中绘制h=50,在第二个绘图中绘制h=48,依此类推。

library(xts)
data(sample_matrix)
x <- as.xts(sample_matrix)

# plot with single line
my.panel <- function(x, ...) {
    lines(x, ...)
    abline(h=50, col = "red", lty="solid", lwd=1.5 )
}
plot.zoo(x, main="title",
plot.type="multiple", type="o", lwd=1.5, col="blue",
panel=my.panel)


# plot multiple lines in all plots
my.panel <- function(x, ...) {
    lines(x, ...)
    abline(h=c(50,50,48,50), col = "red", lty="solid", lwd=1.5 )}

plot.zoo(x, main="title",
plot.type="multiple", type="o", lwd=1.5, col="blue",
panel=my.panel)

1 个答案:

答案 0 :(得分:6)

在实际?plot.zoo文本中未详细说明在多面板图中自定义单个面板。在“详细信息”部分中,您会发现:
“对于自定义面板,panel可以引用parent.frame$panel.number以确定调用面板的帧。请参阅示例。”还有很多例子。使用它们作为模板,我发现这可以是一种调用单独面板的方法,并在每个面板中单独绘制hline。 <强>更新。感谢@G。 Grothendieck进行编辑,使代码更多更清洁!

# create values for hline, one for each panel
hlines <- c(50, 50, 48, 50)

# panel function that loops over panels
my.panel <- function(x, ...) {
  lines(x, ...)
  panel.number <- parent.frame()$panel.number
  abline(h = hlines[panel.number], col = "red", lty = "solid", lwd = 1.5)
}

plot.zoo(x, main = "title", type = "o", lwd = 1.5, col = "blue", panel = my.panel)

enter image description here