R语言实战 - 基本图形(1)- 条形图

本文通过实例详细介绍了如何使用R语言vcd包绘制多种类型的条形图,包括简单的条形图、堆砌条形图、分组条形图及均值条形图等,并展示了如何进行微调以获得更佳的视觉效果。

1. 条形图

1.1 简单的条形图

> library(vcd)
> counts <- table(Arthritis$Improved)
> counts

  None   Some Marked 
    42     14     28 
> 
> barplot(counts,
+         main="Simple Bar Plot",
+         xlab="Improvement", ylab="Frequency")
> 
> barplot(counts,
+         main="Horizontal Bar Plot",
+         xlab="Frequency", ylab="Frequency",
+         horiz=TRUE)
> 

     

1.2 堆砌条形图和分组条形图

> library(vcd)
> counts <- table(Arthritis$Improved, Arthritis$Treatment)
> counts
        
         Placebo Treated
  None        29      13
  Some         7       7
  Marked       7      21
> 
> barplot(counts,
+         main="Stacked Bar Plot",
+         xlab="Treatment", ylab="Frequency",
+         col=c("red","yellow","green"),
+         legend=rownames(counts))
> 
> 
> barplot(counts,
+         main="Grouped Bar Plot",
+         xlab="Treatment", ylab="Frequency",
+         col=c("red", "yellow", "green"),
+         legend=rownames(counts), beside=TRUE)
> 

     

1.3 均值条形图

> states <- data.frame(state.region, state.x77)
> means <- aggregate(states$Illiteracy, by=list(state.region), FUN=mean)
> means
        Group.1        x
1     Northeast 1.000000
2         South 1.737500
3 North Central 0.700000
4          West 1.023077
> means <- means[order(means$x),]
> means
        Group.1        x
3 North Central 0.700000
1     Northeast 1.000000
4          West 1.023077
2         South 1.737500
> barplot(means$x, names.arg=means$Group.1)
> title("Mean Illiteracy Rate")
> 

1.4 条形图的微调

> par(mar=c(5,8,4,2))
> par(las=2)
> counts <- table(Arthritis$Improved)
> barplot(counts,
+         main="Treatment Outcome",
+         horiz=TRUE, cex.names=0.8,
+         names.arg=c("No Improvement", "Some Improvement", "Marked Improvement"))
> 

1.5 棘状图

> library(vcd)
> attach(Arthritis)
> counts <- table(Treatment, Improved)
> spine(counts, main="Spinogram Example")
> detach(Arthritis)
> 

 

转载于:https://www.cnblogs.com/wnzhong/p/7536266.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值