R语言基础| 中级绘图

写在前面

前面第六章的图形主要是展示单分类变量或连续型变量的分布情况。本章主要研究二元变量或多元变量关系的可视化。更多教程可参考:

R语言基础学习手册

图片集锦:

11.1 散点图    

1)添加最佳拟合曲线的散点图: 绘制汽车重量与燃油效率之间的关系图(mtcars包):

head(mtcars)
##                    mpg cyl disp  hp drat    wt  qsec vs am gear carb
## Mazda RX4         21.0   6  160 110 3.90 2.620 16.46  0  1    4    4
## Mazda RX4 Wag     21.0   6  160 110 3.90 2.875 17.02  0  1    4    4
## Datsun 710        22.8   4  108  93 3.85 2.320 18.61  1  1    4    1
## Hornet 4 Drive    21.4   6  258 110 3.08 3.215 19.44  1  0    3    1
## Hornet Sportabout 18.7   8  360 175 3.15 3.440 17.02  0  0    3    2
## Valiant           18.1   6  225 105 2.76 3.460 20.22  1  0    3    1
library(ggplot2)
ggplot(mtcars,aes(x=wt,y=mpg))+geom_point()+geom_smooth(method = "lm",se=FALSE,color="red")+geom_smooth(method = "loess",se=FALSE,color="blue",linetype="dashed")+labs(title = "Basic Scatter Plot of MPG vs. Weight",x="Car weight",y="Miles per gallon")+theme_bw()
## `geom_smooth()` using formula = 'y ~ x'
## `geom_smooth()` using formula = 'y ~ x'

注:

1.将 se=FALSE 设置为geom_smooth()函数的参数,可以禁用置信区间的显示,使拟合曲线仅显示其基本形状,而不显示任何不确定性范围(阴影)。

2.LOESS 是一种非参数的回归方法,它通过在数据周围的局部区域内进行加权拟合来估计变量之间的关系。它在拟合过程中考虑了数据的局部特征,因此可以更好地适应非线性关系。

2)添加单独的最佳拟合曲线的散点图: 分别绘制四缸、六缸和八缸汽车的汽车重量与燃油效率之间的关系图(mtcars包):

library(ggplot2)
ggplot(mtcars,aes(x=wt,y=mpg,color=factor(cyl),shape=factor(cyl)))+geom_point()+geom_smooth(method = "lm",se=FALSE)+geom_smooth(method = "loess",se=FALSE,linetype="dashed")+labs(title = "Basic Scatter Plot of MPG vs. Weight",subtitle = "By numberof cylinders",x="Car weight",y="Miles per gallon")+theme_bw()
## `geom_smooth()` using formula = 'y ~ x'
## `geom_smooth()` using formula = 'y ~ x'

散点图可以一次对两个定量变量间的关系进行可视化,但当变量超过2个时,可以用散点图矩阵展示。

11.1.1 散点图矩阵(Scatterplot Matrix)

散点图矩阵在R中被用来同时展示多个变量之间的关系。它是一种多变量可视化方法,通过在一个图形中显示多个散点图,可以帮助我们观察和理解变量之间的相互关系,特别是在探索性数据分析中非常有用。

主要用于:

1.变量关系的可视化

2.变量之间的相关性分析

3.特征选择和变量筛选

之前在8.2.4中展示了car包中的ScatterplotMatrix函数创建方法,这里学习GGally包中的ggpairs()函数创建ggplot2版本的散点图矩阵。

  • 11.1.1.1 基础ggpairs()函数(GGally包中的)

观察mtcars数据集中,汽车里程(mpg)、汽车重量(wt)、排量(disp)和后轴比(drat)间的二元关系:

library(GGally)
## Warning: 程辑包'GGally'是用R版本4.3.2 来建造的
## Registered S3 method overwritten by 'GGally':
##   method from   
##   +.gg   ggplot2
ggpairs(mtcars[c("mpg","disp","drat","wt")])

  • 11.1.1.2 添加拟合线、直方图和相关系数的散点图矩阵
