R语言与医学统计图形【1】par函数
张铁军,陈兴栋等 著
R语言基础绘图系统
基础绘图包之高级绘图函数——par函数
基础绘图包并非指单独某个包,而是由几个R包联合起来的一个联盟,比如graphics、grDevices等。
掌握par函数(作为20个主要统计图形函数之一)的主要参数。?par
adj 微调图中字符位置。adj=c(x,y),相对左下角坐标点,一般不超过1。
bg 绘图区域背景色。
par(bg="green")
bty 设置图形边框样式。包含
o, l , 7, c, u, ]
可选。
bty <- c('o', 'l' , '7', 'c', 'u', ']')
par(mfrow=c(3,2)) #切分画布
for(i in 1:6){
par(bty=bty[i])
plot(1:5,main=paste("the bty is",bty[i],sep = ':'))
}
cex 设置图上元素,如文字或符号的缩放倍数。
plot(1:5, cex=1:5)
。衍生参数:cex.lab, cex.main, cex.sub, cex.axis
.col 设置元素颜色。
family 文本字体。包括
serif, sans, mono, symbol
。如par(family='serif')
即为医学科研论文中常用的times new roman字体。font 字体样式。包括
1, 2, 3, 4
分别为正常,粗体,斜体和粗斜体。las 坐标轴刻度标签样式。包括
0,1,2,3
,分别为平行于坐标轴,水平,垂直于坐标轴,垂直。lty 线条样式。包括
0,1,2,3,4,5,6
,分别为不划线,实线,虚线,点线,点划线,长划线,点长划线。lwd 线条宽度。用法类似cex。注意:当在par函数中使用lwd时,图形中所有元素(如线条,坐标轴,边框等)的线宽都会改变;若只需图中线条宽度变化,需将lwd加入绘图函数中。
#全局设置线宽
par(mfrow=c(2,3))
for(i in 1:6){
par(lty=i,lwd=i) #设置不同线型和线宽
plot(1:5,type = 'l',main = paste('the lty is',i,sep = ':'),
sub = paste('the lwd is',i,sep = ':'))
}
#仅设置线条宽度
plot(rnorm(50),type = 'l',lwd=2,main = "图中线条宽度为默认的2倍")
mar和mai 设置图形边界空白宽度,用于控制绘图面积大小。接受4个数值向量,分别为图形下、左、上、右的边界宽度。前者默认
c(5,4,4,2)+0.1
,单位为线宽,后者单位为英寸。mfrow和mfcol 画布切割。2个元素,几行几列组合。
mgp 坐标轴到画布边缘的距离。后接3个元素分别表示坐标轴标题、刻度标签、坐标轴线到图形的距离,默认
mgp=c(3,1,0)
pch 点的形状。包括25种,即
1-25
,其中15-20
可进行颜色填充。
plot(rep(1:5,times=5),rep(1:5,each=5),pch=1:25,
cex=1.5, bty='l', xlim = c(1,5.4),
xlab = '',ylab = '',main = '25种不同点型')
#低级绘图函数,图中添加文本
text(rep(1:5,times=5)+0.15,rep(1:5,each=5),
labels = 1:25, col = 'red')
- srt 图中字符串旋转角度。
plot(1:25,pch=1)
text(x=c(5,10,20),y=c(7,15,10),col = 'red',
labels = c("R","China","Love"),
srt=30)
- tck和tcl 设置坐标轴刻度线的高度。tck是与图形宽度和高度的比例值(-1到1之间),tcl是与文本行高的比例值。负值表坐标轴刻度向外,正值表示向内。
par(mfrow=c(1,2))
plot(1:10,tck=0.03,main = 'tck=0.03') #刻度线朝内
plot(1:10,tck=-0.03,main = 'tck=-0.03') #刻度线朝外
usr 限定画布大小,
usr=c(x1,x2,y1,y2)
,分别表示x轴左、右极限,y轴的下、上极限的矩形区域。xaxt和yaxt 设置坐标轴样式,默认标准样式为
s
。若不需要坐标轴或需自定义坐标轴,可设置n
,即不绘制刻度及标签,但仍有一条刻度线。xlog和ylog 坐标轴取值log转换。
fig 取值
fig=c(x1,x2,y1,y2)
,配合new=TRUE
参数,用于在当前图形上添加新的图形。
x <- rnorm(1000)
#QQ图
qqnorm(x)
#添加正态拟合线
qqline(x,col="red")
#设置参数,新图形位置
op <- par(fig=c(0.02,0.5,0.5,0.98),new=TRUE)
#0.02表示新图形左边框与原图左边框的距离是原图宽度的2%
#0.5表示新图形右边框与原图左边框的距离是原图宽度的50%
#0.5表示新图形下边框......下................高度的50%
#0.98表示.....上..........下......................98%
#绘制新图形直方图
hist(x,probability = T,col = 'light blue',
xlab='',ylab='',main = '',axes = F)
#添加概率密度曲线
lines(density(x),col="red",lwd=2)
#新图形加边框
box()
#释放par参数
par(op)
- xpd 设置绘图区域大小。包括
TRUE, FALSE, NA
,FALSE代表绘图区域,即图形中点线条等元素所占面积;TRUE代表图形区域,即图形占地面积;NA代表设备区域,即Rstudio中的plots窗口面积。
坐标轴、标题等元素在图形区域,而非绘图区域。这个参数作用就是实现设定绘图区域大小,方面我们在绘图区域外部添加额外内容。
par(omi=c(0.1,0.1,0.2,0.2),mai=c(2,2,1,2),xpd=NA)
#omi参数定义图形区域与设备区域间的距离(英寸)。
#mai参数定义绘图区域与图形区域间的距离(英寸)。
plot(1:10)
text(3,-5,'绘图区域外添加的文字')
text(-0.5,12,'A',cex = 3,family='serif')
科研论文中版面图(panel plot)的应用:即一张画布分布多张图。
#上下排布
#图A,上半边绘图区域
par(omi=rep(0,4),mai=c(3.5,1,1,1),xpd=NA)
plot(1:10)
text(-0.5,12,'A',cex = 2,family='serif')
#图B,下半边绘图区域
par(new=TRUE,mai=c(1,1,3.5,1))
plot(1:10)
text(-0.5,12,'B',cex=2,family='serif')
#左右排布
#mai下左上右
#图A,左半边绘图区域
par(omi=rep(0,4),mai=c(1,1,1,5),xpd=NA)
plot(1:10)
text(-0.5,12,'A',cex = 2,family='serif')
#图B,右半边绘图区域
par(new=TRUE,mai=c(1,5,1,1))
plot(1:10)
text(-0.5,12,'B',cex=2,family='serif')
- ask 逻辑参数。设为TRUE时,一次展示一张画布显示一张图。若为FALSE,所有图一闪而过。
以上par函数的22个参数较为常用。大部分可直接在高级绘图函数中使用,等同par()使用;部分参数只能在par中设置和使用,包括ask, fig, fin ,lheight, mai, mar, mfcol, mfrow, mfg, new, oma, omd, omi, pin, plt, ps, pty, usr, xlog, ylog
。
注意:
par函数对图形参数的改变是永久性的,即在R关闭前,par函数对每张图都起作用。以下方法解决永久性改变问题:
- 1.将所有参数保存为一个实名对象,待图形绘制完毕后,再释放实名对象。
op <- par(fig=c(0.02,0.5,0.5,0.98),new=TRUE)
hist(x,probability = T,col = 'light blue',
xlab='',ylab='',main = '',axes = F)
lines(density(x),col="red",lwd=2)
box()
#释放par参数
par(op)
- 2.图形绘制完成后,调用
dev.off
关闭绘图框。
R语言与医学统计图形【1】par函数的更多相关文章
- R语言与医学统计图形【2】散点图、盒形图
R语言基础绘图系统 基础图形--散点图.盒形图 plot是一个泛型函数(generic method),对于不同的数据绘制不同的图形. par函数的大部分参数在plot中通用. 1.散点图 plot绘 ...
- R语言与医学统计图形【6】低级绘图函数
R语言基础绘图系统 基础绘图包之低级绘图函数--定义坐标轴.图例.文本 低级绘图函数:本身不具备图形绘制能力,只是在已有图形基础上添加元素. 函数 功能 arrows 添加箭头 axis 坐标轴 bo ...
- R语言与医学统计图形【5】饼图、条件图
R语言基础绘图系统 基础图形--饼图.克利夫兰点图.条件图 6.饼图 pie(rep(1,26),col=rainbow(26), labels = LETTERS[1:26], #标签 radius ...
- R语言与医学统计图形【4】直方图、金字塔图
R语言基础绘图系统 基础图形--直方图.金字塔图 3.直方图 参数设置及比较. op <- par(mfrow=c(2,3)) data <- rnorm(100,10,5) hist(d ...
- R语言与医学统计图形【3】条形图、误差图
R语言基础绘图系统 基础图形--条形图.误差图 3.条形图 barplot接收的数据是矩阵而非数据框. data <- sample(c(50:80),5) barplot(data,col=h ...
- R语言与医学统计图形【7】低级绘图函数
R语言基础绘图系统 基础绘图包之低级绘图函数--气泡图.一页多图.背景网格.添加线条和散点.数学表达式 4.气泡图 symbols是高级绘图函数,可在图上添加标记,标记的形状包括:circles,sq ...
- R语言与医学统计图形【8】颜色的选取
R语言基础绘图系统 基础绘图包之低级绘图函数--内置颜色. 1.内置颜色选取 功能657种内置颜色.colors() 调色板函数:palette(), rgb(), rainbow(). palett ...
- R语言与医学统计图形-【28】ggplot2扩展包ggrepel、ggsci、gganimate、ggpubr
ggplot2绘图系统--扩展包ggrepel.ggsci.gganimate.ggpubr等 部分扩展包可在CRAN直接下载,有些需借助devtools包从Github下载. 1. ggrepel包 ...
- R语言与医学统计图形-【33】生存曲线、森林图、曼哈顿图
1.生存曲线 基础包survival+扩展包survminer. survival包内置肺癌数据集lung. library(survival) library(survminer) str(lung ...
随机推荐
- Scrum Meeting 0509
零.说明 日期:2021-5-9 任务:简要汇报两日内已完成任务,计划后两日完成任务 一.进度情况 组员 负责 两日内已完成的任务 后两日计划完成的任务 qsy PM&前端 测试 测试 cyy ...
- 计算机网络传输层之TCP拥塞控制(慢开始与拥塞避免、快重传和快恢复)
文章转自:https://blog.csdn.net/weixin_43914604/article/details/105532044 学习课程:<2019王道考研计算机网络> 学习目的 ...
- MyBatis源码分析(六):Spring整合分析
一.Mybatis-Spring源码结构 二.Myabtis交给Spring管理的组件 1. dataSource 数据源 配置一个数据源,只要是实现了javax.sql.DataSource接口就可 ...
- Node.js躬行记(13)——MySQL归档
当前我们组管理着一套审核系统,除了数据源是服务端提供的,其余后台管理都是由我们组在维护. 这个系统就是将APP中的各类社交信息送到后台,然后有专门的审核人员来判断信息是否合规,当然在送到后台之前已经让 ...
- 神经网络 感知机 Perceptron python实现
import numpy as np import matplotlib.pyplot as plt import math def create_data(w1=3,w2=-7,b=4,seed=1 ...
- hdu 5172 GTY's gay friends(线段树最值)
题意: GTY有n个朋友,站成一排,每个人有一个特征值ai. 有m个询问.每次询问给两个数L,R.问你[L,R](即aL...aR)是否是1..(R-L+1)的一个全排列. 是输出YES,否则输出NO ...
- Python之模块导入(不看会后悔系列)
看到这个标题猜想大家内心OS: 什么辣鸡水文,划走划走~ 别急有干货! 静态导入(照顾新人) 假设现在有两个文件a,b在不同目录,b文件想引用a文件中的函数: # test_module/sub_mo ...
- 羽夏看Win系统内核——驱动篇
写在前面 此系列是本人一个字一个字码出来的,包括示例和实验截图.由于系统内核的复杂性,故可能有错误或者不全面的地方,如有错误,欢迎批评指正,本教程将会长期更新. 如有好的建议,欢迎反馈.码字不易, ...
- java注解@Transactional事务类内调用不生效问题及解决办法
@Transactional 内部调用例子 在 Spring 的 AOP 代理下,只有目标方法由外部调用,目标方法才由 Spring 生成的代理对象来管理,这会造成自调用问题.若同一类中的其他没有@T ...
- 问题 L: Yougth的最大化
题目描述 Yougth现在有n个物品的重量和价值分别是Wi和Vi,你能帮他从中选出k个物品使得单位重量的价值最大吗? 输入 有多组测试数据 每组测试数据第一行有两个数n和k,接下来一行有n个数Wi和V ...