私は2つのことを成し遂げようとしています。まず、ベクトルがある場合1:5
、同じ数の2倍を含み、繰り返しを除く、これらの要素の一意の組み合わせを示す行列(または2つのベクトル)を取得します。
今、私はマトリックスを使用してこれを行うことができます:
foo <- matrix(1:5,5,5)
cbind(foo[upper.tri(foo,diag=TRUE)],foo[lower.tri(foo,diag=TRUE)])
[,1] [,2]
[1,] 1 1
[2,] 1 2
[3,] 2 3
[4,] 1 4
[5,] 2 5
[6,] 3 2
[7,] 1 3
[8,] 2 4
[9,] 3 5
[10,] 4 3
[11,] 1 4
[12,] 2 5
[13,] 3 4
[14,] 4 5
[15,] 5 5
しかし、もっと簡単な方法が必要です。で使用しようとしVectorize
ましseq
たが、エラーが発生します:
cbind(Vectorize(seq,"from")(1:5,5),Vectorize(seq,"to")(5,1:5))
Error in Vectorize(seq, "from") :
must specify formal argument names to vectorize
私がしたい2番目のことは、ベクトルを含むリストがある場合bar
、その要素の要素の数に等しい繰り返しリストの要素を含むベクトルを取得することです。私はこれを行うことができます:
unlist(apply(rbind(1:length(bar),sapply(bar,length)),2,function(x)rep(x[1],x[2])))
[1] 1 1 1 1 1 2 2 2 2 2 2 2 3 3 3 3 3 3 3 3 3 3
しかし、やはりもっと簡単な方法があるはずです。ここで再試行Vectorize
しましたが、同じエラーが発生しました:
Vectorize(rep,"each")(1:length(bar),each=sapply(bar,length))
in Vectorize(rep, "each") :
must specify formal argument names to vectorize