public class MultinormalPCAGen extends MultinormalGen
MultinormalGen for a multivariate normal distribution, generated via the method of principal components analysis
(PCA) of the covariance matrix. The covariance matrix
Σ is
decomposed (by the constructor) as
Σ = VΛVt where
V is an orthogonal matrix and
Λ is the diagonal matrix made up
of the eigenvalues of
Σ. Vt is the transpose
matrix of V. The eigenvalues are ordered from the
largest (λ1) to the smallest (λd). The random multinormal
vector
X is generated via
| Constructor and Description |
|---|
MultinormalPCAGen(NormalGen gen1,
double[] mu,
double[][] sigma)
Equivalent to
MultinormalPCAGen(gen1, mu, new DenseDoubleMatrix2D(sigma)). |
MultinormalPCAGen(NormalGen gen1,
double[] mu,
DoubleMatrix2D sigma)
Constructs a multinormal generator with mean vector mu
and covariance matrix sigma.
|
| Modifier and Type | Method and Description |
|---|---|
static DoubleMatrix2D |
decompPCA(double[][] sigma)
Computes the decomposition sigma =
Σ = VΛVt.
|
static DoubleMatrix2D |
decompPCA(DoubleMatrix2D sigma)
Computes the decomposition sigma =
Σ = VΛVt.
|
double[] |
getLambda()
Returns the eigenvalues of
Σ in decreasing order.
|
static double[] |
getLambda(DoubleMatrix2D sigma)
Computes and returns the eigenvalues of sigma in
decreasing order.
|
DoubleMatrix2D |
getPCADecompSigma()
Returns the matrix
A = V()1/2 of this object.
|
void |
nextPoint(double[] p)
Generates a point from this multinormal distribution.
|
static void |
nextPoint(NormalGen gen1,
double[] mu,
DoubleMatrix2D sigma,
double[] p)
Generates a d-dimensional vector from the multinormal
distribution with mean vector mu and covariance matrix
sigma, using the one-dimensional normal generator gen1 to
generate the coordinates of
Z, and using the PCA decomposition of
Σ.
|
void |
setSigma(DoubleMatrix2D sigma)
Sets the covariance matrix
Σ of this multinormal generator
to sigma (and recomputes
A).
|
getMu, getMu, getSigma, setMu, setMugetDimension, getStream, nextArrayOfPoints, setStreampublic MultinormalPCAGen(NormalGen gen1, double[] mu, double[][] sigma)
MultinormalPCAGen(gen1, mu, new DenseDoubleMatrix2D(sigma)).public MultinormalPCAGen(NormalGen gen1, double[] mu, DoubleMatrix2D sigma)
gen1 - the one-dimensional generatormu - the mean vector.sigma - the covariance matrix.java.lang.NullPointerException - if any argument is null.java.lang.IllegalArgumentException - if the length of the mean
vector is incompatible with the dimensions of the covariance matrix.public static DoubleMatrix2D decompPCA(double[][] sigma)
public static DoubleMatrix2D decompPCA(DoubleMatrix2D sigma)
public DoubleMatrix2D getPCADecompSigma()
public static double[] getLambda(DoubleMatrix2D sigma)
public double[] getLambda()
public void setSigma(DoubleMatrix2D sigma)
sigma - the new covariance matrix.java.lang.IllegalArgumentException - if sigma has
incorrect dimensions.public static void nextPoint(NormalGen gen1, double[] mu, DoubleMatrix2D sigma, double[] p)
p - the array to be filled with the generated point.java.lang.IllegalArgumentException - if the one-dimensional normal
generator uses a normal distribution with μ not equal to 0, or
σ not equal to 1.java.lang.IllegalArgumentException - if the length of the mean
vector is different from the dimensions of the covariance matrix,
or if the covariance matrix is not symmetric and positive-definite.java.lang.NullPointerException - if any argument is null.public void nextPoint(double[] p)
nextPoint in class MultinormalGenp - the array to be filled with the generated pointTo submit a bug or ask questions, send an e-mail to Pierre L'Ecuyer.