R中条形图数组中的恒定条形宽度

CJO*_*CJO 5 plot r width

我正在尝试制作一个(1 行,3 列)条形图数组,它们都具有相同的条形宽度

所有三个条形图都有不同数量的观测值,因此每个图的条形宽度最终都不同(即,具有最多观测值的图形具有最窄的条形,而具有最少观测值的图形具有最宽的条形)。我从barplot {graphics} R文档中了解到,

“除非xlim指定,否则指定单个值将没有可见效果”

但是,我x labels是字符串,所以我不确定如何指定xlim. 我不介意我的图的宽度是否不同,但是我需要以某种方式指定它吗?

这是一些假数据和我正在使用的代码……谢谢你的帮助。

height4plot1 <- c(1,6,9,2,3,10,7,15)
names4plot1 <- c("P1","P2","P3","P4","P5","P6","P7","P8")

height4plot2 <- c(5,4,10,2)
names4plot2 <- c("M1","M2","M3","M4")

height4plot3 <- c(4,12)
names4plot3 <0 c("U1","U2")

par(mfrow=c(1,3),
    mar=c(10,5,2,1),
    cex.axis=0.7,
    mgp=c(3,0.5,0))
barplot(height4plot1,
    names.arg=names4plot1,
    las=3,
    axes=TRUE,
    axisnames=TRUE,
    ylab="YLAB",
    ylim=ylim,
    plot=TRUE,
    main="PLOT1",
    width=1)
barplot(height4plot2,
    names.arg=names4plot2,
    las=3,
    axes=TRUE,
    axisnames=TRUE,
    ylim=ylim,
    plot=TRUE,
    main="PLOT2",
    width=1)
barplot(height4plot3,
    names.arg=names4plot3,
    las=3,
    axes=TRUE,
    axisnames=TRUE,
    ylim=ylim,
    plot=TRUE,
    main="PLOT3",
    width=1)
Run Code Online (Sandbox Code Playgroud)

Gre*_*now 1

如果没有诸如等的变量,height4plot1测试代码和修改会更困难,但这里有一些可能性:

您可以width=0.8为每个图指定,xlim=c(0,maxnum)其中 maxnum 是不同图中的最大条形数。这将在每个较小的条形图中留下一个空白部分。

您可以填充较短的高度向量,NA直到它们的长度相同(这仍然会给出空部分)。

您可以将 3 个向量连接在一起并制作一个箱线图,可能对 3 个组进行不同的着色以帮助区分它们。该abline函数可用于在组之间添加分隔线(并查看spacebarplot 的参数,或包含“NA”作为分隔符以在组之间提供更多空间)。您可以使用返回值来帮助将标题放置在每个组的上方。

您可以使用layout而不是par设置您的 3 个绘图区域具有不同的宽度,但是获得精确的宽度比率以给出完全相同大小的条形并不简单(尽管您可能会通过反复试验来接近)。如果您真的想要这条路线,那么grconvertX可能optim会有所帮助。

我建议使用上面的第二个选项。