主成分分析のQモードとRモードの違いについて調べていたんですが、ネット上にほとんど情報を見つけられませんでした。
クラスター分析とか相関係数にもQモードとRモードがあるみたいで、統計では結構一般的に使われている言葉みたいなのですが、これだけ日本語情報が少ないとなるとちょっと困りますね。
統計言語Rのメーリングリストにちょうど次のような質問が寄せられていたので、一部翻訳してみました。
こんにちは。
どなたか主成分分析のQモードとRモードの違いについて教えていただけないでしょうか。
それぞれ prcomp() と princomp() 関数に対応しているようなのですが。
by Lívio Cipriano
こんにちは Livio、
prcomp のヘルプファイルにはこんなことが載ってるよ‥
この計算はデータ行列の特異値分解によって行われます。共分散行列の固有値は使用されません。これは一般的に、結果の計算誤差を減らすのに好ましい方法と言えます。
princomp のヘルプファイルにはこう書いてる‥
princomp は、変数の特徴を抽出する、いわゆるRモードPCAにのみ対応しています。
データ行列が与えられたとき、少なくとも変数と同じ数のサンプルが必要です。
このRとQという用語はレイモンド・キャッテルという心理学者が彼の﹁データボックス﹂の議論の中で導入したものなんだ。 データボックスというのは、データを3つの次元︵サンプル、変数、時間︶から考えるもので、それによってデータを6つの違った方向から分析できるようになる。*1 典型的なデータ行列というのは、観測値︵サンプル︶が行で、変数が列だよね。 そしてさらに典型的には列数よりは行数のほうが多い︵行数>>列数︶。 もし変数の複雑さを軽減した構造を見つけたい*2んだったら普通に変数の解析をすればいい。これがRモードだ。 一方、データ行列の転置行列を解析にかけることもできる。これがQモードだ。 この場合、データ行列の行方向の複雑さを軽減することになるよね。
もし、特異値分解を使って主成分分析を行う場合(prcomp)、RモードかQモードかは特には問題にならない。 だけど、共分散行列に基づく princomp で行う場合にはそれが問題になる。
いま、データ行列の次元が
だったとする︵
個の変数について、
個の観測値がある︶
Rモード解析に princomp を使った場合、共分散行列
の次元は
、ランクは
と
の小さいほうになるよね。
一方、Qモード解析に princomp を使った場合、共分散行列
の次元は
、ランクはRモードのときと同じく
と
の小さいほうになる。
つまり、行数が列数より大きいとき(
)*3、転置行列の共分散行列
の次元は
になるのに、ランクは列数
のままなんだ。*4 *5
まとめると、Qモード解析は変数に対するサンプルの類似パターンを見つける手法、Rモード解析はサンプルに対する変数の類似性を見つける手法ってことだよ。 さらに一般的には時間方向に拡張されて・・・。︵略︶まあ、これは君が知りたいことを超えているよね。 by Bill
このRとQという用語はレイモンド・キャッテルという心理学者が彼の﹁データボックス﹂の議論の中で導入したものなんだ。 データボックスというのは、データを3つの次元︵サンプル、変数、時間︶から考えるもので、それによってデータを6つの違った方向から分析できるようになる。*1 典型的なデータ行列というのは、観測値︵サンプル︶が行で、変数が列だよね。 そしてさらに典型的には列数よりは行数のほうが多い︵行数>>列数︶。 もし変数の複雑さを軽減した構造を見つけたい*2んだったら普通に変数の解析をすればいい。これがRモードだ。 一方、データ行列の転置行列を解析にかけることもできる。これがQモードだ。 この場合、データ行列の行方向の複雑さを軽減することになるよね。
もし、特異値分解を使って主成分分析を行う場合(prcomp)、RモードかQモードかは特には問題にならない。 だけど、共分散行列に基づく princomp で行う場合にはそれが問題になる。
いま、データ行列の次元が
つまり、行数が列数より大きいとき(
まとめると、Qモード解析は変数に対するサンプルの類似パターンを見つける手法、Rモード解析はサンプルに対する変数の類似性を見つける手法ってことだよ。 さらに一般的には時間方向に拡張されて・・・。︵略︶まあ、これは君が知りたいことを超えているよね。 by Bill