applyを使用して行列の行全体を実行したいと思います。また、関数で現在の行の行名を使用したいと思います。rownames
関数内でcolnames
、、、dimnames
またはnames
直接使用することはできないようです。この質問の情報に基づいて、おそらく回避策を作成できることを認識しています。
apply
しかし、私の質問は、最初の引数で配列の行名と列名をどのように処理するか、およびによって呼び出される関数内で作成されたオブジェクトへの名前の割り当てをどのように処理するapply
かです。次の例で示したいので、少し一貫性がないようです。このように設計された理由はありますか?
# Toy data
m <- matrix( runif(9) , nrow = 3 )
rownames(m) <- LETTERS[1:3]
colnames(m) <- letters[1:3]
m
a b c
A 0.5092062 0.3786139 0.120436569
B 0.7563015 0.7127949 0.003358308
C 0.8794197 0.3059068 0.985197273
# These return NULL
apply( m , 1 , FUN = function(x){ rownames(x) } )
NULL
apply( m , 1 , FUN = function(x){ colnames(x) } )
NULL
apply( m , 1 , FUN = function(x){ dimnames(x) } )
NULL
# But...
apply( m , 1 , FUN = function(x){ names(x) } )
A B C
[1,] "a" "a" "a"
[2,] "b" "b" "b"
[3,] "c" "c" "c"
# This looks like a column-wise matrix of colnames, with the rownames of m as the column names to me
# And further you can get...
n <- apply( m , 1 , FUN = function(x){ names(x) } )
dimnames(n)
[[1]]
NULL
[[2]]
[1] "A" "B" "C"
# But you can't do...
apply( m , 1 , FUN = function(x){ n <- names(x); dimnames(n) } )
NULL
適用で内部的に何が起こるかを理解したいだけですか?どうもありがとう。