Quasi-Monte-Carlo algorithm for systematic generation of shock
scenarios from an arbitrary multivariate elliptical distribution. The
algorithm selects a systematic mesh of arbitrary fineness that
approximately evenly covers an isoprobability ellipsoid in d
dimensions.
 (Flood, Mark D. & Korenko, George G. “Systematic
Scenario Selection”, Office of Financial Research Working Paper #0005,
2013)
install.packages("devtools")
library(devtools)
install_github("mvk222/SyScSelection")
library(SyScSelection)Estimate the mean and covariance matrix from the data:
mu <- colMeans(data)
sig <- cov(data)
The number of dimensions, d, is taken directly from the
data:
 d <- length(data[1,])
Get the size parameter for a normal dist’n at a 95%
threshold:
calpha <- sizeparam_normal_distn(.95, d)
Create a hyperellipsoid object. Note that the constructor takes
the inverse of the disperion matrix:
hellip <- hyperellipsoid(mu, solve(sig), calpha)
Scenarios are calculated as a mesh of fineness 3. The number of
scenarios is a function of the dimensionality of the hyperellipsoid and
the fineness of the mesh:
scenarios <- hypercube_mesh(3, hellip)
Estimate the mean, covariance, and degrees of freedom from the
data:
 mu <- colMeans(data)
sig <- cov(data)
nu <- dim(data)[1] - 1
The number of dimensions, d, is taken directly from the
data:
 d <- length(data[1,])
Get the size parameter for a normal dist’n at a 95%
threshold:
calpha <- sizeparam_t_distn(.95, d, nu)
Create a hyperellipsoid object. Note that the constructor takes
the inverse of the disperion matrix:
hellip <- hyperellipsoid(mu, solve(sig), calpha)
Scenarios are calculated as a mesh of fineness 3. The number of
scenarios is a function of the dimensionality of the hyperellipsoid and
the fineness of the mesh:
scenarios <- hypercube_mesh(3, hellip)