R-韋恩圖系列-VennDiagram

R-韋恩圖系列-ggVennDiagram - 簡書 (jianshu.com)
R-韋恩圖系列-VennDiagram - 簡書 (jianshu.com)
R-韋恩圖系列-UpSetR - 簡書 (jianshu.com)

VennDiagram包是繪制韋恩圖的一個(gè)經(jīng)典包了。它不是基于ggplot體系葫掉,但可以通過轉(zhuǎn)換變?yōu)間gplot對(duì)象(我更習(xí)慣些)些举。另外每次繪圖時(shí),但會(huì)生成一個(gè)日志log文件俭厚,比較麻煩户魏。
參考教程:https://www.r-graph-gallery.com/14-venn-diagramm.html

  • 示例數(shù)據(jù)
# install.packages("VennDiagram")
library(VennDiagram)

genes <- paste0("gene",1:1000)
set.seed(20210302)
gene_list <- list(A = sample(genes,100),
                  B = sample(genes,200),
                  C = sample(genes,300),
                  D = sample(genes,200))
  • 簡單用法:關(guān)鍵是設(shè)置filename參數(shù),如果為正常名挪挤,則直接保存文件至本地叼丑;如果設(shè)置為NULL值,那么會(huì)得到gList圖像扛门,可配合grid.draw {grid}在R界面顯示。但無論哪一種方法都會(huì)生成log文件论寨。
#保存圖片至本地
venn.diagram(gene_list, filename = "test.png")

#在R界面顯示
venn.plot = venn.diagram(gene_list, 
                         filename = NULL)
grid.draw(venn.plot)
file.remove(list.files(pattern = "*log"))
dev.off()

1、類別名 category name

  • 相關(guān)參數(shù)如下:
category.names, #類別名內(nèi)容
cat.cex = 0.6,  #類別名字體大性岬省(相對(duì)1)
cat.fontface = "bold", #加粗
cat.col = rainbow(3)
cat.pos = c(-27, 27, 135),   #0度為12點(diǎn)方向,順時(shí)針旋轉(zhuǎn)
cat.dist = c(0.055, 0.055, 0.085), #類別名距離圓的距離
cat.fontfamily = "sans", #字體
rotation.degree = 60 #旋轉(zhuǎn)角度(逆時(shí)針)
rotation = 1 #適合3 set的情況
  • 演示
venn.plot = venn.diagram(gene_list[1:3], filename = NULL,
                         category.names = LETTERS[1:3],
                         cat.cex = 1.5,
                         cat.fontface = "bold",
                         cat.pos = c(-20, 20, 180),
                         cat.col = rainbow(3))
grid.draw(venn.plot)
file.remove(list.files(pattern = "*log"))
dev.off()

2火焰、圓的相關(guān)設(shè)置

  • 主要包括圓的填充顏色(離散),邊的顏色昌简、形狀、粗細(xì)
fill  #填充顏色
col # 邊的顏色
lwd = 2, #邊的寬度
lty = 'blank', #邊的類型 dashed dotted
  • 演示
library(RColorBrewer)
venn.plot = venn.diagram(gene_list, filename = NULL,
                         fill = brewer.pal(4, "Pastel2"),
                         col = brewer.pal(4, "Pastel2"),
                         lwd = 2, lty = "dashed")
grid.draw(venn.plot)
file.remove(list.files(pattern = "*log"))
dev.off()

如上圖纯赎,我認(rèn)為VennDiagramggVennDiagram包最大的不同就在于圓的填充顏色:前者為離散的顏色,而后者為連續(xù)漸變顏色(參看上一篇筆記)

3犬金、交集數(shù)值展示的相關(guān)設(shè)置

venn.plot = venn.diagram(gene_list,
                         cex = 2,
                         fontface = "bold", 
                         filename = NULL)
grid.draw(venn.plot)
file.remove(list.files(pattern = "*log"))
dev.off()

4、特殊情況 2 sets

  • 如下圖所示樊诺,當(dāng)繪制兩個(gè)set的交集情況時(shí),圓的面積大小與對(duì)應(yīng)數(shù)目成正比词爬;
  • 而且當(dāng)交集數(shù)目過小時(shí),會(huì)自動(dòng)使用引導(dǎo)線注釋
gene_list2 <- list(A = sample(genes,20),
                  B = sample(genes,100))
venn.plot = venn.diagram(gene_list2,
                         filename = NULL)
grid.draw(venn.plot)
file.remove(list.files(pattern = "*log"))
dev.off()
  • 可通過ext.系列參數(shù)修改這根引導(dǎo)線格式顿膨,例如直接取消~
