【问题标题】:barplot(): Frequency percentages per groupbarplot():每组的频率百分比
【发布时间】:2016-07-22 15:41:47
【问题描述】:

我正在尝试制作一个分组条形图,y 轴上的频率 (%) 和 x 轴上的 depression_meds (N/Y),由另一个变量 score (LOW/HIGH) 分组。

到目前为止我的代码:

meds <- table(data2$depression_meds,data2$score)/sum(table(data2$score)) * 100
bp <- barplot(meds, beside=TRUE, axes=FALSE, xlab="Anti-depression meds use", names=c("No", "Yes"), col=c("azure3", "azure"), ylab="Frequency (%)", ylim=c(0,100))
axis(2, at=seq(0,100,10))
legend("topright", legend=c("LOW", "HIGH"), bty="n", fill=c("azure3", "azure"))
text(bp, 0, round(medtimerx, 1), cex=1, pos=3)

这很棒,并制作了以下条形图:

但是百分比使用的是 243 的总 n(下表的第 3 列),而不是每个分数组的 n(下表中的第 1 和第 2 列),这是有道理的,因为这是我除以时所做的按总和。但这不是我想要的。我一直在尝试获取每个分数组的频率,以便四个条形与下面的第一列和第二列相匹配,但我已经没有想法了。有人有什么建议吗?

Depression meds (0=N, 1=Y)   LOW (N=99)   HIGH (N=144)   TOTAL (N=243)
                         0   96 (97.0%)   116 (80.6%)    212 (87.2%)     
                         1   3 (3.0%)     28 (19.4%)     31 (12.8%)  

这是我的数据:

> dput(data2)
structure(list(depression_meds = c(0L, 0L, 0L, 0L, 0L, 0L, 0L, 
0L, 0L, 1L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 
0L, 0L, 1L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 1L, 0L, 0L, 0L, 0L, 
1L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 
0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 
0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 
0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 1L, 1L, 0L, 0L, 0L, 0L, 0L, 1L, 
0L, 0L, 0L, 1L, 0L, 0L, 0L, 0L, 0L, 1L, 0L, 0L, 1L, 0L, 0L, 0L, 
0L, 0L, 0L, 0L, 0L, 0L, 1L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 1L, 
0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 
0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 1L, 1L, 0L, 0L, 0L, 
0L, 0L, 0L, 1L, 0L, 0L, 0L, 1L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 
0L, 0L, 0L, 0L, 0L, 0L, 1L, 0L, 0L, 1L, 0L, 0L, 0L, 0L, 0L, 0L, 
0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 1L, 0L, 0L, 0L, 1L, 
0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 1L, 0L, 
0L, 1L, 0L, 0L, 0L, 0L, 1L, 0L, 0L, 0L, 0L, 0L), score = c(1L, 
1L, 0L, 0L, 0L, 0L, 1L, 1L, 0L, 1L, 0L, 0L, 0L, 0L, 0L, 1L, 1L, 
0L, 0L, 1L, 0L, 0L, 0L, 0L, 1L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 
0L, 1L, 1L, 0L, 0L, 1L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 
0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 0L, 1L, 0L, 0L, 0L, 0L, 0L, 
0L, 0L, 1L, 0L, 0L, 0L, 0L, 0L, 1L, 1L, 0L, 0L, 0L, 0L, 0L, 0L, 
0L, 0L, 0L, 1L, 0L, 0L, 0L, 0L, 0L, 0L, 1L, 0L, 1L, 1L, 1L, 1L, 
1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 
1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 
1L, 0L, 0L, 0L, 1L, 0L, 1L, 0L, 1L, 0L, 1L, 0L, 0L, 0L, 0L, 0L, 
0L, 0L, 0L, 0L, 0L, 0L, 1L, 0L, 0L, 1L, 0L, 0L, 0L, 0L, 0L, 1L, 
1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 
1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 
1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 
1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 
1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 1L, 
1L, 1L)), .Names = c("depression_meds", "score"), row.names = c(NA, 
-243L), class = "data.frame")

感谢您的帮助,我的大脑不再工作了。

【问题讨论】:

    标签: r plot bar-chart


    【解决方案1】:

    在这种情况下使用prop.table很合适,它提供了一个margin参数来指定按行或按列的概率计算:

    meds <- prop.table(table(data2), margin = 2) * 100
    meds
    #                score
    # depression_meds         0         1
    #               0 96.969697 86.111111
    #               1  3.030303 13.888889
    

    【讨论】:

    • 首先检查了另一个答案,但投票赞成使用 prop.table,我会记住这一点以备不时之需。谢谢!
    • 当然可以。您接受哪个答案并不重要。差别不大。
    【解决方案2】:

    将此用于您的汇总表:

    meds <- table(data2)
    
    #               score
    #depression_meds   0   1
    #              0  96 124
    #              1   3  20
    
    meds <- scale(meds, FALSE, colSums(meds)) * 100
    
    #               score
    #depression_meds         0         1
    #              0 96.969697 86.111111
    #              1  3.030303 13.888889
    

    无需更改其余代码:

    bp <- barplot(meds, beside=TRUE, axes=FALSE, xlab="Anti-depression meds use", names=c("No", "Yes"), col=c("azure3", "azure"), ylab="Frequency (%)", ylim=c(0,100))
    axis(2, at=seq(0,100,10))
    legend("topright", legend=c("LOW", "HIGH"), bty="n", fill=c("azure3", "azure"))
    text(bp, 0, round(meds, 1), cex=1, pos=3)
    

    【讨论】:

    • 太棒了。非常感谢!
    猜你喜欢
    • 2017-11-29
    • 2021-12-24
    • 2020-10-17
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2019-10-26
    • 2011-04-17
    • 1970-01-01
    相关资源
    最近更新 更多