Функция для применения идентификатора к узлам в дендрограмме

Я хотел бы знать, есть ли функция, которая применяет идентификатор ко всем узлам в данной дендрограмме (двоичное дерево).

Поэтому я хочу функцию, которая после этого на данном дереве будет делать следующее:

attr(tr,"ID")             ## should give 1   or  1 

attr(tr[[1]],"ID")        ## should give 2  or 10

attr(tr[[2]],"ID")        ## should give 3  or 11

attr(tr[[c(1,1)]],"ID")   ##  should give 4  or 100

так далее...

И, если дано, чтобы начать с binaryID 110 (идентификатор главного узла)

это 1-й ребенок ID должен быть 1100, это 2-й ребенок ID должен быть 1101

Заметка: - dendrapply() применяет функцию ко всем узлам дерева

Пакет с использованием = "статистика"

 D=rbind(
+ c(1,1,1,1,1),
+ c(1,2,1,1,1),
+ c(2,2,2,2,2),
+ c(2,2,2,2,1),
+ c(3,3,3,3,3),
+ c(3,3,3,3,2))

Ddend=as.dendrogram(hclust.vector(D))

funID<-function(tr,StartID){
 .....
 attr(n,"ID")= ID  # for all the nodes in tr
 }

Что будет с funID?

1 ответ

Решение

Это код взят из stats:::reorder.dendrogram и модифицировано, чтобы соответствовать метке корня и каждого листа с возрастающим целым числом. Это может не совсем соответствовать вашим спецификациям, но посмотрите, подходит ли это...

label.leaves <- 
 function (x, wts) 
 { N=1
     if (!inherits(x, "dendrogram")) 
         stop("we require a dendrogram")
     oV <- function(x, wts) {
         if (is.leaf(x)) {
             attr(x, "ID") <- N; N <<- N+1
             return(x)
         }
         k <- length(x)
         if (k == 0L) 
             stop("invalid (length 0) node in dendrogram")
         vals <- numeric(k)
         for (j in 1L:k) { N <- N+1
             b <- oV(x[[j]], wts)
             x[[j]] <- b
             vals[j] <- N; N <- N+1
         }
       x
     }
     stats:::midcache.dendrogram(oV(x, wts))
 }

Тестирование:

> Ddend.L <- label.leaves(Ddend)
> rapply(Ddend.L, function(x) return( attr(x, "ID") ))
[1] 1 2 3 4 5 6
Другие вопросы по тегам