我有一个关于箱线图的绘图问题(使用基本图形)。
我有几个数据数组,我希望将它们变成箱形图并进行比较。这些数组反映了不同的实验,我想展示的是基本结果和实验的百分比差异(在一个图上!)。即第一个 y 轴上的基本结果和第二个 y 轴上的 % diff:
base <- array(runif(12*24*3), dim=c(12,24,3))
exp1 <- array(runif(12*24*3), dim=c(12,24,3))
exp2 <- array(runif(12*24*3), dim=c(12,24,3))
exp3 <- array(runif(12*24*3), dim=c(12,24,3))
exp4 <- array(runif(12*24*3), dim=c(12,24,3))
# calc p.diff
p.diff <- function(mod,base) {
100.0*((mod-base)/base) }
a <- p.diff(exp1,base)
b <- p.diff(exp2,base)
c <- p.diff(exp3,base)
# combine the % diff arrays
exps <- list(a,b,c)
# plot the results
boxplot(base, xlim=c(1,4), col="gray", xaxt="n", ylab="Base values", outline=FALSE)
axis(side=1, 1:4, labels=c("base","% exp1","% exp2","% exp3") )
par(new=TRUE)
boxplot(exps, col="red", ylim=c(-200,200), outline=FALSE, axes=FALSE)
axis(4)
grid()
这几乎可行,但我没有正确定位不同的箱形图(如果你运行我的例子,你会明白我的意思)。那么有没有更好的方法来控制箱线图的位置呢?还是产生类似类型图形的更好方法?