ベース R で推奨される関数はprcomp()
です。そのヘルプ ファイルを読んでください?prcomp
。
例は次のとおりです。
mod <- prcomp(USArrests, scale = TRUE)
mod
はクラスのオブジェクトで"prcomp"
あり、固有ベクトルの行列 (生の/スケーリングされていない主成分) は component にありますx
> str(mod)
List of 5
$ sdev : num [1:4] 1.575 0.995 0.597 0.416
$ rotation: num [1:4, 1:4] -0.536 -0.583 -0.278 -0.543 0.418 ...
..- attr(*, "dimnames")=List of 2
.. ..$ : chr [1:4] "Murder" "Assault" "UrbanPop" "Rape"
.. ..$ : chr [1:4] "PC1" "PC2" "PC3" "PC4"
$ center : Named num [1:4] 7.79 170.76 65.54 21.23
..- attr(*, "names")= chr [1:4] "Murder" "Assault" "UrbanPop" "Rape"
$ scale : Named num [1:4] 4.36 83.34 14.47 9.37
..- attr(*, "names")= chr [1:4] "Murder" "Assault" "UrbanPop" "Rape"
$ x : num [1:50, 1:4] -0.976 -1.931 -1.745 0.14 -2.499 ...
..- attr(*, "dimnames")=List of 2
.. ..$ : chr [1:50] "Alabama" "Alaska" "Arizona" "Arkansas" ...
.. ..$ : chr [1:4] "PC1" "PC2" "PC3" "PC4"
- attr(*, "class")= chr "prcomp"
x
コンポーネントを見てください:
> head(mod$x)
PC1 PC2 PC3 PC4
Alabama -0.9756604 1.1220012 -0.43980366 0.154696581
Alaska -1.9305379 1.0624269 2.01950027 -0.434175454
Arizona -1.7454429 -0.7384595 0.05423025 -0.826264240
Arkansas 0.1399989 1.1085423 0.11342217 -0.180973554
California -2.4986128 -1.5274267 0.59254100 -0.338559240
Colorado -1.4993407 -0.9776297 1.08400162 0.001450164
コンポーネント 1 と 2 を抽出する
> scrs <- mod$x[, 1:2]
> head(scrs)
PC1 PC2
Alabama -0.9756604 1.1220012
Alaska -1.9305379 1.0624269
Arizona -1.7454429 -0.7384595
Arkansas 0.1399989 1.1085423
California -2.4986128 -1.5274267
Colorado -1.4993407 -0.9776297
次に、それらをプロットすることができます:
plot(scrs, asp = 1) ## asp = 1 gives equal scaling to x and y axes