次の行列のランダム分布が異なるプロットを生成する理由を知っている人はいますか? (これは、逆ウィシャート分布を使用してサンプリングされた 10x10 行列のセットから最初のセルの PDF のプロットを生成するコードです。驚くべきことに、逆行列を実行する方法によってプロットが異なります。正しいプロットはInverse[_] によって取得されるのはなぜですか?)
ベースコード:
<< MultivariateStatistics`;
Module[{dist, p, k, data, samples, scale, graphics, distribution},
p = 10;
k = 13;
samples = 500;
dist = WishartDistribution[IdentityMatrix[p], k];
(* a samples x p x p array *)
data = Inverse[#] & /@ RandomVariate[dist, samples];
(* distribution graphics *)
distribution[i_, j_] := Module[{fiber, f, mean, rangeAll, colorHue},
fiber = data[[All, i, j]];
dist = SmoothKernelDistribution[fiber];
f = PDF[dist];
Plot[f[z], {z, -2, 2},
PlotLabel -> ("Mean=" <> ToString[Mean[fiber]]),
PlotRange -> All]
];
Grid @ Table[distribution[i, j], {i, 1, 3}, {j, 1, 5}]
]
コードバリアント: 上記、行を変更
data = Inverse[#] & /@ RandomVariate[dist, samples];
これで
data = #^(-1) & /@ RandomVariate[dist, samples];
プロットされた分布が異なることがわかります。