8、科研作图之直方图详解——ggplot2

数据准备

假设有200个男性和200个女性的身高数据(这里使用随机函数生成)。

#数据准备
set.seed(96)
df = data.frame(
  sex = factor(rep(c("F", "M"), each=200)),
  height = c(rnorm(200, 170), rnorm(200, 165)))
head(df)

40a5a20414684c0c989b45f5e4e163a0.png

基础语法

p = ggplot(df,aes(x = height))

p + geom_histogram(bins = 50,color = "black", fill = "gray")

 其中:

bins:用于规定 总柱体的条数;

 cfe210fc06174f71a3ca11553c5f6e87.png

添加平均值线

 #添加平均值线
p + geom_histogram(bins = 50,color = "black", fill = "gray") +
  geom_vline(aes(xintercept=mean(height)),
           color="blue", linetype="dashed", size=1)

1c5144e7b5c2491da03d335225fda328.png

两组数据共图

按不同的性别按不同颜色显示:

#按不同性别不同颜色显示
p + geom_histogram(aes(color = sex), fill = "white",alpha = 0.6)

f665bbf6dae0451ead84e7f1d819ad70.png 

添加密度曲线

添加总的曲线

#添加总的频率线
p + geom_histogram(aes(y=..density..), colour="black", fill="white") +
  geom_density(alpha=0.6,fill = "grey")
 

ed608f06cedb47708cbf69985f8a04b4.png 

 

分组添加曲线

 #按性别添加频率线
p + geom_histogram(aes(y=..density.., color = sex, fill = sex),
                   alpha=0.5, position="identity")+
  geom_density(aes(color = sex), size = 1)

b301c7356e164f5daefc960d549acbeb.png

至此完成基本的六种科研常用作图的绘制...

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值