使用R繪制花瓣圖_2020-11-10

上篇博客,我們講到了使用R包繪制不超過五組數(shù)據(jù)集的維恩圖,末尾留了個尾巴:就是數(shù)據(jù)集超過五組數(shù)據(jù)集怎么繪制呢,當(dāng)然可以選擇繪制花瓣圖進行數(shù)據(jù)的分析和可視化距帅。下面我就帶了大家使用R繪制花瓣圖!

廢話不多說括堤,直接上R繪圖代碼:


測試數(shù)據(jù)文件內(nèi)容長這樣碌秸!需要的請在該博文下面留言聯(lián)系我!


## 1.導(dǎo)入R包(R包如果沒有安裝悄窃,導(dǎo)入前需要安裝讥电,使用install.packages("R包名稱")進行安裝)

library(rio)

library(plotrix)

## 2.讀取數(shù)據(jù)

venn_data_index <- list.files(path = "./", pattern = "^venn_data")

venn_data <- import(venn_data_index)

sample_id <- colnames(venn_data)

otu_id <- unique(venn_data[,1])

otu_id <- otu_id[otu_id != '']

core_otu_id <- otu_id

otu_num <- length(otu_id)

## 3.遍歷數(shù)據(jù)文件獲取數(shù)據(jù)

for (i in 2:ncol(venn_data)) {

? otu_id <- unique(venn_data[,i])

? otu_id <- otu_id[otu_id != '']

? core_otu_id <- intersect(core_otu_id, otu_id)

? otu_num <- c(otu_num, length(otu_id))

}

core_num <- length(core_otu_id)

## 4.定義備選顏色(示例數(shù)據(jù)20個樣本,所以我設(shè)置了20種顏色)

ellipse_col <- c('#6181BD4E','#F348004E','#64A10E4E','#9300264E','#464E044E','#049a0b4E','#4E0C664E','#D000004E','#FF6C004E','#FF00FF4E','#c7475b4E','#00F5FF4E','#BDA5004E','#A5CFED4E','#f0301c4E','#2B8BC34E','#FDA1004E','#54adf54E','#CDD7E24E','#9295C14E')

## 5.創(chuàng)建繪圖函數(shù):flower_plot()

flower_plot <- function(sample, otu_num, core_otu, start, a, b, r, ellipse_col, circle_col) {

? par( bty = 'n', ann = F, xaxt = 'n', yaxt = 'n', mar = c(1,1,1,1))

? plot(c(0,10),c(0,10),type='n')

? n? <- length(sample)

? deg <- 360 / n

? res <- lapply(1:n, function(t){

? ? draw.ellipse(x = 5 + cos((start + deg * (t - 1)) * pi / 180),

? ? ? ? ? ? ? ? y = 5 + sin((start + deg * (t - 1)) * pi / 180),

? ? ? ? ? ? ? ? col = ellipse_col[t],

? ? ? ? ? ? ? ? border = ellipse_col[t],

? ? ? ? ? ? ? ? a = a, b = b, angle = deg * (t - 1))

? ? text(x = 5 + 2.5 * cos((start + deg * (t - 1)) * pi / 180),

? ? ? ? y = 5 + 2.5 * sin((start + deg * (t - 1)) * pi / 180),

? ? ? ? otu_num[t])

? ? if (deg * (t - 1) < 180 && deg * (t - 1) > 0 ) {

? ? ? text(x = 5 + 3.3 * cos((start + deg * (t - 1)) * pi / 180),

? ? ? ? ? y = 5 + 3.3 * sin((start + deg * (t - 1)) * pi / 180),

? ? ? ? ? sample[t],

? ? ? ? ? srt = deg * (t - 1) - start,

? ? ? ? ? adj = 1,

? ? ? ? ? cex = 1

? ? ? )

? ? } else {

? ? ? text(x = 5 + 3.3 * cos((start + deg * (t - 1)) * pi / 180),

? ? ? ? ? y = 5 + 3.3 * sin((start + deg * (t - 1)) * pi / 180),

? ? ? ? ? sample[t],

? ? ? ? ? srt = deg * (t - 1) + start,

? ? ? ? ? adj = 0,

? ? ? ? ? cex = 1

? ? ? )

? ? }

? })

? draw.circle(x = 5, y = 5, r = r, col = circle_col, border = NA)

? text(x = 5, y = 5, paste('Core:', core_otu))

}

## 6.調(diào)用上述函數(shù)作圖(保存圖片到本地文件夾中)

png('flower.png', width = 1500, height = 1500, res = 200, units = 'px')

flower_plot(sample = sample_id, otu_num = otu_num, core_otu = core_num,

? ? ? ? ? ? start = 90, a = 0.5, b = 2, r = 1, ellipse_col = ellipse_col, circle_col = 'white')

