2013-03-06 17 views
6

Ho una matrice nella seguente formacombinando numero di colonna avente stessi valori

[,1] [,2] [,3] [,4] [,5] [,6] [,7] [,8] [,9] [,10] [,11] 
    1  1  3  2  3  1  1  2  3  3  2 

e segue la mia uscita desiderata (combinando i numeri di colonna, avente stessi valori).

a<-1,2,6,7 
b<-3,5,9,10 
c<-4,8,11 
+0

Ogni volta che si nome oggetti 'a',' B', 'C' o' obj1', 'obj2' ecc si è essenzialmente creato un elenco di falso che è molto più difficile da gestire rispetto a quello reale. – Backlin

risposta

1
m1 <- matrix(c(1, 1, 3, 2, 3, 1, 1, 2, 3, 3, 2), nrow = 1) 
split(seq_len(ncol(m1)), m1[1, ]) 

fornisce un elenco con gli elementi desiderati. Presumo che non si vuole veramente creare vettori a, b e c

split(seq_len(ncol(m1)), m1[1, ]) 

$`1` 
[1] 1 2 6 7 

$`2` 
[1] 4 8 11 

$`3` 
[1] 3 5 9 10 
0

La tua domanda è un po 'strano e sospetto che vi manca qualche dettaglio. Per ottenere esattamente quello che vuoi è un po 'goffo. In primo luogo generare alcuni dati:

##Some data 
R> m = matrix(sample(1:3, 10, replace=T), ncol=10) 
R> m 
    [,1] [,2] [,3] [,4] [,5] [,6] [,7] [,8] [,9] [,10] 
[1,] 1 2 2 3 1 3 3 2 2  1 

poi scegliere i valori unici:

R> v = unique(m[1,]) 

ora creare vettori in base alle esigenze:

R> (a = which(v[1]==m[1,])) 
[1] 1 5 10 
R> (b = which(v[2]==m[1,])) 
[1] 2 3 8 9 
R> (c = which(v[3]==m[1,])) 
[1] 4 6 7 

Tuttavia questo non è scalabile (o elegante). Se si dispone di più di un paio di valori, si vuole iterare v, in modo da qualcosa come:

(l = sapply(v, function(i) which(m[1, ] == i))) 

La variabile l è una lista. Per accedere ai singoli elementi, utilizzare

l[[1]] 
l[[2]] 
l[[3]] 
5

Di seguito si fornisce una lista che dovrebbe essere sufficiente:

aList <- setNames(split(seq_along(mat), mat), unique(letters[mat])) 
aList 
# $a 
# [1] 1 2 6 7 
# 
# $c 
# [1] 4 8 11 
# 
# $b 
# [1] 3 5 9 10 

Ma se si ha realmente bisogno le variabili nel proprio ambiente, quindi è possibile fare:

attach(aList) 
+0

(+1) per una soluzione leggermente più elegante – adibender

0

È possibile utilizzare by per raggruppare gli elementi duplicati e restituire i loro nomi.

tab <- read.table(text ='[,1] [,2] [,3] [,4] [,5] [,6] [,7] [,8] [,9] [,10] [,11] 
    1  1  3  2  3  1  1  2  3  3  2',head=T) 

x <- t(tab) 
by(x,x,FUN=rownames) 
INDICES: 1 
[1] "X..1." "X..2." "X..6." "X..7." 
---------------------------------------------------------------------------------------------------------- 
INDICES: 2 
[1] "X..4." "X..8." "X..11." 
---------------------------------------------------------------------------------------------------------- 
INDICES: 3 
[1] "X..3." "X..5." "X..9." "X..10." 

EDIT uscita più bella

rownames(x) <- 1:nrow(x) 
> by(x,x,FUN=rownames) 
INDICES: 1 
[1] "1" "2" "6" "7" 
---------------------------------------------------------------------------------------------------------- 
INDICES: 2 
[1] "4" "8" "11" 
---------------------------------------------------------------------------------------------------------- 
INDICES: 3 
[1] "3" "5" "9" "10" 
Problemi correlati