如何在动物园对象的xyplot中仅反转一个y轴

时间:2012-01-23 10:18:13

标签: r lattice zoo

我在创建动物园对象的xyplot时遇到了一些麻烦。

我创建了一个简化的例子:

z <- zoo(cbind(a=1:4,b=11:14,c=10:13,d=5:8,e=10:7,f=1:4), 1991:1994)

我使用以下代码创建了一个多面板xyplot:

numLbl <- 4
xx <- seq(from = min(time(z)), to = max(time(z)), length.out = numLbl)
xyplot(z[,c(1,2,4,6)],scales = list(x = list(at = time (z), rot = 90)), layout = c(1,4), aspect = "fill", xlab = "",
panel = function (x,y, ...) {
    panel.abline (v = xx, col = "grey", lty = 3)
    panel.xyplot(x, y, type = "b", col = 1)
})

我想做的是只在其中一个面板上反转y轴。我找到了一个相关的例子:

http://r.789695.n4.nabble.com/lattice-limits-in-reversed-order-with-relation-quot-same-quot-td2399883.html

但是我不能让预付费用于我的例子。我对格子很新,而且可能还有我不理解的面板功能。

此外,如果有一种简单的方法可以将其中一个面板作为直方图而其他面板作为直线,我将非常感谢提示。

非常感谢任何帮助!

1 个答案:

答案 0 :(得分:1)

以下是执行第一项工作的预付款示例:

numLbl <- 4
count <- 0
swap <- 3
xx <- seq(from = min(time(z)), to = max(time(z)), length.out = numLbl)
xyplot(z[,c(1,2,4,6)],scales = list(x = list(at = time (z), rot = 90)),
    layout = c(1,4), aspect = "fill", xlab = "",
panel = function (x,y, ...) {
    panel.abline (v = xx, col = "grey", lty = 3)
    panel.xyplot(x, y, type = "b", col = 1)
},
prepanel = function (x,y, ...) {
    count <<- count + 1

    lims <- list(xlim=c(min(x),max(x)), ylim=c(min(y),max(y)));

    if (swap == count) {
        lims[[2]] = rev(lims[[2]]);
    }
    lims;
}
)