我想限制使用'lsmeans'
R中的包计算的事后对比。
library(nlme) #for gls
model<-gls(time~ benchmark*gc*opt, method="REML",data=d)
lsmeans.d<-lsmeans(model, ~benchmark:gc:opt)
pairs(lsmeans.d)
这将输出基准 x gc x opt 的所有可能组合的比较。
我的问题是:如何在 lsmeans 函数中指定仅计算和输出每个唯一基准:gc 组合中的比较?
我只想知道它们是否在基准 x gc 的每个组合中的“开和关”处理之间存在显着差异。我添加了红线来显示这一点。
原始数据如下:
来自2的示例
d=expand.grid(obs=0:10, benchmark=c('antlr', 'bloat', 'chart', 'eclipse', 'fop', 'hsqldb', 'jython', 'luindex', 'lusearch', 'pmd', 'xalan'), gc=c('CopyMS', 'GenCopy', 'GenImmix', 'GenMS', 'Immix'), opt=c('on', 'off'), heapSize=seq(from=1.5, to=4, by=0.5))
d$time = rexp(nrow(d), 0.01)+1000
d$time = d$time + abs(d$heapSize-3)*100
d$time[d$opt=='on'] = d$time[d$opt=='on']-200
d$time[d$opt=='on' & d$benchmark=='bloat'] = d$time[d$opt=='on' & d$benchmark=='bloat'] + 190
d$time[d$opt=='on' & d$benchmark=='pmd' & d$gc=='Immix'] = d$time[d$opt=='on' & d$benchmark=='pmd' & d$gc=='Immix'] + 600
ggplot() +
facet_grid(gc~benchmark) +
geom_boxplot(data=d, mapping=aes(x=opt, y=time, color=opt))