在ggplot2中具有平均轮廓的刻面时间序列

use*_*111 6 r time-series ggplot2

使用以下模拟时间序列:

n=70
m1 = matrix(rnorm(n), ncol=7)
m2 = matrix(rnorm(n, 0,4), ncol=7)
d = data.frame(rbind(m1,m2), cl=rep(c(1,2), each=5))
Run Code Online (Sandbox Code Playgroud)

(前7列代表时间点,最后一列代表该类)

是否可以使用ggplot2构建包含每个图中平均曲线的分面时间序列?

结果应如下所示:绘制平均曲线

Eri*_*ail 12

它可能不是最漂亮的代码,但我相信它可以满足您的需求,

n=70
m1 = matrix(rnorm(n), ncol=7)
m2 = matrix(rnorm(n, 0,4), ncol=7)
d = data.frame(rbind(m1,m2), cl=rep(c(1,2), each=5))

d <- cbind(paste("d", 1:NROW(d), sep = ""), d)
names(d)[1] <- "id.var"

library(reshape)
longDF <- melt(d, id=c("cl", "id.var"))
library(ggplot2)

p <- ggplot(data = longDF, aes(x = variable, y = value, group = id.var))
p + geom_line() + stat_smooth(aes(group = 1), method = "lm", 
se = FALSE, colour="red") + facet_grid(cl ~ .)
Run Code Online (Sandbox Code Playgroud)

请不要犹豫,改进我的代码.

带有stat_smooth和facet_grid的意大利面条图

  • 我很高兴,我知道当你被卡住时感觉如何.您应该尝试将`se = FALSE`更改为`se = TRUE`,我经常发现这些信息非常有用. (2认同)