1

我想制作一个图表,facet_wrap并将其绘制在 pdf 文件的不同页面中。我读过很多选项,这很有效: R + ggplot:在多个页面上绘图, 但只有当你在每个页面中都有相同的行时。

我有这个演示数据来解释我的情况:

A <- data.frame(TIME = rep(c(0, 5, 10, 15, 30, 45, 60), 5))
A$C <- (1 - exp(-0.2*A$TIME))
A$ID <- rep(1:5, each = 7)
A$R <- rnorm(35, mean = 1, sd = 0.01)
A$C2 <- A$C*A$R
Pages <- 5
A2 <- A[c(1,4:8,10:22,24:35),]

所以,我有不同数量的观察 ID。我试图用每个 ID 中的观察次数创建一个向量(我想要每页一个 ID),但它不起作用。

nrws <- ddply(A2, .(ID), "nrow")
nsamp <- nrws[,2]

pdf("Test.pdf")
for (i in seq(Pages))
  {
    slice = seq(((i-1)*nsamp[i]),(i*nsamp[i]))
    slice2 = slice[!(slice > nrow(A2))]
    A3 = A2[slice2,]
    p1 <- ggplot(A3, aes(x = TIME, y = C2)) +  
      geom_line(size = 0.5) +
      geom_point(size = 1) +
      facet_wrap(~ID)
print(p1)
  }
dev.off()

你可以帮帮我吗?

提前致谢, 纳乔

4

1 回答 1

1

我认为您在尝试计算“切片”时想多了。也许你想要这个?

不完全确定。如果您不需要每页只需要一个 ID facet_wrap,并且您可能需要明确设置比例以使其在页面之间保持相同。

library(plyr)

A <- data.frame(TIME = rep(c(0, 5, 10, 15, 30, 45, 60), 5))
A$C <- (1 - exp(-0.2*A$TIME))
A$ID <- rep(1:5, each = 7)
A$R <- rnorm(35, mean = 1, sd = 0.01)
A$C2 <- A$C*A$R
Pages <- 5
A2 <- A[c(1,4:8,10:22,24:35),]

nrws <- ddply(A2, .(ID), "nrow")
nsamp <- nrws[,2]

pdf("Test.pdf")
for (i in seq(Pages))
{
#  slice = seq(((i-1)*nsamp[i]),(i*nsamp[i]))
#  slice2 = slice[!(slice > nrow(A2))]
#  A3 = A2[slice2,]

  A3 = A2[A2$ID==i,]
  p1 <- ggplot(A3, aes(x = TIME, y = C2)) +  
    geom_line(size = 0.5) +
    geom_point(size = 1) +
    facet_wrap(~ID)
  print(p1)
}
dev.off()
于 2015-11-06T12:12:10.110 回答