ggplot2回顾(3): 图层语法基础

library(ggplot2)
library(tidyverse)
library(scales)
library(nlme)

1. 图层

图层五要素
  • 数据集:每个图层都可以有自己的数据集
  • 一组图形属性的映射:设定和映射之间的区别
  • 几何对象:决定一组可用的图形属性
  • 统计变换:返回一个包含新变量的数据框, 每一个统计变换都有默认的几何对象,下面两行代码出图一样
ggplot(diamonds,aes(carat,price,color=cut))+geom_point()
ggplot(diamonds,aes(carat,price,color=cut))+stat_identity()
  • 位置调整:通过调整元素的位置来避免图形重合
图层是普通的R对象

可以赋值给变量,便于代码复用

bestfit <- geom_smooth(method = "lm",se=F,color="lightblue",alpha=0.5,size=2)
msleep %>% ggplot(aes(x=sleep_rem,y=sleep_total))+bestfit

2. 数据

关于分面:分面是一个全局操作,作用于所有图层,需要一个默认数据集,这个数据集定义了分面变量(一般是离散变量)

3. 图形属性映射

3.1 图和图层

图层映射(指geom_函数中的映射)和默认映射(指ggplot()函数中的映射)的结合:以geom_函数中的映射为准

3.2 设定和映射的区别

个人理解:设定是设置为“一个值”,映射是设置为“多个值”;前者放在aes()外面,后者放在aes()里面

p <- mtcars %>% ggplot(aes(x=mpg,y=wt))
p+geom_point(color="lightblue")
p+geom_point(aes(color="lightblue"))
p+geom_point(aes(color="blue"))

对于color来说,如果是映射,变量有几个值才是重要的,值的内容并不重要,上面两行代码得到的图一样,都是粉红色的(这是默认色)

3.3 分组(新内容)

group=xxx: 变量是离散的
interaction():有时候需要组合两个变量达到分组的目的

默认分组不管用的时候,只能自己设置group,3种情况

3.3.1 多个分组与单个图形属性(指group)
nlme::Oxboys %>% ggplot(aes(age,height))+geom_line()
nlme::Oxboys %>% ggplot(aes(age,height,group=Subject))+geom_line()
nlme::Oxboys %>% ggplot(aes(age,height,color=Subject))+geom_line() 

此时,这一行代码更像是上一行代码的“进一步形式”,换言之,color=潜在地进行了group=操作

3.3.2 不同图层上的不同分组:有的图层展示个体,有的图层展示组群
nlme::Oxboys %>% ggplot(aes(age,height,group=Subject))+geom_line()+geom_smooth(method = "lm",se=F)
nlme::Oxboys %>% ggplot(aes(age,height,group=Subject))+geom_line()+geom_smooth(group=1,method = "lm",se=F)
3.3.3 修改默认分组

当x映射为某变量,而这个变量是离散的,则默认根据这个变量分组

nlme::Oxboys %>% ggplot(aes(Occasion,height))+geom_boxplot()
nlme::Oxboys %>% ggplot(aes(Occasion,height))+geom_boxplot()+geom_line(aes(group=Subject),color="lightblue")
3.4 匹配图形属性和图形对象
a <- c(1,2,3,1,2,3,1,3,5)
dim(a) = c(3,3)
df2 <- as.data.frame(a)
colnames(df2) <- c("x","y","color")
df2
#第一幅图
ggplot()+geom_point(df2,mapping=aes(x,y,color=factor(df2$color)),size=8)+geom_segment(aes(x=df2$x[c(1,2)],y=df2$y[c(1,2)],xend=df2$x[c(2,3)],yend=df2$y[c(2,3)],color=factor(df2$color[c(1,2)])),size=4)
#第二幅图
df2 %>% ggplot(aes(x,y,color=color))+geom_point(size=8)+geom_line(size=4)
#第三幅图
xgrid <- with(df2,seq(min(df2$x),max(df2$x),length=50))
interp <- data.frame(
  x=xgrid,
  y=approx(df2$x,df2$y,xout = xgrid)$y,
  color=approx(df2$x,df2$color,xout = xgrid)$y
)
ggplot(df2,aes(x,y,color=color))+geom_point(size=8)+geom_line(data = interp,size=4)

大概率,你在网上看不到这部分内容,除了这里。因为书上没有代码,根据图想代码的人是少数。

4. 几何对象

