如何根据数据集中的列覆盖 ggplot2
图例指南中的 aes
大小值?
请参考以下示例(编辑 2:添加了 Trial C,并将线条尺寸改为使用对数刻度):
library(data.table)
set.seed(26798)
dt<-rbind(data.table(Trial="A",Value=rweibull(1000,1.0,0.5)),
data.table(Trial="B",Value=rweibull(100,1.2,0.75)),
data.table(Trial="C",Value=rweibull(10,1.3,0.8)))
# Add a count and something like a cumulative distribution:
dt2<-dt[order(Trial,Value),list(Value,N=.N),by=Trial][,list(Value,N,y=1-cumsum(N)/sum(N)),by=Trial]
dt2
## Trial Value N y
## 1: A 0.0003628745 1000 0.999
## 2: A 0.0013002615 1000 0.998
## 3: A 0.0017002173 1000 0.997
## 4: A 0.0022597343 1000 0.996
## 5: A 0.0026608082 1000 0.995
## ---
##1096: B 1.6821827814 100 0.040
##1097: B 2.2431595707 100 0.030
##1098: B 2.5122479833 100 0.020
##1099: B 2.5519954416 100 0.010
##1100: B 2.6848412995 100 0.000
ggplot(dt2) +
geom_line(aes(x=Value,y=y,group=Trial,color=Trial,size=N)) +
scale_size(range=c(0.1, 2), trans="log") +
guides(size=F, color=guide_legend(override.aes=list(size=2)))
我希望每个试验值在图例中的线条粗细与图表中的线条相匹配(例如,“A”应该粗,“B”应该细)。 编辑1: @Arun和@ChelseaE给出了手动调整每个线条粗细的好建议,但是我的实际数据集有许多因子级别并且不断变化,因此我需要使其“动态”。
@DidzisElferts在类似问题的答案中 (Control ggplot2 legend look without affecting the plot),展示了如何将大小设置为静态值。上面示例的最后一行中的size=2
部分允许我更改图例的线条大小,但我希望它与图表中的线条大小匹配。使用size=N
似乎是合理的,但它会出现“对象'N'未找到”的错误。正确的语法是什么?
期望的输出: