Matrix Normal and Matrix T Distributions
Matrix normal and matrix distributions are matrix variate normal and
distributions with specified row and column scale matrices. Typical uses include time series analysis, random processes, and multivariate regression.
Given the scale matrices Σrow and Σcol, matrix normal distribution has probability density proportional to . Sample from a matrix normal distribution.
data:image/s3,"s3://crabby-images/7830c/7830c45f2135178423cf971fddac56b64dee1ea6" alt="Click for copyable input"
Subscript[\[CapitalSigma], row] = {{1, 0.9}, {0.9, 1}};
Subscript[\[CapitalSigma], col] = {{1, -0.9}, {-0.9, 1}};
data:image/s3,"s3://crabby-images/ce9a0/ce9a091d60115559f2ac989b7f2e76f6b9f18cd1" alt="Click for copyable input"
RandomVariate[
MatrixNormalDistribution[Subscript[\[CapitalSigma], row],
Subscript[\[CapitalSigma], col]]]
data:image/s3,"s3://crabby-images/5abda/5abda9525475a39056d307a79d1a6d60677496ea" alt=""
Visualize the sampled row vectors on a scatter plot and compare it with the density function.
data:image/s3,"s3://crabby-images/e9883/e98838afb3ff621d47bf97e29346dc55c872370f" alt="Click for copyable input"
sample = RandomVariate[
MatrixNormalDistribution[Subscript[\[CapitalSigma], row],
Subscript[\[CapitalSigma], col]], 10^4];
firstrows = sample[[All, 1]];
data:image/s3,"s3://crabby-images/018d3/018d3f2a415395aab54c80d331eb5f9b0ffb7951" alt=""
Visualize the sampled column vectors on a histogram and compare it with the density function.
data:image/s3,"s3://crabby-images/88956/8895673991c91b9c35862bb0885f64796181135c" alt="Click for copyable input"
firstcols = sample[[All, All, 1]];
data:image/s3,"s3://crabby-images/1bfd7/1bfd7bee6b8bd33d8cbde300a90e2b3b6be797ec" alt=""
Similar to Student and multivariate
distributions, matrix
distribution is a mixture of matrix normal distribution with inverse Wishart distributed scale parameter. Sample from a matrix
distribution.
data:image/s3,"s3://crabby-images/534e8/534e898ad774e5b1d02124e848aa93436c4a62b7" alt="Click for copyable input"
RandomVariate[
MatrixTDistribution[Subscript[\[CapitalSigma], row],
Subscript[\[CapitalSigma], col], 3]]
data:image/s3,"s3://crabby-images/df666/df666fa96aa5d5c280f2a08bd005fb9922d6a744" alt=""
Generate a set of matrix distributed matrices.
data:image/s3,"s3://crabby-images/adfb7/adfb7604de210e0bc19b371feb8477335dfacf31" alt="Click for copyable input"
sample = RandomVariate[
MatrixTDistribution[Subscript[\[CapitalSigma], row],
Subscript[\[CapitalSigma], col], 3], 10^4];
Lower-dimensional projections of matrix distributed variates are Student
and multivariate
distributed. Project the sample to two-dimensional vectors and verify the goodness of fit.
data:image/s3,"s3://crabby-images/39f74/39f74671b0e47bd7f60d3450517906e94ee84466" alt="Click for copyable input"
v = {1, 2};
vecs = sample.v;
data:image/s3,"s3://crabby-images/52164/52164367ac1c92af1072e1d010500e5cf8d3f92c" alt="Click for copyable input"
DistributionFitTest[vecs,
MultivariateTDistribution[
Subscript[\[CapitalSigma],
row] (v.Subscript[\[CapitalSigma], col].v)/3, 3]]
data:image/s3,"s3://crabby-images/a86fe/a86fe99417bc87da65401ac0079447355f3eed78" alt=""
Visualize the projected data on a scatter plot and compare it with the density function.
data:image/s3,"s3://crabby-images/09c5a/09c5a56e6493ea882cef2babf8ee8375a495e089" alt=""