4.1 ggplot2中常见的几何对象
名称 描述 一般用法
abline 线,由斜率和截距决定 ggplot()+geom_abline(slope = -1,intercept = 2)+xlim(0,4)+ylim(0,4)
area 面积图 ggplot(df, aes(x=weight,fill=sex))+geom_area(stat ="bin",alpha=0.4)#注意stat ="bin"不能和y=df$某变量一起出现
hline/vline 水平/垂直线 p+geom_vline(data=df, aes(xintercept=mean_value))#数据框的行数等于添加线的条数(如果只有一行,没有必要这样写),且至少为1列(mean_value)
bar 条形图 ggplot(diamonds, aes(x=cut))+geom_bar()
bin2d 2维热图 ggplot(diamonds,aes(x=carat,y=price))+geom_bin2d()#当散点图重叠严重,可以试试这个
boxplot 箱线图 ggplot(diamonds,aes(clarity,price))+geom_boxplot()
density 光滑密度曲线图 ggplot(diamonds, aes(x=price))+geom_density()
crossbar/errorbar/linerange/pointrange 在竖直方向表示区间 见详解2
errorbarh 水平的误差棒 类似errorbar的用法
histogram 直方图 ggplot(diamonds,aes(x=price))+geom_histogram()
jitter 添加扰动后的散点图 ggplot(diamonds,aes(carat,price))+geom_jitter()
line 按照x的顺序连线
path 按照数据的原始顺序连线
point 散点图
rug 边际地毯图 ggplot(mtcars, aes(wt, mpg))+geom_point()+geom_rug(sides="trbl")
segment 添加线段或箭头
smooth 添加光滑曲线
step 阶梯线 ggplot(recent, aes(date, unemploy)) + geom_step()
text 文本注释
violin 小提琴图 ggplot(diamonds,aes(color,price))+geom_violin()
4.2 面积图
#创建数据框
set.seed(1234)
df <- data.frame(
  sex=factor(rep(c("F", "M"), each=200)),
  weight=round(c(rnorm(200, mean=55, sd=5),
                 rnorm(200, mean=65, sd=5)))
)
head(df)
#基础面积图
##纵轴为频数
ggplot(df, aes(x=weight))+geom_area(stat = "bin")
##纵轴为频率
ggplot(df, aes(x=weight,y=..density..))+geom_area(stat = "bin")
#中级面积图
##添加均值线,添加填充颜色,添加边缘颜色,改变边缘线条类型
ggplot(df, aes(x=weight))+geom_area(stat = "bin",fill="lightblue",color="darkblue",linetype="dashed")+geom_vline(xintercept=mean(df$weight),color="blue", linetype="dashed", size=1)
##按照性别分开,注意是堆叠的,如何不堆叠在一起,见后面的位置调整部分
ggplot(df, aes(x=weight,fill=sex))+geom_area(stat ="bin",alpha=0.4)
##有时需要根据X, Y值来画面积图;这种情况也可以用条形图/直方图
set.seed(1234)
year <- rep(1990:2015, times = 2)
type <- rep(c('A','B'),each = 26)
value <- c(runif(26),runif(26, min = 1,max = 1.5))
df <- data.frame(year = year, type = type, value = value)
ggplot(data = df, mapping = aes(x = year, y = value, fill = type)) + geom_area()
4.3 在竖直方向表示区间
df <- data.frame(
  trt = factor(c(1, 1, 2, 2)),
  resp = c(1, 5, 3, 4),
  group = factor(c(1, 2, 1, 2)),
  upper = c(1.1, 5.3, 3.3, 4.2),
  lower = c(0.8, 4.6, 2.4, 3.6)
)
p <- ggplot(df, aes(trt, resp, colour = group))
#一条竖直线,没有用到resp的信息
p + geom_linerange(aes(ymin = lower, ymax = upper))
#一条竖直线+一个点
p + geom_pointrange(aes(ymin = lower, ymax = upper))
#带有水平线的盒子图
p + geom_crossbar(aes(ymin = lower, ymax = upper), width = 0.2)
#“工”字图,没有用到resp的信息
p + geom_errorbar(aes(ymin = lower, ymax = upper), width = 0.2)

5. 统计变换

将原数据集作为输入,返回新的数据集,伴随插入新的变量。生成变量的名称需用..XXX..,这些变量可以直接被调用。

diamonds%>%ggplot(aes(x=carat))+geom_histogram(aes(y=..density..))
diamonds%>%ggplot(aes(x=carat))+geom_histogram(aes(y=..count..))
名称 描述 生成变量
bin 计算封箱数据 count, density, x
density 一维密度计算 *
identity 不对数据进行数据转换 *

6. 位置调整

名称 描述
dodge 避免重叠,并排放置
fill 堆叠图形元素,并将高度标准化为1
identity 不做任何调整;不适用于条形图
jitter 给点添加扰动,避免重叠
stack 堆叠图形元素
ggplot(df,aes(x=weight, fill=sex))+geom_area(stat ="bin",position = "stack",alpha=0.3)
ggplot(diamonds, aes(x=cut))+geom_bar(aes(fill=color),position = "fill")
ggplot(diamonds,aes(x=carat))+geom_histogram(aes(fill=color),position = "dodge")
#在直方图中是左右排开;在面积图和密度图中是前后排开

7. 自定义组合

结合几何对象和统计变换

d <- ggplot(diamonds,aes(carat))+xlim(0,3)
d+stat_bin(aes(y=..count..),binwidth = 0.1,geom="area")
d+stat_bin(aes(size=..density..),binwidth = 0.1,geom = "point")
d+stat_bin(aes(fill = ..count..), binwidth = 0.1,geom = "bar",position = "fill")

reference

《ggplot2: 数据分析与图形艺术》

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,684评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,143评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,214评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,788评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,796评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,665评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,027评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,679评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,346评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,664评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,766评论 1 331
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,412评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,015评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,974评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,203评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,073评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,501评论 2 343

推荐阅读更多精彩内容