dev.off()

pdf('flower.pdf', width = 15, height = 15)

flower_plot(sample = sample_id, otu_num = otu_num, core_otu = core_num,

? ? ? ? ? ? start = 90, a = 0.5, b = 2, r = 1, ellipse_col = ellipse_col, circle_col = 'white')

dev.off()

## 7.成果展示


結(jié)尾語:

本次我們的維恩圖系列就算完成了轧抗,希望對大家有幫助允趟,大家可以通過“跑”(運行)別人的代碼來進行快速的R語言的學(xué)習(xí)!最后鸦致,請點贊加關(guān)注潮剪,有問題歡迎討論!

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末分唾,一起剝皮案震驚了整個濱河市抗碰,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌绽乔,老刑警劉巖弧蝇,帶你破解...
    沈念sama閱讀 216,372評論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡看疗,警方通過查閱死者的電腦和手機沙峻,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,368評論 3 392
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來两芳,“玉大人摔寨,你說我怎么就攤上這事〔懒荆” “怎么了是复?”我有些...
    開封第一講書人閱讀 162,415評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長竖螃。 經(jīng)常有香客問我淑廊,道長,這世上最難降的妖魔是什么特咆? 我笑而不...
    開封第一講書人閱讀 58,157評論 1 292
  • 正文 為了忘掉前任季惩,我火速辦了婚禮,結(jié)果婚禮上腻格,老公的妹妹穿的比我還像新娘画拾。我一直安慰自己,他們只是感情好荒叶,可當(dāng)我...
    茶點故事閱讀 67,171評論 6 388
  • 文/花漫 我一把揭開白布碾阁。 她就那樣靜靜地躺著输虱,像睡著了一般些楣。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上宪睹,一...
    開封第一講書人閱讀 51,125評論 1 297
  • 那天愁茁,我揣著相機與錄音,去河邊找鬼亭病。 笑死鹅很,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的罪帖。 我是一名探鬼主播促煮,決...
    沈念sama閱讀 40,028評論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼整袁!你這毒婦竟也來了菠齿?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 38,887評論 0 274
  • 序言:老撾萬榮一對情侶失蹤坐昙,失蹤者是張志新(化名)和其女友劉穎绳匀,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,310評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡擅耽,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,533評論 2 332
  • 正文 我和宋清朗相戀三年佛析,在試婚紗的時候發(fā)現(xiàn)自己被綠了涝桅。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,690評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡殉了,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出嗜历,到底是詐尸還是另有隱情宣渗,我是刑警寧澤,帶...
    沈念sama閱讀 35,411評論 5 343
  • 正文 年R本政府宣布梨州,位于F島的核電站痕囱,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏暴匠。R本人自食惡果不足惜鞍恢,卻給世界環(huán)境...
    茶點故事閱讀 41,004評論 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望每窖。 院中可真熱鬧帮掉,春花似錦、人聲如沸窒典。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,659評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽瀑志。三九已至涩搓,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間劈猪,已是汗流浹背昧甘。 一陣腳步聲響...
    開封第一講書人閱讀 32,812評論 1 268
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留战得,地道東北人充边。 一個月前我還...
    沈念sama閱讀 47,693評論 2 368
  • 正文 我出身青樓,卻偏偏與公主長得像常侦,于是被迫代替她去往敵國和親浇冰。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,577評論 2 353

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

  • ## 1.導(dǎo)入R包 library("VennDiagram") library("rio") ## 2.設(shè)置...
    知無牙閱讀 1,036評論 1 1
  • From shirinsplayground聋亡,非常好的機器學(xué)習(xí)的文章肘习,保存下來,慢慢學(xué)習(xí)杀捻。 https://shi...
    iColors閱讀 1,197評論 0 0
  • 久違的晴天井厌,家長會蚓庭。 家長大會開好到教室時,離放學(xué)已經(jīng)沒多少時間了仅仆。班主任說已經(jīng)安排了三個家長分享經(jīng)驗器赞。 放學(xué)鈴聲...
    飄雪兒5閱讀 7,520評論 16 22
  • 創(chuàng)業(yè)是很多人的夢想,多少人為了理想和不甘選擇了創(chuàng)業(yè)來實現(xiàn)自我價值墓拜,我就是其中一個港柜。 創(chuàng)業(yè)后,我由女人變成了超人咳榜,什...
    亦寶寶閱讀 1,808評論 4 1
  • 今天感恩節(jié)哎夏醉,感謝一直在我身邊的親朋好友。感恩相遇涌韩!感恩不離不棄畔柔。 中午開了第一次的黨會,身份的轉(zhuǎn)變要...
    迷月閃星情閱讀 10,562評論 0 11