多重共線性とは、説明変数どうしの相関が高いと起こる現象で、相関している変数それぞれの係数の標準誤差が大きくなる現象です。
サンプルを変えただけで係数が大きく動き、正負の符号が反対になる場合もあります。
多重共線性があるかどうかの検定にはVIF(Variance Inflation Factor)を使います。10以上であると多重共線性があると判断されます。
多重共線性がある場合は、相関している変数のいずれかを除くのがよいですが、両方使いたい場合は平均をとったり、主成分分析を使って、相関の無い変数に変化する方法があります。
経済統計の使い方では、統計データの入手法から分析法まで解説しています。

多重共線性=説明変数どうしの相関が高いこと
最小二乗法が優れた結果をもたらす条件として、「説明変数に相関がない」があります。
多重共線性(multicollinearity)は、説明変数どうしに相関がある場合のことです。
英語の略で「マルチコがある」などと呼ばれることもあります。相関が高い場合は通常線形の関係にあるので、共線性と呼びます。
標準誤差が大きくなる
多重共線性がある場合、係数の標準誤差が大きくなります。係数が最小二乗法によって推定できたとしても、確率的に存在する範囲が広いということです。その結果以下のような症状が出てきます。
- サンプルを少し変えただけで結果が大きく変わる
- 標準誤差が大きいのでt値は小さくなる
- 想定された符号と反対になる場合もしばしばある
3Dグラフでみると
3Dグラフでみると、説明変数がX1とX2が相関していない場合、Yを推計した平面はどっしり落ち着いています。多少サンプルが増えても減っても係数が揺らがないです。

下のグラフは、説明変数X1とX2が相関している場合です。Yに回帰した平面は定まらず、サンプル数が少し増えただけで大きく平面の傾きが変わりそうです。

多少わかりにくいと思いますので、動画もみて下さい。点が平面を支えていない様子がわかると思います。
3Dグラフの描き方は最後を参考にしてください。
発見にはVIF
多重共線性があるかどうかを発見するには、VIF(Variance Inflation Factor)を使います。分散膨張要因という意味ですが、係数の誤差を広げる要因ということです。
変数同士に相関があるかどうかを見つけるという意味では相関係数でよいのではないかという気もします。確かに、2変数であれば相関係数を見ても多重共線性があるかどうかはわかります。しかし、3変数以上になると、それぞれの組み合わせを計算する必要があります。場合によっては、ある変数とほかの変数2つの組み合わせで相関が高い可能性もあります。そこで、3変数
VIFはその決定係数
決定係数が高いということは、
多重共線性の目安として、VIFが10以上だと多重共線性が疑われるといわれています。
2変数の場合で相関係数とVIFの関係をみるとVIFが10ということは以下の式が成り立つとういことです。
決定係数が0.9、相関係数に直すと平方根をとって0.95ということになります。
多重共線性への対処
多重共線性は相関の高い変数が入っているということなので、VIFが最も高い変数を外すことが有効です。その変数を除いても、ほかに相関が高い変数が入っているので、推定結果は大きな影響を受けないはずです。
相関の高い変数がわかっていて、しかも両方の変数を入れたい場合は、平均をとって新たな説明変数とすることが考えられます。
別の方法として、相関の高い変数群を主成分分析にかけて、第1主成分、第2主成分などを説明変数とすることが考えられます。主成分どうしは相関がないので、多重共線性の問題は生じません。
具体例
以下の仮想データを使って多重共線性の影響を見ていきましょう。使ったデータはここにあります。サンプル数は50です。
と には高い相関関係 は と と低い相関関係 は で計算する。
推定結果
推定結果は以下の結果になりました。
変数 | 係数 | 標準誤差 | t値 |
10.78 | 0.80 | 13.5 | |
0.52 | 0.10 | 5.2 | |
0.46 | 0.10 | 4.6 | |
0.50 | 0.014 | 35.3 |
サンプル数を変えた場合
サンプルを1~40、1~30に変えた場合の
サンプル数 | 1-50 | 1-40 | 1-30 |
10.78 | 10.39 | 9.97 | |
0.52 | 0.61 | 0.69 | |
0.46 | 0.39 | 0.36 | |
0.50 | 0.51 | 0.51 |
VIFの計算
VIFを計算すると、各変数は以下の結果になりました。
14.2 14.2 1.2
を除いた推定
多重共線性が疑われるX2を除いて推定すると以下の結果となります。
変数 | 係数 | 標準誤差 | t値 |
11.4 | 0.93 | 12.2 | |
0.96 | 0.035 | 27.4 | |
0.51 | 0.017 | 30.5 |
EViewsの出力例
詳しいデータが見られるようにするため、EViewsの推定結果も載せておきます。
基本的な推計

サンプル数40の場合

サンプル数30の場合

VIFの結果

を除いた推定

3DグラフのRプログラム
library(rgl)
plot3d(mdata$X1,mdata$X2,mdata$Y,type="p",col="blue")
fit <- lm(Y ~ X1+X2 , mdata)
coefs <- coef(fit)
planes3d(coefs[2], coefs[3], -1, coefs[1], col="blue", alpha=0.5)
次にもう一つグラフを描きます。
plot3d(mdata$X1,mdata$X3,mdata$Y,type="p",col="red")
fit <- lm(Y ~ X1+X3 , mdata)
coefs <- coef(fit)
planes3d(coefs[2], coefs[3], -1, coefs[1], col="blue", alpha=0.5)

そのほかにもいろいろと問題がある
