統計学における主成分分析
📂統計的分析統計学における主成分分析
概要
多重回帰分析 Y←X1,⋯,Xp を行うとしよう。主成分分析、英語では PCA は、簡単に言えば量的変数が きちんと独立しているように 「再構成」して分析する方法だ。多変量データの分析という観点から見ると、より少ない変数で現象を説明しようとする「次元削減」の意味を持つ。
主成分分析の理論的導出をしっかり理解するためには、線形代数、可能ならば数値線形代数についての知識まで必要だ。全く分からないなら、Step 3, 4も読んで理解してみるといい。数理統計学にある程度自信があるなら、数理統計学での主成分分析 のポストを読むのもいい。
導出
Step 1. p 個の独立変数と n 個のサンプルがあるデータを標準化
y1y2⋮yn=11⋮1x11x21⋮xn1⋯⋯⋱⋯x1px2p⋮xnpβ0β1⋮βp
は、設計行列を使って Y=Xβ+ε として表せる。この X を標準化した行列を Z というのは、j 番目の独立変数 Xj の標本平均 xj と標本標準偏差 sXj に対し (i,j) 成分が
(Z)ij:=sXjxij−xj
の行列である。そうすると、新しい回帰係数
Θ:=θ1θ2⋮θp
について、定数項がない回帰分析の計画行列式 Y=ZΘ+ε を得ることができる。この Z=[Z1⋯Zp] は、ベクトル X1,⋯,Xp を標準化した Z1,⋯,Zp で構成された(n×p) 行列となる。
Step 2.
スペクトル分解について、ZTZ は、(p×p) が対称行列であるが、その定義を考えると、n−11ZTZ は Z1,⋯,Zp に対する共分散行列となる。特に Z は標準化された行列であり、同時に相関係数行列ともなる。スペクトル理論によれば、
{ZTZ=QΛQTQTQ=QQT=I
を満たす直交行列
Q=q11q21⋮qp1q12q22⋮qp2⋯⋯⋱⋯q1pq2p⋮qpp
と、ZTZ の固有値からなる対角行列
Λ=diag(λ1,λ2,⋯,λp)=λ10⋮00λ2⋮0⋯⋯⋱⋯00⋮λp
が存在する。ここで、便宜上 λ1≥λ2≥⋯≥λp になるようにし、Z もそれに対応して再編成した行列と考えよう。
Step 3. 主成分の構成
I=QQT なので、
Y=ZΘ+ε=ZQQTΘ+ε
ここで、C:=ZQ と α:=QTΘ とすると、
Y=Cα+ε
これがC=[C1⋯Cp] に対するC1,⋯,Cp の 主成分pCsだ。j 番目の主成分の形は
Cj=q1jZ1+⋯+qpjZp=i=1∑pqijZj
元の独立変数を線形結合で再構成したものだ。
Step 4.
主成分の独立性も次の計算で確認できる:
⟹⟹⟹ZTZ=QΛQTQTZTZQ=Λ(ZQ)T(ZQ)=ΛCTC=Λ
つまり、
CjTCj={λj0,i=j,i=j
これにより、主成分は必ず独立していて、固有値 λj が 0 に近い程度に小さいことは、Cj=i=1∑pqijZj がゼロベクトルに近いことを意味し、したがってZ1,⋯,Zp が多重共線性を持つと見なすことができる。
■
限界
主成分回帰分析 Y←C1,⋯,Cp は、固有値に問題のある変数を除去することで多重共線性の問題を回避する。さらに、元の回帰分析と比べるとずっと少ない変数を使うため、次元が削減されたと言える。
しかし、主成分分析は万能のように見えるが、必ずしもそうではない。まず、Z を作るために標準化するということは、質的変数や変換に対して手を付けにくい点が多いことを意味し、このように「再構成」する過程で分析自体が理解しにくくなる。
統計が統計学を理解していない人にも必要だと考えると、この点はかなり致命的だ。例えば、韓国経済に対する分析に主成分分析を使うとしたら、失業率X2 や平均初任給X7 など理解しやすい数字ではなく、「総合雇用指数」C4 などの変わった言葉で表されることになる。分析者でさえ、使える回帰式を作り出したとしても、その真の意味を掴むことが出来ない大惨事が起こる可能性がある。(コンピュータ科学の分野では、データの理解より予測と分類が重要であるため、この欠点にあまり神経を使わない。)
また、どの主成分も除外せずにY←C1,⋯,Cp をそのまま使う場合、元のY←X1,⋯,Xp と変わらないが、ここでいくつかの主成分を除外すること自体が、元々あったデータを諦めることを意味する。それでも必要ならば使うべきだが、必要なければわざわざ使う理由はない。使う時は、どんな欠点や限界があるかをはっきりと理解して使うべきだ。
条件数
一方、導出過程で得られる固有値を通じて多重共線性を診断する数値的指標である条件数condition number
κ:=λpλ1
を計算できる。経験的にκ>15 ならば、元のデータに多重共線性があると推測できるが、それほど広く使われてはいない。
参照