我有一个大数据框。这是样本数据(前几次观察)。
Year ComplaintCategory Days Loop
FY07-09 Service 1 Short
FY07-09 Service 22 Short
FY07-09 Product 15 Long
FY07-09 Product 6 Long
FY07-09 Product 6 Long
FY07-09 Service 3 Short
我想在条件箱图上只显示中值。计算与每个箱图相对应的中值,并将其存储在矢量 CalculatedMedian 中。中值如下。
12.0 26.0 13.5 17.0 20.0 48.0 35.0 21.0 NA NA 0.0 NA NA 29.0 30.0 19.0
如何在每个面板中仅打印中值,并在中位数处打印相应的箱图?
bwplot(Days ~ Loop | factor(Year),
ProductData, layout = c(8, 1), pch = rep("|", 2),
ylim = c(-10,100), scales=list(y = list(at=seq(0, 100,10))),
main=list(label="", cex=1.4),
ylab=list(label="Settlement Days", cex=1.3),
xlab=list(label="Loop", cex=1.3),
par.settings = list( box.rectangle = list(col= "black",lwd=1.3,lty=1),
box.umbrella = list(col= "black",lwd=1.3,lty=1),
ylim = seq(0, 100, by=10),
plot.symbol = list(col='black')),
panel=function(x, y,...) {
panel.abline(v = x, h = seq(0, 100, by = 10),
col = "lightgrey",lty = 2,lwd=1)
panel.bwplot(x, y,fill=c('lemonchiffon1','lavenderblush1'),...)
panel.text(x = x, y =CalculatedMedian, labels = CalculatedMedian)}
以下是代码的输出:
答案 0 :(得分:0)
这是使用一些测试数据的最小示例。如果您想要一个包含原始数据的解决方案,请提供可重现的示例。
这里我们在调用中创建一个中位数矢量,然后使用从中位数获得的坐标绘制它们。
dd <- data.frame(
x = rnorm(100),
ind = as.factor(rbinom(100, 3, 1/3))
)
bwplot(x ~ ind, data = dd, md = tapply(dd$x, dd$ind, median),
panel = function(x, y, md, ...) {
panel.bwplot(x, y, ...)
panel.text(x = 1:4, y = md, labels = round(md, 2), pos = 3)
})