library(GGally)
library(ggplot2)
diagplots <- function(data,mapping){ggplot(data = data,mapping = mapping)+geom_histogram(fill="lightblue",color="black")
}
lowerplots <- function(data,mapping){ggplot(data = data,mapping = mapping)+geom_point(color="darkgrey")+geom_smooth(method = "lm",color="steelblue",se=FALSE)+geom_smooth(method = "loess",color="red",se=FALSE,linetype="dashed")
}
upperplots <- function(data,mapping){ggally_cor(data = data,mapping = mapping,display_grid = FALSE,size=3,color="black")
}mytheme <- theme(strip.background = element_blank(),panel.grid = element_blank(),panel.background = element_blank(),panel.border = element_rect(color = "grey20",fill = NA))ggpairs(mtcars,columns = c("mpg","disp","drat","wt"),columnLabels = c("MPG","Displacement","R Axle Ratio","Weight"),lower = list(continuous=lowerplots),diag = list(continuous=diagplots),upper = list(continuous=upperplots))+mytheme
## `stat_bin()` using `bins = 30`. Pick better value with `binwidth`.
## `geom_smooth()` using formula = 'y ~ x'
## `geom_smooth()` using formula = 'y ~ x'
## `stat_bin()` using `bins = 30`. Pick better value with `binwidth`.
## `geom_smooth()` using formula = 'y ~ x'
## `geom_smooth()` using formula = 'y ~ x'
## `geom_smooth()` using formula = 'y ~ x'
## `geom_smooth()` using formula = 'y ~ x'
## `stat_bin()` using `bins = 30`. Pick better value with `binwidth`.
## `geom_smooth()` using formula = 'y ~ x'
## `geom_smooth()` using formula = 'y ~ x'
## `geom_smooth()` using formula = 'y ~ x'
## `geom_smooth()` using formula = 'y ~ x'
## `geom_smooth()` using formula = 'y ~ x'
## `geom_smooth()` using formula = 'y ~ x'
## `stat_bin()` using `bins = 30`. Pick better value with `binwidth`.

知识点补充:

  • 1.theme()函数

theme() 函数是 ggplot2 包中用于设置图表外观的函数。它可以用于修改和自定义图表的各个元素,如标题、轴标签、网格线、背景颜色等。以下是 theme() 函数的一些常用参数和用法:

theme(...)

1)通过 theme() 函数可以设置的图表元素包括:

title:图表标题的样式。

plot.title:绘图区域的标题样式。

axis.title:坐标轴标题的样式。

axis.text:坐标轴刻度标签的样式。

axis.line:坐标轴线的样式。

axis.ticks:坐标轴刻度线的样式。

legend.title:图例标题的样式。

legend.text:图例标签的样式。

panel.background:面板背景的样式。

panel.grid:面板网格线的样式。

panel.border:面板边框的样式。

strip.background:面板标题背景的样式。

2)对于每个图表元素,可以使用不同的函数来设置样式,常用的函数包括:

element_text():用于设置文本样式,如字体、大小、颜色等。

element_line():用于设置线条样式,如颜色、线型、粗细等。

element_rect():用于设置矩形样式,如颜色、填充、边框等。

element_blank():用于设置为空,即不显示该元素。

  • 2.在 ggpairs() 函数中,lower、diag 和 upper参数

用于指定自定义绘图函数,以控制矩阵散点图矩阵中不同位置的图层绘制方式:

lower: 用于指定下三角部分的图层绘制方式;

diag:用于指定对角线部分的图层绘制方式;

upper:用于指定上三角部分的图层绘制方式。

list(continuous =)指定了一个连续型变量的图层设置.

  • 3. ggally_cor()函数 ggally_cor()函数用于创建变量之间相关性矩阵的可视化。

用法:

