中级绘图
1、散点图
1 2 3 4 5 6 7
| attach(mtcars) plot(wt,mpg,main="基本散点图:英里数与车重",xlab = "车重(lbs/1000)",ylab="一加仑的公里数",pch=19) abline(lm(mpg~wt),col="red",lwd=2,lty=1) lines(lowess(wt,mpg),col="blue",lwd=2,lty=2)
|
data:image/s3,"s3://crabby-images/3b7d5/3b7d59c06cebd35b57d5592a1448a03d80fbd6ba" alt=""
1 2
| library(car) scatterplot(mpg~wt|cyl,data=mtcars,lwd=2,main="不同气缸英里数与车重",xlab="车重(lbs/1000)",ylab="每加仑距离",legend.plot=TRUE,id.method="identify",labels=row.names(mtcars),boxplots="xy")
|
data:image/s3,"s3://crabby-images/cdf45/cdf45b491eba4b95d54cde0c60ac34cb9b1b86c6" alt=""
1.1、散点矩阵图
1 2 3 4
| plot(~mpg+disp+drat+wt,data=mtcars) pairs(~mpg+disp+drat+wt,data=mtcars,upper.panel = NULL)
|
data:image/s3,"s3://crabby-images/254e7/254e721abe96533510af136e73727bdee75ffe2b" alt=""
data:image/s3,"s3://crabby-images/dc1bb/dc1bb58e8101c14c080a1fa1c00a45fb8be475c7" alt=""
1 2 3 4
| library(car) scatterplotMatrix(~mpg+disp+drat+wt,data=mtcars,spread=FALSE,lty.smooth=2,main="散点矩阵图")
|
data:image/s3,"s3://crabby-images/cf5a8/cf5a84064252d0f2e89198db6ab77c18b7639d1f" alt=""
1 2
| scatterplotMatrix(~mpg+disp+drat+wt|cyl,data=mtcars,by.groups = TRUE,diagonal="histogram",main="散点矩阵图")
|
data:image/s3,"s3://crabby-images/c6396/c6396e072c12d6ad56395f38f3c9907722158013" alt=""
1 2 3 4 5 6 7 8 9 10
| library(gclus) mydata<-mtcars[c(1,3,5,6)] mydata.corr<-abs(cor(mydata)) mycolors<-dmat.color(mydata.corr) myorder<-order.single(mydata.corr) cpairs(mydata,myorder,panel.colors = mycolors,gap=.5,main="根据相关性排序与着色图")
|
data:image/s3,"s3://crabby-images/90ab3/90ab3a6e82f46e2c4f2ada58289fbafa1ee95a69" alt=""
1.2、高密度散点图
1 2 3 4 5 6 7 8 9
| set.seed(1234) n<-10000 c1<-matrix(rnorm(n,mean = 0,sd=0.5),ncol=2) c2<-matrix(rnorm(n,mean = 3,sd=2),ncol=2) mydata<-rbind(c1,c2) mydata<-as.data.frame(mydata) names(mydata)<-c("x","y") with(mydata,plot(x,y,pch=19,main="Scatter Plot with 10000 points"))
|
data:image/s3,"s3://crabby-images/2a206/2a206ebd91de24a6842e11bd3eb0383a04b299ab" alt=""
1
| with(mydata,smoothScatter(x,y,main="Scatter Plot with 10000 points"))
|
data:image/s3,"s3://crabby-images/f4e91/f4e91b0642ca2395c7a713b2ee332db257bfeebc" alt=""
1 2 3 4 5
| library(hexbin) with(mydata,{ bin<-hexbin(x,y,xbins=50) plot(bin,main="六边形散点图") })
|
data:image/s3,"s3://crabby-images/e52bb/e52bb95482d7e07fc28bd06bfc8dde9ebb4588f9" alt=""
1 2
| library(IDPmisc) with(mydata,iplot(x,y,main="颜色散点图"))
|
data:image/s3,"s3://crabby-images/07f34/07f344ee717fbbd1ba5c6de6e58c2557ecc8c90c" alt=""
1.3、三维散点图
1 2 3
| library(scatterplot3d) attach(mtcars) scatterplot3d(wt,disp,mpg,main="三维散点图")
|
data:image/s3,"s3://crabby-images/c117f/c117fa6e6665b5389595ec4f2a566d2d6763bb6f" alt=""
1 2
| scatterplot3d(wt,disp,mpg,pch=16,highlight.3d=TRUE,type="h",main="三维散点图")
|
data:image/s3,"s3://crabby-images/64de9/64de944f99e3cce910bc875fc83a2fe5a0e8f868" alt=""
1 2 3 4
| s3d<-scatterplot3d(wt,disp,mpg,pch=16,highlight.3d=TRUE,type="h",main="三维散点图与回归面") fit<-lm(mpg~wt+disp) s3d$plane3d(fit)
|
data:image/s3,"s3://crabby-images/5b605/5b605002f0286e7d076b5af99f430420722996ca" alt=""
1 2 3 4
| library(rgl) attach(mtcars) plot3d(wt,disp,mpg,col="red",size=5)
|
data:image/s3,"s3://crabby-images/d61e6/d61e6a5dfe0872c4173657ad65b37984dd189c29" alt=""
1 2 3
| library(Rcmdr) scatter3d(wt,disp,mpg)
|
data:image/s3,"s3://crabby-images/b1c68/b1c68b15f7d232528ee9dc259ec594a08e8dfb48" alt=""
1.4、气泡图
1 2 3 4 5
| r<-sqrt(disp/pi) symbols(wt,mpg,circle=r,inches = 0.30,fg="white",bg="lightblue",main="气泡图,比例为排量", ylab="每加仑公里数",xlab="自重(lbs/1000)") text(wt,mpg,rownames(mtcars),cex=0.6)
|
data:image/s3,"s3://crabby-images/57677/5767737254278d1319d1f5128aad75da060a01bf" alt=""
2、折线图
data:image/s3,"s3://crabby-images/b5e8d/b5e8d18b9954b79cc49d7894af9a9daf2150ab39" alt=""
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28
| Orange$Tree<-as.numeric(Orange$Tree) ntrees<-max(Orange$Tree) xrange<-range(Orange$age) yrange<-range(Orange$circumference) plot(xrange,yrange,type="n", xlab="树龄/天",ylab="直径/mm") colors<-rainbow(ntrees) linetype<-c(1:ntrees) plotchar<-seq(18,18+ntrees,1) for(i in 1:ntrees){ tree<-subset(Orange,Tree==i) lines(tree$age,tree$circumference, type="b",lwd=2, lty=linetype[i], col=colors[i], pch=plotchar[i]) } title("树图","折线示例") legend(xrange[1],yrange[2], 1:ntrees,cex=0.8,col=colors,pch=plotchar,lty=linetype,title="Tree")
|
data:image/s3,"s3://crabby-images/16ea1/16ea1cebbe9c03113470ffce22f069607c21293b" alt=""
3、相关图
1 2 3 4 5 6 7 8 9 10 11 12 13 14
| library(corrgram) corrgram(mtcars,order=TRUE,lower.panel = panel.shade,upper.panel = panel.pie,text.panel = panel.txt, main="相关系数图")
|
data:image/s3,"s3://crabby-images/bc577/bc577ff5e28f048ac50a5d3e12bc535ce2153eb0" alt=""
1 2 3 4 5 6
| corrgram(mtcars,order=TRUE, lower.panel = panel.ellipse, upper.panel = panel.pts, text.panel = panel.txt, diag.panel = panel.minmax, main="相关系数图")
|
data:image/s3,"s3://crabby-images/a86de/a86de90bf097e60c1efe6f7d3f6c67e03182853a" alt=""
4、马赛克图
1 2 3 4 5 6 7 8 9
| library(vcd) ftable(Titanic) mosaic(Titanic,shade = TRUE,legend=TRUE)
|
data:image/s3,"s3://crabby-images/7f0d8/7f0d875128ecd3fb54bfc98b02d23aca1a97e932" alt=""