# ext.text = F
# ext.percent = 0 重疊數(shù)目低于多少百分比锅锨,使用線
# ext.pos
# ext.line.lwd
venn.plot = venn.diagram(gene_list2,
                         ext.text = F,
                         filename = NULL)
grid.draw(venn.plot)
file.remove(list.files(pattern = "*log"))
dev.off()
  • 當(dāng)然恋沃,如果不想讓圓的面積與數(shù)值存在這種對(duì)應(yīng)關(guān)系必搞,可通過如下方式進(jìn)行繪制
venn.plot <- draw.pairwise.venn(
  area1 = 50,
  area2 = 50,
  cross.area = 20)
dev.off()

#修改展示標(biāo)簽內(nèi)容
venn.plot[[5]]$label = length(setdiff(gene_list2[[1]], gene_list2[[2]]))
venn.plot[[6]]$label = length(setdiff(gene_list2[[2]], gene_list2[[1]]))
venn.plot[[7]]$label = length(intersect(gene_list2[[1]], gene_list2[[2]]))
grid.draw(venn.plot)
file.remove(list.files(pattern = "*log"))
dev.off()

5、轉(zhuǎn)為ggplot2對(duì)象

library(ggplot2)
library(ggplotify)
library(cowplot)
as.ggplot(plot_grid(grobTree(venn.plot))) +
  ggtitle("This is title")

最后關(guān)于韋恩圖的標(biāo)題囊咏,venn.diagram函數(shù)的mainsub系列參數(shù)可以設(shè)置恕洲;另外由于可以轉(zhuǎn)換為ggplot對(duì)象,所以之后使用ggplot title相關(guān)函數(shù)也可以~

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末梅割,一起剝皮案震驚了整個(gè)濱河市霜第,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌户辞,老刑警劉巖泌类,帶你破解...
    沈念sama閱讀 219,427評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異底燎,居然都是意外死亡刃榨,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,551評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門双仍,熙熙樓的掌柜王于貴愁眉苦臉地迎上來喇澡,“玉大人,你說我怎么就攤上這事殊校。” “怎么了读存?”我有些...
    開封第一講書人閱讀 165,747評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵为流,是天一觀的道長。 經(jīng)常有香客問我让簿,道長敬察,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,939評(píng)論 1 295
  • 正文 為了忘掉前任尔当,我火速辦了婚禮莲祸,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘椭迎。我一直安慰自己锐帜,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,955評(píng)論 6 392
  • 文/花漫 我一把揭開白布畜号。 她就那樣靜靜地躺著缴阎,像睡著了一般。 火紅的嫁衣襯著肌膚如雪简软。 梳的紋絲不亂的頭發(fā)上蛮拔,一...
    開封第一講書人閱讀 51,737評(píng)論 1 305
  • 那天述暂,我揣著相機(jī)與錄音,去河邊找鬼建炫。 笑死畦韭,一個(gè)胖子當(dāng)著我的面吹牛肛跌,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播惋砂,決...
    沈念sama閱讀 40,448評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼西饵,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了期虾?” 一聲冷哼從身側(cè)響起镶苞,我...
    開封第一講書人閱讀 39,352評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤茂蚓,失蹤者是張志新(化名)和其女友劉穎剃幌,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體牍白,經(jīng)...
    沈念sama閱讀 45,834評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡茂腥,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,992評(píng)論 3 338
  • 正文 我和宋清朗相戀三年最岗,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了朝捆。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,133評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡歼捐,死狀恐怖晨汹,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情剥扣,我是刑警寧澤铝穷,帶...
    沈念sama閱讀 35,815評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站晦炊,受9級(jí)特大地震影響宁脊,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜稳衬,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,477評(píng)論 3 331
  • 文/蒙蒙 一坐漏、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧街夭,春花似錦慨畸、人聲如沸衣式。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,022評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽婶博。三九已至凡人,卻和暖如春名党,著一層夾襖步出監(jiān)牢的瞬間传睹,已是汗流浹背岸晦。 一陣腳步聲響...
    開封第一講書人閱讀 33,147評(píng)論 1 272
  • 我被黑心中介騙來泰國打工启上, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人冈在。 一個(gè)月前我還...
    沈念sama閱讀 48,398評(píng)論 3 373
  • 正文 我出身青樓讥邻,卻偏偏與公主長得像,于是被迫代替她去往敵國和親系宜。 傳聞我的和親對(duì)象是個(gè)殘疾皇子发魄,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,077評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容