ggally_cor(data, mapping = NULL, method = "pearson", color = "RdYlBu"

display_grid是一个参数,用于控制是否显示相关性矩阵的网格线。

11.1.2 普通高密度散点图(当观测值较多时容易造成重叠)

set.seed(1234)
n <- 10000
c1 <- matrix(rnorm(n,mean=0,sd=0.5),ncol = 2)#用于生成一个具有 n 行和 2 列的矩阵 c1,其中矩阵的每个元素都是从均值为 0、标准差为 0.5 的正态分布中随机抽取的数字
c2 <- matrix(rnorm(n,mean = 3,sd=2),ncol = 2)
mydata <- rbind(c1,c2)
mydata <- data.frame(mydata)
names(mydata) <- c("x","y")#将mydata数据框原来的列名修改为x和y
library(ggplot2)
ggplot(mydata,aes(x=x,y=y))+geom_point()

注:

rnorm(n, mean = 0, sd = 0.5) 是一个随机函数 rnorm(),用于生成符合正态分布的随机数。其中,n 是要生成的随机数的个数,mean 是正态分布的均值,sd 是正态分布的标准差。在这里,我们生成了 n 个均值为 0、标准差为 0.5 的正态分布随机数。

从该图看出,当观测值较多时,散点重叠后非常难看,可以用下面方法进行改进。

  • 11.1.2.1 利用核密度估计生成用颜色密度来表示点分布的散点图SmoothScatter()
with(mydata,smoothScatter(x,y,main="Scatter Plot colored by smoothed dendities"))

注:SmoothScatter() 函数是一个用于生成平滑散点图的函数,较高密度区域将以较亮的颜色表示,较低密度区域将以较暗的颜色表示,这有助于观察数据的分布模式和聚集情况。

  • 11.1.2.2 方法2

利用hexbin包中的geom_hex()函数

library(ggplot2)
library(hexbin)
## Warning: 程辑包'hexbin'是用R版本4.3.2 来建造的
ggplot(mydata,aes(x=x,y=y))+geom_hex(bins=50)+#bins 参数用于指定六边形的数量或密度级别scale_fill_continuous(trans='reverse')#使颜色较深的表示较大的密度区域

11.1.3 三维散点图

散点图和散点图矩阵都是二元变量关系,如需三元(三维)散点图需要使用scatterplot3d包中的scaterplot3d()函数:

scatterplot3d(x,y,z)

x:水平轴,y:竖直轴,z透视轴。

举例:观察mpg,wt,disp三者的关系:

library(scatterplot3d)
with(mtcars,scatterplot3d(wt,disp,mpg,main = "Basic 3D scatter plot"))

scatterplot3d() 函数的设置包括:

color:用于指定数据点的颜色。

pch:用于指定数据点的形状。可以是一个整数或字符向量,对应于不同的形状选项。例如,pch = 16 表示实心圆点,pch = 3 表示倒三角形。

main:用于设置图表的标题。

xlab、ylab、zlab:用于设置 x、y、z 轴的标签。

xlim、ylim、zlim:用于设置 x、y、z 轴的显示范围。

theta、phi:用于设置视角的旋转。theta 控制水平旋转角度,phi 控制垂直旋转角度。

box:用于控制是否显示坐标轴框线。设定为 FALSE 可以隐藏框线。

type:“p”:绘制散点图(默认选项),即绘制数据点。“l”:绘制连线,将数据点按照它们在数据向量中的顺序连接起来,形成线条。“n”:不绘制任何内容,只创建一个空的 3D 坐标系。“h”绘制垂直于底部平面的线段。

  • 11.1.3.1 设置一些scatterplot3d()的参数
library(scatterplot3d)
with(mtcars,scatterplot3d(wt,disp,mpg,pch = 16,type = "h",main = "Basic 3D scatter plot"))

  • 11.1.3.2 添加回归平面
library(scatterplot3d)
s3d <- with(mtcars,scatterplot3d(wt,disp,mpg,pch = 16,type = "h",main = "Basic 3D scatter plot"))
fit <- lm(mpg~wt+disp,mtcars)
s3d$plane3d(fit)#xxx$plane3d() 函数用于在三维散点图上添加一个平面,fit为一个回归分析,因此是建立回归平面

回归面表示预测值,点为实际值,平面值到点的距离为残差值。若点在平面上,则表示预测值被低估;反之则高估。

11.1.4 旋转三维散点图

  • 11.1.4.1 rgl包中的plot3d()函数

语法:

library(rgl)
plot3d(x,y,z)

参数包括:

1.type: 可选参数,指定绘图类型。常见的类型有:

“s”: 绘制散点图(默认值)。

“l”: 绘制线条。

“h”: 绘制线段,垂直于底部平面。

“n”: 不绘制任何内容,只创建一个空的 3D 坐标系。

2.col

3.size

举例:

library(rgl)
with(mtcars,plot3d(wt,disp,mpg,col="red",size=5))#注意这里用col而非color指定颜色

由于这个是交互式的,这里不展示,在rstudio中进行展示。

  • 11.1.4.2 car包中的scatter3d()函数

与plot3d()相比,scatter3d()包含各种回归曲面,eg线性,二次,平滑和加性等类型的回归曲面。

语法:

library(car)
scatter3d(x,y,z)

举例:

library(car)
library(carData)
library(mgcv)
library(MASS)
library(nlme)
with(mtcars,scatter3d(wt,disp,mpg,color="red",size=5))

同样,这里不做展示,需要展示的去Rstudio中演示。

11.1.5 气泡图

先建立一个二维散点图,用点的大小代表第3个变量的值,即气泡图。

语法:

ggplot(data,aes(x=,y=,size=,fill=factor()))+geom_point(alpha=,color=,shape=)+labs()

size= 即是圆圈大小代表的变量,

fill=factor()按这个进行分组填充,

shape可以设置为数字值,0-25之间,也可以设置为字符型:“circle”(实心圆形),“square”(实心正方形),“triangle”(实心三角形)等。

举例:

ggplot(mtcars,aes(x=wt,y=mpg,size=disp,fill=factor(cyl)))+geom_point(alpha=0.6,shape="circle",aes(color=factor(cyl)))+labs(fill="Cylinders",color="Cylinders")+theme_minimal()

ggplot(mtcars,aes(x=wt,y=mpg,size=disp,color=factor(cyl)))+geom_point(alpha=0.6,shape="circle")+labs(fill="Cylinders",color="Cylinders")+theme_minimal()

两种效果是一样的!

一般来说,统计人员会倾向避免使用气泡图,因为相对于长度,体积或者面积更困难。

11.2 折线图

11.2.1 语法

将散点图上的点连起来即折线图。即在原有基础上加geom_line(),可设置的参数有:

size:线条粗细;

color:线条颜色;

linetype:线型(1实线,2虚线),另外,“solid”:实线(默认值)。“dashed”:虚线。“dotted”:点线。“dotdash”:点划线。“longdash”:长虚线。“twodash”:双划线。

11.2.2 散点图和折线图

用Orange数据集为例,包含5棵树的树龄和年轮数据。现要考察第一颗橘树的生长情况。

library(ggplot2)
tree1 <- subset(Orange,Tree==1)
tree1
## Grouped Data: circumference ~ age | Tree
##   Tree  age circumference
## 1    1  118            30
## 2    1  484            58
## 3    1  664            87
## 4    1 1004           115
## 5    1 1231           120
## 6    1 1372           142
## 7    1 1582           145
ggplot(tree1,aes(x=age,y=circumference))+geom_point(size=1)+geom_line()+theme_bw()

用Orange数据集为例,包含5棵树的树龄和年轮数据。现要考察5颗橘树的生长情况。

library(ggplot2)
Orange
## Grouped Data: circumference ~ age | Tree
##    Tree  age circumference
## 1     1  118            30
## 2     1  484            58
## 3     1  664            87
## 4     1 1004           115
## 5     1 1231           120
## 6     1 1372           142
## 7     1 1582           145
## 8     2  118            33
## 9     2  484            69
## 10    2  664           111
## 11    2 1004           156
## 12    2 1231           172
## 13    2 1372           203
## 14    2 1582           203
## 15    3  118            30
## 16    3  484            51
## 17    3  664            75
## 18    3 1004           108
## 19    3 1231           115
## 20    3 1372           139
## 21    3 1582           140
## 22    4  118            32
## 23    4  484            62
## 24    4  664           112
## 25    4 1004           167
## 26    4 1231           179
## 27    4 1372           209
## 28    4 1582           214
## 29    5  118            30
## 30    5  484            49
## 31    5  664            81
## 32    5 1004           125
## 33    5 1231           142
## 34    5 1372           174
## 35    5 1582           177
ggplot(Orange,aes(x=age,y=circumference,linetype=Tree,color=Tree))+scale_color_brewer(palette = "Set1")+#用于选择调色板geom_point(size=1)+geom_line()+theme_bw()

11.3 相关图

11.3.1 corrgram()函数

来自corrgram()包(需要安装)

语法:

library(corrgram)
corrgram(x,order = ,panel = ,text.panel = ,diag.panel = )

x:是一行一个观测值的数据框

order=TRUE:相关矩阵将使用主成分分析法对变量重排序,这将使得二元变量的关系模式更为明显

panel:可以用lower.panel= 和upper.panel=分别设置主对角线下方和上方的元素类型

text.panel和diag.panel:控制主对角线元素类型。

可用的panel值见下表,其中非对角线的部分主要应用于lower.panel和upper.panel;主对角线部分主要应用于text.panel和diag.panel:

位置面版选项描述
非对角线panel.pie用饼图的填充比例来表示相关性大小
panel.shade用阴影的深度来表示相关性大小
panel.ellipse画一个置信椭圆和平滑曲线
panel.pts画一个散点图
panel.conf画出相关性并包含置信区间
panel.cor画出相关性,不包含置信区间
主对角线panel.txt输出变量名
panel.minmax输出变量的最大最小值和变量名
panel.density输出核密度曲线和变量名

11.3.2 举例

数据集mtcars中变量相关性,共11个变量:

cor <- cor(mtcars,method = "pearson")
cor
##             mpg        cyl       disp         hp        drat         wt
## mpg   1.0000000 -0.8521620 -0.8475514 -0.7761684  0.68117191 -0.8676594
## cyl  -0.8521620  1.0000000  0.9020329  0.8324475 -0.69993811  0.7824958
## disp -0.8475514  0.9020329  1.0000000  0.7909486 -0.71021393  0.8879799
## hp   -0.7761684  0.8324475  0.7909486  1.0000000 -0.44875912  0.6587479
## drat  0.6811719 -0.6999381 -0.7102139 -0.4487591  1.00000000 -0.7124406
## wt   -0.8676594  0.7824958  0.8879799  0.6587479 -0.71244065  1.0000000
## qsec  0.4186840 -0.5912421 -0.4336979 -0.7082234  0.09120476 -0.1747159
## vs    0.6640389 -0.8108118 -0.7104159 -0.7230967  0.44027846 -0.5549157
## am    0.5998324 -0.5226070 -0.5912270 -0.2432043  0.71271113 -0.6924953
## gear  0.4802848 -0.4926866 -0.5555692 -0.1257043  0.69961013 -0.5832870
## carb -0.5509251  0.5269883  0.3949769  0.7498125 -0.09078980  0.4276059
##             qsec         vs          am       gear        carb
## mpg   0.41868403  0.6640389  0.59983243  0.4802848 -0.55092507
## cyl  -0.59124207 -0.8108118 -0.52260705 -0.4926866  0.52698829
## disp -0.43369788 -0.7104159 -0.59122704 -0.5555692  0.39497686
## hp   -0.70822339 -0.7230967 -0.24320426 -0.1257043  0.74981247
## drat  0.09120476  0.4402785  0.71271113  0.6996101 -0.09078980
## wt   -0.17471588 -0.5549157 -0.69249526 -0.5832870  0.42760594
## qsec  1.00000000  0.7445354 -0.22986086 -0.2126822 -0.65624923
## vs    0.74453544  1.0000000  0.16834512  0.2060233 -0.56960714
## am   -0.22986086  0.1683451  1.00000000  0.7940588  0.05753435
## gear -0.21268223  0.2060233  0.79405876  1.0000000  0.27407284
## carb -0.65624923 -0.5696071  0.05753435  0.2740728  1.00000000
library(corrgram)
## Warning: 程辑包'corrgram'是用R版本4.3.2 来建造的
corrgram(cor,order =TRUE ,lower.panel = panel.shade,upper.panel=panel.cor,text.panel =panel.txt ,diag.panel = panel.minmax)
## Warning in par(usr): argument 1 does not name a graphical parameter
## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter

11.3.3 可以用colorRampPallette()函数指定颜色

1.先用colorRampPallette()指定颜色

2.用col.regions选项引用前者的输出结果

library(corrgram)
cols <- colorRampPalette(c("darkgoldenrod4","burlywood1","darkkhaki","darkgreen"))
corrgram(cor,order =TRUE ,col.regions=cols,lower.panel=panel.shade,upper.panel=panel.cor,text.panel =panel.txt ,diag.panel = panel.minmax)
## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter## Warning in par(usr): argument 1 does not name a graphical parameter

11.4 马赛克图(vcd包中的mosaic()函数)

马赛克图是一种用于可视化两个或多个分类变量之间关系的图形。它的特点是图形中的矩形区域的面积与数据频数成比例。通过颜色、阴影或边框等方式,可以进一步表示不同类别的条件概率或关联程度。

语法:

#用法1:
mosaic(table)#table为数组形式的列联表
#用法2
mosaic(formula, data, shade = TRUE, legend = TRUE)#shade = TRUE, legend = TRUE为可选项

formula:一个公式,用于指定变量之间的关系。

data:数据框,包含相关变量。

shade = TRUE:该参数指定是否对马赛克图的矩形区域进行填充。当shade = TRUE时,每个矩形区域将使用不同的颜色进行填充,以区分不同的类别。

legend = TRUE:该参数指定是否显示图例。当legend = TRUE时,会在马赛克图的边缘添加一个图例,用于解释不同的类别或颜色所代表的含义。图例通常包括颜色示例和对应的标签。

举例:

以Titanic数据集为例,包含存活或死亡的乘客数、乘客的船舱等级、性别以及年龄层(儿童或成人)。

library(vcd)
library(grid)
Titanic
## , , Age = Child, Survived = No
## 
##       Sex
## Class  Male Female
##   1st     0      0
##   2nd     0      0
##   3rd    35     17
##   Crew    0      0
## 
## , , Age = Adult, Survived = No
## 
##       Sex
## Class  Male Female
##   1st   118      4
##   2nd   154     13
##   3rd   387     89
##   Crew  670      3
## 
## , , Age = Child, Survived = Yes
## 
##       Sex
## Class  Male Female
##   1st     5      1
##   2nd    11     13
##   3rd    13     14
##   Crew    0      0
## 
## , , Age = Adult, Survived = Yes
## 
##       Sex
## Class  Male Female
##   1st    57    140
##   2nd    14     80
##   3rd    75     76
##   Crew  192     20
mosaic(~Class+Sex+Age+Survived,data = Titanic,shade=TRUE,legend=TRUE)

11.5 补充s3d$plane3d() 函数

其中s3d指三维散点图,s3d$plane3d()则是在s3d的三维散点图中绘制平面。配合fit使用则生成回归平面。

11.6 补充scale_color_brewer(palette = )和调色板

scale_color_brewer(palette = )是用于设置调色板

调色板可用 RColorBrewer 包提供的函数 display.brewer.all() 来查看

library(RColorBrewer)
display.brewer.all()

11.7 补充colors()函数

该函数可以返回所有657种颜色的名称

完整教程请查看

R语言基础学习手册

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/503130.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

神经网络第一课

目录 背景知识生物神经元人工神经元模型神经网络训练神经网络结论背景知识 神经网络是一种人工智能模型,其主要受生物神经系统启发,重现了大脑中神经元之间相互连接的方式。 神经网络已在很多领域中取得显著成就,如图像识别、自然语言处理和语音识别等。 生物神经元 神经…

Docker:安装 XXL-JOB 分布式调度任务的技术指南

1、简述 XXL-JOB 是一个分布式任务调度平台&#xff0c;提供简单易用的任务调度功能。它支持分布式调度、失败重试、任务监控和报警等功能。XXL-JOB 采用了服务端与执行器的架构&#xff0c;任务调度在服务端进行&#xff0c;而任务的实际执行则由各个执行器完成。 XXL-JOB 的…

Git revert回滚

回退中间的某次提交&#xff08;此操作在预生产分支上比较常见&#xff09;&#xff0c;建议此方式使用命令进行操作&#xff08;做好注释&#xff0c;方便后续上线可以找到这个操作&#xff09; Git操作&#xff1a; 命令&#xff1a;revert -n 版本号 1&#xff1a;git re…

新年到了!使用Python创建一个简易的接金元宝游戏

引言 在本教程中&#xff0c;我们将一起学习如何使用Python编程语言和Pygame库来创建一个简单的休闲游戏——“接金元宝”。 准备工作 首先&#xff0c;确保你的计算机上已经安装了Python&#xff08;推荐3.6以上版本&#xff09;和Pygame库。如果还没有安装Pygame&#xff0…

GoF23种设计模式 简介

文章目录 面向对象(OO)设计原则&#xff08;7&#xff09;单一职责原则开闭原则里氏代换原则依赖倒转原则接口隔离原则合成复用原则迪米特法则 创建型模式 &#xff08;5&#xff09;工厂方法模式 &#xff08;类模式&#xff0c;其余都是对象模式&#xff09;抽象工厂模式建造…

【数电尾灯设计】2022-8-16

缘由数电尾灯设计问题&#xff0c;求解答--CSDN问答 从题目可以列出 000 100 010 111-----------4进制 000 100 010 110 001 101 011 111-----------8进制 由列出可知用16进制芯片的3个引脚可以获得8进制推导出4进制从而可用逻辑处理为4进制实现尾灯功能。之上第一步实现了尾灯…

在线机考|2024华为实习秋招春招编程题(最新)——第3题_个性化歌单推荐系统_300分(十一)

题目内容 假设你是音乐服务的开发者,为了提高用户体验需要解决推荐歌单的同质化问题,保证推荐给用户的所有歌单不包含相同歌曲的。给定一个包含N个歌单和M条歌单重复记录,每个歌单用一个从1到N的整数编号,歌单重复记录包含两个歌单的ID,表示两个歌单有相同的歌曲。 你的任…

Ant Design Pro写项目的总结经验(react)

配置代理&#xff08;proxy&#xff09; 在config文件夹下面的config.ts里面配置修改 修改前&#xff1a;修改后&#xff1a; 修改账号框以及登录接口以及登录返回的code 由于它的账号框是username,但是我们接口请求要填写的是account&#xff0c;因此可以全局搜索进行替换…

安卓14无法安装应用解决历程

客户手机基本情况&#xff1a; 安卓14&#xff0c;对应的 targetSdkVersion 34 前天遇到了安卓14适配问题&#xff0c;客户发来的截图是这样的 描述&#xff1a;无法安装我们公司的B应用。 型号&#xff1a;三星google美版 解决步骤&#xff1a; 1、寻找其他安卓14手机测试…

51单片机(二)中断系统与外部中断实验

中断即单片机因为某些原因E暂定现在的工作P0&#xff0c;转去做其他的工作P1&#xff0c;完了之后继续之前的事P0&#xff0c;其他工作P1就是中断程序&#xff0c;原因E就是中断事件&#xff0c;原因由外部发生&#xff0c;程序不能预测到的是硬中断&#xff0c;可以由程度触发…

66.基于SpringBoot + Vue实现的前后端分离-律师事务所案件管理系统(项目 + 论文)

项目介绍 传统办法管理信息首先需要花费的时间比较多&#xff0c;其次数据出错率比较高&#xff0c;而且对错误的数据进行更改也比较困难&#xff0c;最后&#xff0c;检索数据费事费力。因此&#xff0c;在计算机上安装律师事务所案件管理系统软件来发挥其高效地信息处理的作用…

大数据组件(三)快速入门实时计算平台Dinky

大数据组件(三)快速入门实时计算平台Dinky Dinky 是一个开箱即用的一站式实时计算平台&#xff08;同样&#xff0c;还有StreamPark&#xff09;&#xff0c;以 Apache Flink 为基础&#xff0c;连接数据湖仓等众多框架&#xff0c;致力于流批一体和湖仓一体的建设与实践。 Di…

实际开发中,常见pdf|word|excel等文件的预览和下载

实际开发中,常见pdf|word|excel等文件的预览和下载 背景相关类型数据之间的转换1、File转Blob2、File转ArrayBuffer3、Blob转ArrayBuffer4、Blob转File5、ArrayBuffer转Blob6、ArrayBuffer转File 根据Blob/File类型生成可预览的Base64地址基于Blob类型的各种文件的下载各种类型…

《Vue3实战教程》19:Vue3组件 v-model

如果您有疑问&#xff0c;请观看视频教程《Vue3实战教程》 组件 v-model​ 基本用法​ v-model 可以在组件上使用以实现双向绑定。 从 Vue 3.4 开始&#xff0c;推荐的实现方式是使用 defineModel() 宏&#xff1a; vue <!-- Child.vue --> <script setup> co…

源代码编译安装X11及相关库、vim,配置vim(1)

一、目录结构 如下。 所有X11及相关库装到mybuild&#xff0c;源代码下载到src下&#xff0c;解压&#xff0c;进入&#xff0c;编译安装。编译时指定--prefix到相同的目录&#xff0c;即上图中mybuild。 ./configure --prefixpwd/../../mybuild [CFLAGS"-I/path/to/X11…

图漾相机基础操作

1.客户端概述 1.1 简介 PercipioViewer是图漾基于Percipio Camport SDK开发的一款看图软件&#xff0c;可实时预览相机输出的深度图、彩色图、IR红外图和点云图,并保存对应数据&#xff0c;还支持查看设备基础信息&#xff0c;在线修改gain、曝光等各种调节相机成像的参数功能…

vulnhub靶场-potato(至获取shell)

arp-scan -l 扫描IP 使用御剑端口扫描扫描端口&#xff0c;扫到了80和7120两个端口&#xff0c;其中7120为ssh端口 使用dirb http://192.168.171.134 扫描目录 发现info.php 访问为phpinfo界面 访问192.168.171.134为一个大土豆&#xff0c;没什么用 所以我们从ssh入手 盲…

谈一谈对事件循环的理解

事件循环⼜叫做消息循环&#xff0c;是浏览器渲染主线程的⼯作⽅式。特别是在JavaScript和Node.js等异步编程环境中&#xff0c;也是核心概念之一。它的主要作用是管理异步操作&#xff0c;确保代码的执行顺序和效率。 并且这个话题很有可能是一个面试题。我先把参考答案放下面…

kafka使用以及基于zookeeper集群搭建集群环境

一、环境介绍 zookeeper下载地址&#xff1a;https://zookeeper.apache.org/releases.html kafka下载地址&#xff1a;https://kafka.apache.org/downloads 192.168.142.129 apache-zookeeper-3.8.4-bin.tar.gz kafka_2.13-3.6.0.tgz 192.168.142.130 apache-zookee…

解决 IntelliJ IDEA 中 Tomcat 日志乱码问题的详细指南

目录 前言1. 分析问题原因2. 解决方案 2.1 修改 IntelliJ IDEA 的 JVM 选项2.2 配置 Tomcat 实例的 VM 选项 2.2.1 设置 Tomcat 的 VM 选项2.2.2 添加环境变量 3. 进一步优化 3.1 修改 Tomcat 的 logging.properties3.2 修改操作系统默认编码 3.2.1 Windows 系统3.2.2 Linux …