R语言基础绘图系统

基础绘图包之低级绘图函数——气泡图、一页多图、背景网格、添加线条和散点、数学表达式

4.气泡图

symbols是高级绘图函数,可在图上添加标记,标记的形状包括:circles,squares,rectangles,stars,thermometers,boxplots. 默认标记圆圈,可用于绘制气泡图

op <- palette(rainbow(5,end = 0.9))
with(trees,{
symbols(Height,Volume,circles = Girth/16,
inches = F,bg=1:5, #背景色
fg='gray30', #前景色
main = '气泡图')
palette(op)
})

重叠点透明色气泡图.

#重叠点透明色气泡图
library(DescTools)
DescTools::PlotBubble(x=d.pizza$delivery_min,y=d.pizza$temperature,
area=d.pizza$price/40, #填充数据,数值标化
xlab='delivery time',ylab='temperature',
col=SetAlpha(as.numeric(d.pizza$area)+2,0.5),
#第一个参数颜色向量,第二个参数透明度
border='darkgrey',
na.rm=TRUE,main='Price-Bubbles',
panel.first=grid()) #panel.grid在画图前添加网格线
#添加图例,与legend类似 。这里图例没生成。
BubbleLegend('bottomleft',
frame = TRUE,
cols = SetAlpha('lightskyblue',0.5),
bg='green',
radius=c(10,5,2)/2,
labels = c(10,5,2),
cex=0.8,
cols.lbl = c('yellow','red','blue'),
width = 12)

5. 一页多图

mfrow/mfcol是等距切分画布,不等面积切割需要layout函数。

nf <- layout(matrix(c(1,1,2,3),2,2,byrow = T),
#将画布切分2行2列四部分,第一块占一行,第2、3块占第二行。
widths = c(3,1),
#每一列宽度,这里第一列是第二列的3倍
heights = c(2,2),
#每一列的高度,这是相对宽/高度,也可用绝对lcm(5)
TRUE)
#展示画布切分效果
layout.show(nf)

a <- seq(100,1)+4*runif(100,0.4)
b <- seq(1,100)^2+runif(100,0.98)
c <- rnorm(100,5,4) hist(c,breaks = 30,border = F,col = rgb(0.4,0.5,0.4,0.5),
xlab = '',main = '',freq = F)
lines(density(c),col='red') boxplot(a,xlab='a',col = rgb(0.3,0.8,0.2,0.5),las=2)
boxplot(b,xlab='b',col=rgb(0.7,0.3,0.3,0.5))



此外,split.screen函数也可用于切分屏幕。

6.背景网格

在基础绘图包中,通过grid函数添加网格背景。

op <- par(mfcol=1:2)
with(iris,{
#默认网格
plot(Sepal.Length,Sepal.Width,col=as.integer(Species),
xlim = c(4,8),ylim=c(2,4.5),panel.first = grid(),
main = 'grid 1')
#三行三列网格,宽度为2实线
plot(Sepal.Length,Sepal.Width,col=as.integer(Species),
panel.first = grid(3,lty = 1,lwd = 2),
main = 'grid 2')
})

7. 添加线条和散点

添加线条。

prevalence_m <- runif(10,0.5,0.8)
prevalence_f <- runif(10,0.3,0.6)
plot(prevalence_m,col='red',lty=1,type = 'l',
ylab='某种疾病患病率',xlab='时间',
lwd=2,ylim=c(0,0.9))
lines(prevalence_f,col='blue',lty=2,lwd=2)
#lines参数与plot大致相同
legend(2.3,0.38,legend = c('男性','女性'),lty=1:2,
lwd=2,col=c('red','blue'))



添加散点。

data <- runif(100)
plot(data,xlab = '',ylab = '')
points(50,mean(data),pch=17,col='red',cex=2)

8. 添加数学表达式

仍通过text添加,借助expression函数。


x <- seq(-3,7,by=1/8)
y <- sin(pi*x) plot(y~x,type='l')
text(-1,0.5,labels = expression(hat(beta)==(X^t * X)^{-1} * X^t *y),
col='red',cex=2)
text(2,-0.5,labels = expression(bar(x)==sum(frac(x[i],n),i==1,n)),
col = 'blue',cex=2)

R语言与医学统计图形【7】低级绘图函数的更多相关文章

  1. R语言与医学统计图形【6】低级绘图函数

    R语言基础绘图系统 基础绘图包之低级绘图函数--定义坐标轴.图例.文本 低级绘图函数:本身不具备图形绘制能力,只是在已有图形基础上添加元素. 函数 功能 arrows 添加箭头 axis 坐标轴 bo ...

  2. R语言与医学统计图形【1】par函数

    张铁军,陈兴栋等 著 R语言基础绘图系统 基础绘图包之高级绘图函数--par函数 基础绘图包并非指单独某个包,而是由几个R包联合起来的一个联盟,比如graphics.grDevices等. 掌握par ...

  3. R语言与医学统计图形【4】直方图、金字塔图

    R语言基础绘图系统 基础图形--直方图.金字塔图 3.直方图 参数设置及比较. op <- par(mfrow=c(2,3)) data <- rnorm(100,10,5) hist(d ...

  4. R语言与医学统计图形【3】条形图、误差图

    R语言基础绘图系统 基础图形--条形图.误差图 3.条形图 barplot接收的数据是矩阵而非数据框. data <- sample(c(50:80),5) barplot(data,col=h ...

  5. R语言与医学统计图形【8】颜色的选取

    R语言基础绘图系统 基础绘图包之低级绘图函数--内置颜色. 1.内置颜色选取 功能657种内置颜色.colors() 调色板函数:palette(), rgb(), rainbow(). palett ...

  6. R语言与医学统计图形【5】饼图、条件图

    R语言基础绘图系统 基础图形--饼图.克利夫兰点图.条件图 6.饼图 pie(rep(1,26),col=rainbow(26), labels = LETTERS[1:26], #标签 radius ...

  7. R语言与医学统计图形【2】散点图、盒形图

    R语言基础绘图系统 基础图形--散点图.盒形图 plot是一个泛型函数(generic method),对于不同的数据绘制不同的图形. par函数的大部分参数在plot中通用. 1.散点图 plot绘 ...

  8. R语言与医学统计图形-【28】ggplot2扩展包ggrepel、ggsci、gganimate、ggpubr

    ggplot2绘图系统--扩展包ggrepel.ggsci.gganimate.ggpubr等 部分扩展包可在CRAN直接下载,有些需借助devtools包从Github下载. 1. ggrepel包 ...

  9. R语言与医学统计图形-【33】生存曲线、森林图、曼哈顿图

    1.生存曲线 基础包survival+扩展包survminer. survival包内置肺癌数据集lung. library(survival) library(survminer) str(lung ...

随机推荐

  1. Java:Object对象小记

    Java:Object对象小记 对 Java 中的 Object 对象,做一个微不足道的小小小小记 Object 的常用方法有哪些 clone() 方法:用于创建并返回当前对象的一份拷贝: 在Java ...

  2. 2021.8.14考试总结[NOIP模拟39]

    T1 打地鼠 全场就俩人没切,还有一个是忘关$freopen$了. $code:$ 1 #include<bits/stdc++.h> 2 #define rin register sig ...

  3. ab矩阵(实对称矩阵)

    今天在做题时巧遇了很多此类型的矩阵,出于更快解,对此进行学习.(感谢up主线帒杨) 1.认识ab矩阵 形如:主对角线元素都是a,其余元素都是b,我们称之为ab矩阵(默认涉及即为n×n阶) 2.求|A| ...

  4. 架构师之路-redis集群解析

    引子 上篇<架构师之路-https底层原理>里我提到了上面的整体视图,文章也介绍了想要真正能在工作中及时正确解决问题的基本功:原理理解透彻.今天以redis集群解析为例介绍一个及时敏锐的发 ...

  5. 数据流中的中位数 牛客网 剑指Offer

    数据流中的中位数 牛客网 剑指Offer 题目描述 如何得到一个数据流中的中位数?如果从数据流中读出奇数个数值,那么中位数就是所有数值排序之后位于中间的数值.如果从数据流中读出偶数个数值,那么中位数就 ...

  6. Kafka 消费迟滞监控工具 Burrow

    Kafka 官方对于自身的 LAG 监控并没有太好的方法,虽然Kafka broker 自带有 kafka-topic.sh, kafka-consumer-groups.sh, kafka-cons ...

  7. 如何减小微信小程序代码包大小

    原作于:https://captnotes.com/how_to_reduce_package_size_of_weapp 这两天被小程序代码包大小暴涨的问题困扰了挺久.简单说说怎么回事吧,就是之前好 ...

  8. 一文搞懂js中的typeof用法

    基础 typeof 运算符是 javascript 的基础知识点,尽管它存在一定的局限性(见下文),但在前端js的实际编码过程中,仍然是使用比较多的类型判断方式. 因此,掌握该运算符的特点,对于写出好 ...

  9. maven项目打包执行

    1.maven项目已完成状态! 2.maven打包前提pom.xml引入插件依赖 <build> <plugins> <plugin> <artifactId ...

  10. 记录一个很傻的错误(C++)

    使用的vscode写代码,导入了vector,memory,然后忘了导入string.但是代码中能够提示std::string也就让我忘了导入string.然后就莫名其妙的报错了.找了很久的错.记录下 ...