我試圖計算和繪制相同的jaccard指數
我的虛擬資料和代碼
df <- data.frame(tumor_type = c("tumor1", "tumor1", "tumor1", "tumor2", "tumor2", "tumor3", "tumor4", "tumor4"), genes = c("geneA", "geneB", "geneC", "geneA", "geneD", "geneD", "geneA", "geneD"))
D1 <- vegdist(unclass(table(df$tumor_type,df$genes)), method = "jaccard")
pheatmap(1-as.matrix(D1))
我明白了

對于我的實際資料,我嘗試了一個在線工具,我得到了這個

我的目標是獲得相似的結果,例如顯示每個子型別中存在的元素及其 jacard 分數
我的資料的一小部分
structure(list(Comparison = c("M0_vs_M1", "M0_vs_M1", "M0_vs_M1",
"M0_vs_M1", "M0_vs_M1", "M0_vs_M1", "M4_vs_M5", "M4_vs_M5", "M4_vs_M5",
"M4_vs_M5", "M4_vs_M5", "M4_vs_M5"), Term = c("GO:0042742", "GO:0009617",
"GO:0006959", "GO:0006956", "GO:0006958", "GO:0002455", "GO:0048863",
"GO:0048864", "GO:0001667", "GO:0048483", "GO:0051129", "GO:0010977"
)), row.names = c(1L, 2L, 3L, 4L, 5L, 6L, 3266L, 3267L, 3268L,
3269L, 3270L, 3271L), class = "data.frame")
我的輸出

uj5u.com熱心網友回復:
您可以通過在內部使用display_numbers = ...引數來添加值pheatmap()。
pheatmap(1-as.matrix(D1), display_numbers = 1-as.matrix(D1))

D2 <- matrix(ncol = 4, nrow = 4)
D2[lower.tri(D2)] <- 1 - D1
D2 <- matrix(D2 % % t(D2), ncol = 4)
diag(D2) <- NA
D2
D3 <- matrix(rep(10, 16), ncol = 4)
diag(D3) <- NA
D3
D4 <- matrix(paste(D3,D2, sep ="\n"), ncol = 4)
diag(D4) <- ""
pheatmap(1-as.matrix(D1), display_numbers = D4)

轉載請註明出處,本文鏈接:https://www.uj5u.com/net/525500.html
標籤:r地图
