综合图区亚洲网友自拍|亚洲黄色网络|成人无码网WWW在线观看,日本高清视频色视频kk266,激情综合五月天,欧美一区日韩一区中文字幕页

English | 中文版 | 手機版 企業(yè)登錄 | 個人登錄 | 郵件訂閱
當(dāng)前位置 > 首頁 > 技術(shù)文章 > 一文教你如何用代謝組學(xué)中層次聚類熱圖的R語言實現(xiàn)-pheatmap( )函數(shù)

一文教你如何用代謝組學(xué)中層次聚類熱圖的R語言實現(xiàn)-pheatmap( )函數(shù)

瀏覽次數(shù):4495 發(fā)布日期:2021-12-9  來源:本站 僅供參考,謝絕轉(zhuǎn)載,否則責(zé)任自負(fù)

在代謝組學(xué)的數(shù)據(jù)分析中,通常根據(jù)代謝物的含量進行層次聚類分析,以反映各個樣本之間代謝物含量的差異。

 

常用的數(shù)據(jù)分析工具中,R語言中的程序包可以靈活繪制出非常美觀的層次聚類熱圖形。本文將利用R語言中的pheatmap包對繪制層次聚類熱圖進行詳細的介紹(詳細參數(shù)見文末彩蛋。

一、pheatmap( )函數(shù)常用參數(shù)簡介

 

pheatmap(mat,  # 熱圖的輸入數(shù)據(jù),數(shù)據(jù)類型為數(shù)值型data.frame或matrix

color = colorRampPalette(rev(brewer.pal(n = 7, name = "RdYlBu")))(100),  # 熱圖顏色設(shè)置

cellwidth = NA,  # 設(shè)置熱圖單元格的寬度

cellheight = NA,  # 設(shè)置熱圖單元格的高度

treeheight_row = ifelse((class(cluster_rows) == "hclust") || cluster_rows, 50, 0),  # 設(shè)置行聚類樹的高度

treeheight_col = ifelse((class(cluster_cols) == "hclust") || cluster_cols, 50, 0),  # 設(shè)置列聚類樹的高度

cluster_rows = TRUE,  # 是否對行進行聚類

cluster_cols = TRUE,  # 是否對列進行聚類

cutree_rows = NA,  # 設(shè)置將行聚類的結(jié)果分割成多少個集群,分割依據(jù)時基于層次聚類結(jié)果,如果未對行進行聚類,則該參數(shù)被直接忽略

cutree_cols = NA,  # 設(shè)置將列聚類的結(jié)果分割成多少個集群,分割依據(jù)時基于層次聚類結(jié)果

annotation_row = NA,  # 在熱圖左側(cè)添加注釋,可用于顯示代謝物的分類信息,數(shù)據(jù)為data.frame格式

annotation_col = NA,  # 在熱圖頂部添加注釋,可用于顯示分組信息,數(shù)據(jù)為data.frame類型

border_color = "grey60",  # 熱圖內(nèi)部單元格的邊界顏色,可設(shè)置為NA無邊界

display_numbers = F,  # 是否在熱圖單元格中顯示相應(yīng)的數(shù)值

fontsize = 10,  # 基礎(chǔ)字體大小設(shè)置

fontsize_row = fontsize,  # 行名字體大小設(shè)置

fontsize_col = fontsize,  # 列名字體大小設(shè)置

filename = NA,  # 保存熱圖的全文件路徑,包含路徑和輸出的熱圖文件名(當(dāng)設(shè)置了filename時,圖形顯示器將不再顯示熱圖

…)

 

 

二、pheatmap( )函數(shù)繪制熱圖實戰(zhàn)

 第一步:安裝所需的R包及原始數(shù)據(jù)導(dǎo)入

install.packages("openxlsx")   # 導(dǎo)入excel數(shù)據(jù)所需的R包

install.packages("pheatmap")   # 繪制熱圖所需的R包

library(openxlsx)

library(pheatmap)

data <- read.xlsx(‘E: /R_TEST.xlsx’)  # 導(dǎo)入數(shù)據(jù)(案例中的數(shù)據(jù)非真實數(shù)據(jù))

rownames(data) <- data[, 1]  # 設(shè)置行名


第二步:基礎(chǔ)熱圖-默認(rèn)參數(shù)

pheatmap(data[, c(3:8)])


圖片
第三步:設(shè)置顏色

pheatmap(data[, c(3:8)], color = colorRampPalette(c('red', 'white', 'blue'))(100))  

# 其中('red', 'white', 'blue')和(100)可根據(jù)需求自行修改


圖片
第四步:設(shè)置單元格大小

pheatmap(data[, c(3:8)], cellwidth = 18, cellheight = 18)


圖片
第五步:設(shè)置聚類樹的高度

pheatmap(data[, c(3:8)], treeheight_row = 100)  

# 設(shè)置行(代謝物)聚類樹的高度

pheatmap(data[, c(3:8)], treeheight_col = 100)  

# 設(shè)置列(樣本)聚類樹的高度


圖片
圖片
第六步:取消聚類

pheatmap(data[, c(3:8)], cluster_rows = FALSE)  

# 取消行聚類

pheatmap(data[, c(3:8)], cluster_cols = FALSE)  

# 取消列聚類


圖片
圖片
第七步:依據(jù)聚類結(jié)果對熱圖進行分割

pheatmap(data[, c(3:8)], cluster_rows = TRUE, cluster_cols = FALSE, cutree_rows = 3) 

# cutree_rows = 3 是根據(jù)聚類結(jié)果進行的具體值設(shè)置


圖片
第八步:添加樣本分組信息

annotation_col = data.frame(Group = factor(rep(c('A','B'), c(3,3))), row.names = colnames(data[, c(3:8)]))   

# 對每個樣本設(shè)置相對于的分組,(A、B為組名,3為每個組的樣本數(shù))

注意:原始數(shù)據(jù)表中每個分組的樣本放在一起,否則factor( )需一一對應(yīng)樣本名設(shè)置相對應(yīng)的分組名。
pheatmap(data[, c(3:8)], cluster_rows = TRUE, cluster_cols = FALSE, cutree_rows = 3, annotation_col = annotation_col)

圖片
第九步:添加代謝物分類信息

annotation_row = data.frame(Class = data$Class, row.names = rownames(data))

pheatmap(data[, c(3:8)], cluster_rows = TRUE, cluster_cols = FALSE, cutree_rows = 3, annotation_col = annotation_col, annotation_row = annotation_row)


圖片
第十步:設(shè)置單元格邊框顏色,默認(rèn)顏色為灰色(grey30)

pheatmap(data[, c(3:8)], cluster_rows = TRUE, cluster_cols = FALSE, cutree_rows = 3, annotation_col = annotation_col, annotation_row = annotation_row, border_color = NA)

# border_color = NA 表示不設(shè)置單元格邊框顏色


圖片
第十一步:單元格內(nèi)顯示數(shù)值

pheatmap(data[, c(3:8)], cluster_rows = TRUE, cluster_cols = FALSE, cutree_rows = 3, annotation_col = annotation_col, annotation_row = annotation_row, border_color = NA, display_numbers = T)


圖片
第十二步:設(shè)置字體大小

pheatmap(data[, c(3:8)], cluster_rows = TRUE, cluster_cols = FALSE, cutree_rows = 3, annotation_col = annotation_col, annotation_row = annotation_row, border_color = NA, display_numbers = T, fontsize = 11)
也可使用fontsize_row和fontsize_col分別對行標(biāo)簽和列標(biāo)簽進行字體大小設(shè)置。
pheatmap(data[, c(3:8)], cluster_rows = TRUE, cluster_cols = FALSE, cutree_rows = 3, annotation_col = annotation_col, annotation_row = annotation_row, border_color = NA, display_numbers = T, fontsize = 11, fontsize_row = 13, fontsize_col = 15)
圖片
第十三步:保存熱圖

pheatmap(data[, c(3:8)], cluster_rows = TRUE, cluster_cols = FALSE, cutree_rows = 3, annotation_col = annotation_col, annotation_row = annotation_row, border_color = NA, display_numbers = T, filename = 'E:/R_TEST.png')   
# filename為保存路徑和文件名
注意:設(shè)置filename后,RStudio圖形界面將不再顯示出熱圖。

 

彩蛋:pheatmap( )函數(shù)的參數(shù)詳解

網(wǎng)盤下載鏈接:

https://pan.baidu.com/s/1ao690Lpk2upH57_pu5AElw 

提取碼:98e4

來源:上海百趣生物醫(yī)學(xué)科技有限公司
聯(lián)系電話:021-61531195
E-mail:chengyichun@biotree.cn

用戶名: 密碼: 匿名 快速注冊 忘記密碼
評論只代表網(wǎng)友觀點,不代表本站觀點。 請輸入驗證碼: 8795
Copyright(C) 1998-2025 生物器材網(wǎng) 電話:021-64166852;13621656896 E-mail:info@bio-equip.com