简体   繁体   English

R- 根据因子水平拆分直方图

[英]R- split histogram according to factor level

This is my data:这是我的数据:

type<-rep(c(0,1),100) 
diff<-rnorm(100)
data<-data.frame(type,diff)

If I want to plot historgram of diff , I do this:如果我想绘制diff直方图,我这样做:

hist(data$diff)

But what I want to do to split my histogram according to type .但是我想要做的是根据type拆分我的直方图。 I could do this:我可以这样做:

par(mfrow=c(1,2))
hist(data$diff[data$type==0])
hist(data$diff[data$type==1])

But what this is giving me are two different histograms side by side.但这给我的是两个不同的直方图并排。 What I want to do is produce a single histogram with diff of 0 at one side and diff of 1 at other side.我想要做的是生成单个直方图,一侧diff0 ,另一侧diff1 Something like this with bars as continuous without the breaks or border in between.像这样的东西,条形是连续的,中间没有中断或边界。 This presumably would mean the axis will be split into two for each factor.这大概意味着对于每个因素,轴将分为两个。 在此处输入图片说明

You can use the ggplot2 package:您可以使用ggplot2包:

library(ggplot2)

ggplot(data,aes(x=diff))+geom_histogram()+facet_grid(~type)+theme_bw()

在此处输入图片说明

You can also put them on the same plot by "dodging" them:您还可以通过“躲避”它们将它们放在同一个图上:

ggplot(data,aes(x=diff,group=type,fill=type))+
  geom_histogram(position="dodge",binwidth=0.25)+theme_bw()

在此处输入图片说明

If you want them to overlap, the position has to be position="identity"如果您希望它们重叠,则位置必须为position="identity"

ggplot(data,aes(x=diff,group=type,fill=type))+
  geom_histogram(position="identity",alpha=0.5,binwidth=0.25)+theme_bw()

在此处输入图片说明

If you want them to look like it does in the first one but without the border, you have to hack it a little:如果你想让它们看起来像第一个但没有边框,你必须稍微修改一下:

data$diff[data$type==1] <- data$diff[data$type==1] + 6

ggplot(data,aes(x=diff,group=type,fill=type))+
  geom_histogram(position="identity",alpha=0.5,binwidth=0.25)+theme_bw()+
  scale_x_continuous(breaks=c(-2:2,4:8),labels=c(-2:2,-2:2))

在此处输入图片说明

That plot was made using the lattice package该图是使用格子包制作的

set.seed(1)
type<-rep(c(0,1),100) 
diff<-rnorm(100)
data<-data.frame(type,diff)


library('lattice')
histogram(~ diff | type, data = data)

在此处输入图片说明

here is how you can do it in base graphics这是您如何在基本图形中做到这一点

## first plot - left half of x-axis, right margin set to 0 lines
par(fig = c(0, .5, 0, 1), mar = c(5,4,3,0))
hist(data$diff[data$type==0], ann = FALSE, las = 1)

## second plot - right half of x-axis, left margin set to 0 lines
par(fig = c(.5, 1, 0, 1), mar = c(5,0,3,2), new = TRUE)
hist(data$diff[data$type==1], ann = FALSE, axes = FALSE)
axis(1)
axis(2, lwd.ticks = 0, labels = FALSE)

title(main = 'Histogram', xlab = 'x label', outer = TRUE, line = -2)

在此处输入图片说明

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM