R实战笔记一

*本文为《R in action》图形基础部分笔记

pdf() png() jpeg() bmp() tiff() xfig() postscript()将图形储存为相应格式,在Rstudio里储存为pdf格式也可以直接手动操作

pdf("mygraph.pdf") 
  attach(mtcars)
  plot(wt, mpg)
  abline(lm(mpg~wt))
  title("Regression of MPG on Weight")
  detach(mtcars)
dev.off()

plot() 中的type指绘图形式,l为line,p为point,b为both

dose <- c(20, 30, 40, 45, 60)
drugA <- c(16, 20, 27, 40, 60)
drugB <- c(15, 18, 25, 31, 40)
plot(dose, drugA, type="b")
plot(dose, drugA)

par()设定绘图的一些特征参数
no.readonly=TRUE option produces a list of current graphical settings that can be modified.
lty: line type,
pch: point type
cex: plotting symbol scale,
lwd: line width
col: line color,
bg: background color,
col.axis, col.main:title , col.lab, col.sub

opar <- par(no.readonly=TRUE)
par(lty=2, pch=17)
plot(dose, drugA, type="b")
par(opar)

font:整数,用于设定字体样式,1=常规,2=粗体,3=斜体,4=粗斜体,5=符号字体(以Adobe符号编码表示)
family:绘制文本时使用的字体族,标准的取值为serif(衬线)、sans(无衬线)、mono(等宽)
family=”mono”/”serif”/”sans”

图形尺寸与边界
pin:以英寸表示的 图形尺寸(宽和高)
mai:以数值向量表示的边界大小,顺序为“下、左、上、右”,单位为英寸
mar:以数值向量表示的边界大小,顺序为“下、左、上、右”,单位为英分。Default:c(5,4,4,2)+0.1

par(pin = c(4,3), mai=c(1, .5, 1, .2))
#4英寸宽3英寸高,上下边界为1英寸,左边界为0.5英寸,右边界为0.2英寸
dose <- c(20, 30, 40, 45, 60)
drugA <- c(16, 20, 27, 40, 60)
drugB <- c(15, 18, 25, 31, 40)
opar <- par(no.readonly=TRUE)
par(pin=c(2, 3))
par(lwd=2, cex=1.5)
par(cex.axis=.75, font.axis=3)
plot(dose, drugA, type="b", pch=19, lty=2, col="red")
plot(dose, drugB, type="b", pch=23, lty=6, col="blue", bg="blue")
par(opar)

main:主标题
sub:副标题
xlab/ylab:x、y轴标签
xlim/ylim:x、y轴坐标范围 xlim = c(0,60)

在某些高级绘图语句中以及包含了默认的标题和标签,可以通过在plot语句或单独的par语句中添加ann=FALSE来移除

title()添加标题和坐标轴标签
title(main = “”, sub = “”, xlab = “”, ylab = “”)
title 中亦可指定其他参数如字体大小与颜色等

axis()坐标轴函数
axis(side, at= , labels= ,pos=, lty=, col=, las=, tck=, …)
side:表示刻度线的绘制位置(1=下,2=左,3=上,4=右)
at:数值型向量,表需要绘制刻度线的位置
labels:字符型向量,刻度线旁边的文字标签,若为NULL,则直接使用at中的值
pos:坐标轴线绘制位置的坐标(即与另一条坐标轴相交的位置的值)
las:标签与坐标轴的位置,0=平行,2=垂直
tck:刻度线长度,相对于绘图区域大小的分数表示,负数表示在图形外侧,正数表示在图形内侧,0表示禁用刻度,1表示绘制网格线,default=-0.01

次要刻度线

library(Hmisc)
minor.tick(nx=n, ny=n, tick.ratio=n)

nx/ny:指定了X与Y轴每两条主刻度线之间通过次要刻度线划分得到的区间个数
tick.ratio:次要刻度线相对于主要刻度线的大小比例

参考线:abline()
abline(h=yvalue, v=xvalue)

abline(h=c(1,5,7))

在y为1、5、7的位置添加了水平实线
同样,在abline中也可以指定其他图形参数(颜色、线条类型及宽度等)

图例:legend()

legend(location,title,legend,…)

location:给定图例位置,可以给定x,y坐标,也可以执行locatior(1),然后通过鼠标单击给出图例位置。也可以使用关键字(bottom/bottomleft/left/topleft/top/topright/right/bottomright/center)如果使用了关键字,可以同时搭配inset=指定图例向图形内侧移动的大小(以绘图区域大小的分数表示)
title:标题,字符串,选填
legend:图例标签组成的字符向量
horiz:horiz=TRUE表水平放置图例,FALSE为垂直放置
其他常用参数:bty,bg,cex,text.col

dose <- c(20, 30, 40, 45, 60)
drugA <- c(16, 20, 27, 40, 60)
drugB <- c(15, 18, 25, 31, 40)
opar <- par(no.readonly=TRUE)
par(pin=c(4, 5))
par(lwd=2, cex=1.5)
par(cex.axis=.75, font.axis=3)
plot(dose, drugA, type="b", pch=19, lty=2, col="red")
lines(dose, drugB, type="b", pch=23, lty=6, col="blue", bg="blue")
legend("topleft", inset=.05, title="drug type", c("A","B"), lty = c(1, 2), pch = c(15,17), col = c("red", "blue"))
par(opar)

文本标注

text(x, y = NULL, labels = seq_along(x$x), adj = NULL,
     pos = NULL,…) #向绘图区域内部添加文本
mtext(text, side = 3, line = 0,...)#向图形的四个边界之一添加文本

location: 可以给定x,y坐标,也可以执行locatior(1)
pos:文本相对位置参数的额方位,1=下,2=左,3=上,4=右,指定pos后可以同时指定offset=作为偏移量,以相对于单个字符宽度的比例表示
side:指定用来放置文本的边,1=下,2=左,3=上,4=右。可以指定参数line=来内移或外移文本,随着值得增加,文本将外移。adj=0将文本向左下对齐,adj=1文本向右上对齐

attach(mtcars)
plot(wt, mpg, 
     main="Mileage vs. Car Weight",
     xlab="Weight", ylab="Mileage",
     pch=18,col="blue")
text(wt,mpg,row.names(mtcars),
     cex=0.5, pos=4, col="red")
detach(mtcars)
#row.names()表示行的名字

数学标注
expression()公示转化函数

#make a hist but use the desity
par(mfrow = c(1,1))
hist(rnorm(100),xlim=c(-3,3),freq=FALSE)
# add a normal curve here
# ’expr’ must be a function or an expression containing ’x’
x<-seq(-5,5,.01)
curve(dnorm(x),add=TRUE)
# add a density expression
text(x=2, y=.35,
     expression(paste("f(x)=",frac(1,sqrt(2*pi)*sigma),
                      exp(-frac(1,2*sigma^2)*((x-mu)^2)))))
#use help:demo(plotmath) to get more details

分屏

#将屏幕分为两行
split.screen(c(2,1))
#将第一行(1)分为两列,记做3、4
split.screen(c(1,2),1)
#将第二行(2)分为三列,记做5、6、7
split.screen(c(1,3),2)
screen(3)
par(bty="o")
plot(0,main="par(bty=\"o\")")
screen(4)
par(bty="l")
plot(0,main="par(bty=\"l\")")
screen(5)
par(bty="7")
plot(0,main="par(bty=\"7\")")
screen(6)
par(bty="n")
plot(0,main="par(bty=\"n\")")
screen(7)
par(bty="c")
plot(0,main="par(bty=\"c\")")

分频法二:layout(mat),mat为一个矩阵,指定所组合的多个图形所在的位置

attach(mtcars)
layout(matrix(c(2,3,1,1),2,2,byrow = TRUE)) #2,3,个图形被放置在第一行,第一个图形被放置在第二行
hist(wt)
hist(mpg)
hist(disp)
detach(mtcars)

在layout函数中使用widths和heights参数可以控制每个图形的的大小
widths:各列宽度值组成的一个向量(相对宽度直接使用数值指定,绝对宽度使用lcm函数指定)
heights:各行高度值组成的一个向量

attach(mtcars)
layout(matrix(c(2,3,1,1),2,2,byrow = TRUE),widths=c(3,1),heights=(1,2))

fig:在单张图形上绘制多张图时控制图形布局【书上篇幅不大,我觉得参数设定有点玄学】
第一个fig=将散点图设定为占据横向范围0到0.8,纵向范围0到0.8。
上方的箱线图横向占据0到0.8,纵向0.55到1。右侧的箱线图横向占据0.65到1,纵向0到0.8。fig=默认会新建一幅图形,所以在添加一幅图到一幅现有图形上时,请设定参数new=TRUE。

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