17

我为大约 50 个人中的每一个人设置了三个因素(set1、set2 和 set3)。set1、set2 和 set3 的值为“A”、“B”、“C”。我想为这些数据制作一个类似热图的图,但让图例显示与值相关的颜色(例如,A='red',B='blue',C='black')。有什么建议么?

谢谢。

4

2 回答 2

26

我决定用 ggplot2 来解决这个问题很容易(无论如何对我来说):

#recreate a data set
dat <- data.frame(person=factor(paste0("id#", 1:50), 
    levels =rev(paste0("id#", 1:50))), matrix(sample(LETTERS[1:3], 150, T), ncol = 3))

library(ggplot2); library(reshape2)
dat3 <- melt(dat, id.var = 'person')
ggplot(dat3, aes(variable, person)) + geom_tile(aes(fill = value),
   colour = "white") + scale_fill_manual(values=c("red", "blue", "black"))

在此处输入图像描述

于 2012-10-21T13:54:08.600 回答
3

也可以使用基本图形制作类似的图。这是使用基image函数的一种方法。该样本具有分类响应而不是数字响应。

dx <- data.frame( Tasks = c('1','2','3','4'),
                  Phase1 = c('Done','Done','Done','WIP'),
                  Phase2 = c('WIP','Done','Done',''),
                  Phase3 = c('','WIP','Done',''))

ff<-factor(as.matrix(dx[,2:4]), 
    levels=c("Done","WIP",""), 
    labels=c("done","wip","-empty-")
)
fx<-matrix(as.numeric(ff), ncol=ncol(dx)-1)

#use labels to assign colors
col<-c(done="darkgreen",wip="orange","-empty-"="black")

imgflip<-function(x) {t(x[nrow(x):1,])}

image(imgflip(fx),
    breaks=(1:(nlevels(ff)+1))-.5,
    col=col[levels(ff)],
    xaxt="n", yaxt="n"
)
axis(2, at=seq(0,1,length.out=nrow(dx)), labels=rev(paste("Task",dx$Tasks)), las=2)
axis(3, at=seq(0,1,length.out=length(names(dx))-1), labels=names(dx)[-1])

这将产生这张照片。

示例图像

于 2014-05-09T05:22:52.107 回答