在自组织映射中通过神经元绘制类概率

时间:2014-11-26 13:07:20

标签: r plot som

我在R中找到了一个很好的自组织地图聚类教程,其中解释了如何在单位空间中显示输入数据(见下文)。为了设置标签的一些规则,我想计算每个神经元中每个类的概率并绘制它。计算概率相当容易:为每个单位取出第i类观测的数量,并将其除以该单位的观测总数。我最终得到data.frame pc。现在我很难映射这个结果,任何关于如何做到这一点的线索?

library(kohonen)
data(yeast)
set.seed(7)
yeast.supersom <- supersom(yeast, somgrid(8, 8, "hexagonal"),whatmap = 3:6)

classes <- levels(yeast$class)
colors <- c("yellow", "green", "blue", "red", "orange")
par(mfrow = c(3, 2))
plot(yeast.supersom, type = "mapping",pch = 1, main = "All", keepMargins = TRUE,bgcol = gray(0.85))

library(plyr)
pc <- data.frame(Var1=c(1:64))

for (i in seq(along = classes)) {
  X.class <- lapply(yeast, function(x) subset(x, yeast$class == classes[i]))
  X.map <- map(yeast.supersom, X.class)
  plot(yeast.supersom, type = "mapping", classif = X.map,
  col = colors[i], pch = 1, main = classes[i], add=TRUE)

  # compute percentage per unit
  v1F <- levels(as.factor(X.map$unit.classif))
  v2F <- levels(as.factor(yeast.supersom$unit.classif))
  fList<- base::union(v2F,v1F)
  pc <- join(pc,as.data.frame(table(factor(X.map$unit.classif,levels=fList))/table(factor(yeast.supersom$unit.classif,levels=fList))*100),by = 'Var1')
  colnames(pc)[NCOL(pc)]<-classes[i]
}

1 个答案:

答案 0 :(得分:0)

好的家伙在这里是一个解决方案: 一旦我计算了概率,它就从定义的梯度(rbPal)中导出颜色代码。渐变由上限和下限定义,颜色的阴影与其间隔成比例。这是通过函数findInterval完成的。

# compute percentage per unit
  v1F <- levels(as.factor(X.map$unit.classif))
  v2F <- levels(as.factor(yeast.supersom$unit.classif))
  fList<- base::union(v2F,v1F)
  pc <- join(pc,as.data.frame(table(factor(X.map$unit.classif,levels=fList))/table(factor(yeast.supersom$unit.classif,levels=fList))*100),by = 'Var1')
  colnames(pc)[NCOL(pc)]<-classes[i]
  rbPal <- colorRampPalette(c('blue','yellow','red'))
  plot(yeast.supersom, type="mapping", bgcol = rbPal((100))[(findInterval(pc[,which(colnames(pc)==as.character(classes[i]))], seq(0:100))+1)], main = paste("Probabily Clusters:", classes[i]))