溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

如何用R語言的ggplot2+ggforce包繪制散點(diǎn)圖并添加分組邊界

發(fā)布時(shí)間:2021-11-22 15:55:46 來源:億速云 閱讀:710 作者:柒染 欄目:大數(shù)據(jù)

本篇文章給大家分享的是有關(guān)如何用R語言的ggplot2+ggforce包繪制散點(diǎn)圖并添加分組邊界,小編覺得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

今天查找桑基圖的資料的時(shí)候發(fā)現(xiàn)了一份介紹ggforce這個(gè)包的使用方法的文章,發(fā)現(xiàn)發(fā)現(xiàn)添加分組邊界還有其他的實(shí)現(xiàn)方法,今天的推文記錄一下。

示例數(shù)據(jù)就直接使用R語言內(nèi)置的鳶尾花數(shù)據(jù)集

 首先是矩形的分組邊界

使用的是 geom_mark_rect() 函數(shù)

df<-iris
colnames(df)<-paste0("V",1:5)
library(ggplot2)
library(ggforce)
ggplot(data=df,aes(x=V1,y=V2,color=V5))+
  geom_point()+
  geom_mark_rect(aes(fill=V5),alpha=0.1)+
  theme_bw()
 
如何用R語言的ggplot2+ggforce包繪制散點(diǎn)圖并添加分組邊界  
image.png
 添加圓形的分組邊界

使用到的是geom_mark_circle()函數(shù)

df<-iris
colnames(df)<-paste0("V",1:5)
library(ggplot2)
library(ggforce)
ggplot(data=df,aes(x=V1,y=V2,color=V5))+
  geom_point()+
  geom_mark_circle(aes(fill=V5),alpha=0.1)+
  theme_bw()+
  coord_cartesian(clip = "off")+
  theme(plot.margin = margin(50,50,50,150),
        legend.background = element_blank())
 
如何用R語言的ggplot2+ggforce包繪制散點(diǎn)圖并添加分組邊界  
image.png

這里又遇到了一個(gè)新的知識(shí)點(diǎn) coord_cartesian(clip = "off") ,如果加上這一行命令,就能夠讓三個(gè)圓圈在最上層,不加的效果如下圖,顯示不全

參考鏈接是 https://guangchuangyu.github.io/2018/05/ggplot2-clip/

如何用R語言的ggplot2+ggforce包繪制散點(diǎn)圖并添加分組邊界  
image.png
 添加橢圓分組邊界

用到的是geom_mark_ellipse()函數(shù)

df<-iris
colnames(df)<-paste0("V",1:5)
library(ggplot2)
library(ggforce)
ggplot(data=df,aes(x=V1,y=V2,color=V5))+
  geom_point()+
  geom_mark_ellipse(aes(fill=V5),alpha=0.1)+
  theme_bw()+
  coord_cartesian(clip = "off")+
  theme(plot.margin = margin(10,10,10,50),
        legend.background = element_blank())
 
如何用R語言的ggplot2+ggforce包繪制散點(diǎn)圖并添加分組邊界  
image.png
 最后是無規(guī)則形狀的分組邊界

用到的是geom_mark_hull()函數(shù)

df<-iris
colnames(df)<-paste0("V",1:5)
library(ggplot2)
library(ggforce)
#install.packages("concaveman")
library(concaveman)
ggplot(data=df,aes(x=V1,y=V2,color=V5))+
  geom_point()+
  geom_mark_hull(aes(fill=V5),alpha=0.1)+
  theme_bw()+
  coord_cartesian(clip = "off")+
  theme(plot.margin = margin(10,10,10,50),
        legend.background = element_blank())
 

這里會(huì)遇到一個(gè)警告信息Warning message: The concaveman package is required for geom_mark_hull需要安裝并加載concaveman這個(gè)包 ··· install.packages("concaveman") library(concaveman) ···

如何用R語言的ggplot2+ggforce包繪制散點(diǎn)圖并添加分組邊界  
image.png
 還可以給每個(gè)組添加文字標(biāo)簽,加一個(gè)label參數(shù)就好了
df<-iris
colnames(df)<-paste0("V",1:5)
library(ggplot2)
library(ggforce)
#install.packages("concaveman")
library(concaveman)
ggplot(data=df,aes(x=V1,y=V2,color=V5))+
  geom_point()+
  geom_mark_ellipse(aes(fill=V5,label=V5),alpha=0.1)+
  theme_bw()+
  coord_cartesian(clip = "off")+
  theme(plot.margin = margin(10,10,10,50),
        legend.background = element_blank())
 
如何用R語言的ggplot2+ggforce包繪制散點(diǎn)圖并添加分組邊界    

以上就是如何用R語言的ggplot2+ggforce包繪制散點(diǎn)圖并添加分組邊界,小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見到或用到的。希望你能通過這篇文章學(xué)到更多知識(shí)。更多詳情敬請(qǐng)關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI