Title: | Multivariate Dependence Modeling with Vines |
---|---|
Description: | Implementation of the vine graphical model for building high-dimensional probability distributions as a factorization of bivariate copulas and marginal density functions. This package provides S4 classes for vines (C-vines and D-vines) and methods for inference, goodness-of-fit tests, density/distribution function evaluation, and simulation. |
Authors: | Yasser Gonzalez-Fernandez [aut, cre], Marta Soto [aut], Joris Meys [ctb] |
Maintainer: | Yasser Gonzalez-Fernandez <[email protected]> |
License: | GPL (>= 2) |
Version: | 1.1.5 |
Built: | 2025-01-08 05:58:28 UTC |
Source: | https://github.com/yasserglez/vines |
The function represents the conditional distribution function of a
bivariate copula and it should be defined for every copula used in
a pair-copula construction. It is defined as the partial derivative of the
distribution function of the copula w.r.t. the second argument
.
h(copula, x, v, eps)
h(copula, x, v, eps)
copula |
A bivariate |
x |
Numeric vector with values in |
v |
Numeric vector with values in |
eps |
To avoid numerical problems for extreme values, the values of
|
signature(copula = "copula")
Default definition of the function for a bivariate copula.
This method is used if no particular definition is given for a copula.
The partial derivative is calculated numerically using the
numericDeriv
function.
signature(copula = "indepCopula")
The function of the independence copula.
signature(copula = "normalCopula")
The function of the normal copula.
signature(copula = "tCopula")
The function of the t copula.
signature(copula = "claytonCopula")
The function of the Clayton copula.
signature(copula = "gumbelCopula")
The function of the Gumbel copula.
signature(copula = "fgmCopula")
The function of the Farlie-Gumbel-Morgenstern copula.
signature(copula = "frankCopula")
The function of the Frank copula.
signature(copula = "galambosCopula")
The function of the Galambos copula.
Aas, K. and Czado, C. and Frigessi, A. and Bakken, H. (2009) Pair-copula constructions of multiple dependence. Insurance: Mathematics and Economics 44, 182–198.
Schirmacher, D. and Schirmacher, E. (2008) Multivariate dependence modeling using pair-copulas. Enterprise Risk Management Symposium, Chicago.
The function represents the inverse of the
function with
respect to its first argument. It should be defined for every copula used
in a pair-copula construction (or it will be evaluated numerically).
hinverse(copula, u, v, eps)
hinverse(copula, u, v, eps)
copula |
A bivariate |
u |
Numeric vector with values in |
v |
Numeric vector with values in |
eps |
To avoid numerical problems for extreme values, the values of
|
signature(copula = "copula")
Default definition of the function for a bivariate copula.
This method is used if no particular definition is given for a copula.
The inverse is calculated numerically using the
uniroot
function.
signature(copula = "indepCopula")
The function of the Independence copula.
signature(copula = "normalCopula")
The function of the normal copula.
signature(copula = "tCopula")
The function of the t copula.
signature(copula = "claytonCopula")
The function of the Clayton copula.
signature(copula = "frankCopula")
The function of the Frank copula.
Aas, K. and Czado, C. and Frigessi, A. and Bakken, H. (2009) Pair-copula constructions of multiple dependence. Insurance: Mathematics and Economics 44, 182–198.
Schirmacher, D. and Schirmacher, E. (2008) Multivariate dependence modeling using pair-copulas. Enterprise Risk Management Symposium, Chicago.
Extend the Vine
class to represent regular vines.
See Vine
for information about the inherited slots.
signature(object = "CVine")
:
Print a textual representation of the C-vine.
signature(object = "DVine")
:
Print a textual representation of the D-vine.
Vine
.
Functions to create Vine
objects.
Vine(type, dimension = 2, trees = dimension - 1, copulas = matrix(list(indepCopula()), dimension - 1, dimension - 1)) CVine(dimension = 2, trees = dimension - 1, copulas = matrix(list(indepCopula()), dimension - 1, dimension - 1)) DVine(dimension = 2, trees = dimension - 1, copulas = matrix(list(indepCopula()), dimension - 1, dimension - 1))
Vine(type, dimension = 2, trees = dimension - 1, copulas = matrix(list(indepCopula()), dimension - 1, dimension - 1)) CVine(dimension = 2, trees = dimension - 1, copulas = matrix(list(indepCopula()), dimension - 1, dimension - 1)) DVine(dimension = 2, trees = dimension - 1, copulas = matrix(list(indepCopula()), dimension - 1, dimension - 1))
type |
Type of vine. Supported values: |
dimension |
See the documentation of the |
trees |
See the documentation of the |
copulas |
See the documentation of the |
dimension <- 3 copulas <- matrix(list(normalCopula(0.5), claytonCopula(2.75), tCopula(0.75, df = 2), NULL), ncol = dimension - 1, nrow = dimension - 1, byrow = TRUE) Vine("DVine", dimension = dimension, trees = dimension - 1, copulas = copulas) DVine(dimension = dimension, trees = dimension - 1, copulas = copulas)
dimension <- 3 copulas <- matrix(list(normalCopula(0.5), claytonCopula(2.75), tCopula(0.75, df = 2), NULL), ncol = dimension - 1, nrow = dimension - 1, byrow = TRUE) Vine("DVine", dimension = dimension, trees = dimension - 1, copulas = copulas) DVine(dimension = dimension, trees = dimension - 1, copulas = copulas)
Base class of all classes that implement vine models in the package. It is a virtual class, no objects may be created from it.
type
:Object of class "character"
. Descriptive name of
the type of vine: Canonical vine or D-vine.
dimension
:Object of class "numeric"
. Dimension of the vine.
dimensionNames
:Object of class "character"
. Names of the
variables of the vine. It is either an empty character vector or a vector
with one element for each variable of the vine.
copulas
:Object of class "matrix"
. It contains the
copula
objects for each copula in the pair-copula
decomposition. The indexes of the matrix follow the notation used for the
subscripts of in (Aas et al., 2009).
trees
:Object of class "numeric"
. Number of dependence
trees of the vine. It should be an integer between 0
and
dimension - 1
, including both endpoints. Functions acting on
vines assume that copulas in arcs of all trees greater than trees
are independence copulas.
signature(object = "Vine")
:
Print a textual representation of the vine.
signature(x = "Vine")
:
Retrieve the names of the variables of the vine.
signature(x = "Vine")
:
Set the names of the variables of the vine.
Aas, K. and Czado, C. and Frigessi, A. and Bakken, H. (2009) Pair-copula constructions of multiple dependence. Insurance: Mathematics and Economics 44, 182–198.
Density evaluation, distribution function evaluation, and random number generation.
dvine(vine, u) pvine(vine, u) rvine(vine, n)
dvine(vine, u) pvine(vine, u) rvine(vine, n)
vine |
A |
u |
Vector of the same dimension of the vine or a matrix with one column for each variable of the vine. |
n |
Number of observations. |
The implementation of the dvine
function for CVine
and DVine
objects is based on the Algorithms 3 and 4
of (Aas et al. 2009), respectively.
The pvine
function is evaluated through the numerical integration of
the density function (using the cubature
package). This is a
computationally demanding procedure, even for small dimensions.
The implementation of the rvine
function for CVine
and DVine
objects is based on the Algorithms 1 and 2
of (Aas et al. 2009), respectively.
dnorm
returns a vector with the evaluation of the density.
pnorm
returns a vector with the evaluation of the distribution
function. rvine
returns a matrix with one column for each variable
of the vine and one row for each observation.
Aas, K. and Czado, C. and Frigessi, A. and Bakken, H. (2009) Pair-copula constructions of multiple dependence. Insurance: Mathematics and Economics 44, 182–198.
Bedford, T. and Cooke, R. M. (2001) Monte Carlo simulation of vine dependent random variables for applications in uncertainty analysis. In 2001 Proceedings of ESREL2001, Turin, Italy.
Bedford, T. and Cooke, R. M. (2001) Probability density decomposition for conditionally dependent random variables modeled by vines. Annals of Mathematics and Artificial Intelligence 32, 245–268.
Kurowicka, D. and Cooke, R. M. (2005) Sampling algorithms for generating joint uniform distributions using the vine-copula method. In 3rd IASC World Conference on Computational Statistics & Data Analysis, Limassol, Cyprus.
dimension <- 3 copulas <- matrix(list(normalCopula(0.5), claytonCopula(2.75), tCopula(0.75, df = 2), NULL), ncol = dimension - 1, nrow = dimension - 1) vine <- DVine(dimension = dimension, trees = dimension - 1, copulas = copulas) dimnames(vine) <- c("A", "B", "C") data <- rvine(vine, 1) dvine(vine, data) pvine(vine, data)
dimension <- 3 copulas <- matrix(list(normalCopula(0.5), claytonCopula(2.75), tCopula(0.75, df = 2), NULL), ncol = dimension - 1, nrow = dimension - 1) vine <- DVine(dimension = dimension, trees = dimension - 1, copulas = copulas) dimnames(vine) <- c("A", "B", "C") data <- rvine(vine, 1) dvine(vine, data) pvine(vine, data)
Estimate a vine model from multivariate data in the unit hypercube. Data can be pseudo-observations constructed from empirical or parametric marginal cumulative distribution functions.
vineFit(type, data, method = "ml", ...)
vineFit(type, data, method = "ml", ...)
type |
Type of vine. Supported values: |
data |
Data matrix of pseudo-observations. |
method |
Inference method. Supported values:
|
... |
Additional arguments for the inference method. |
The "ml"
(Maximum Likelihood) method starts with the sequential estimation
procedure described in (Aas et al., 2009) and then executes a numerical
maximization of the full log-likelihood of the vine. The sequential procedure
is used to determine the family and the initial values of the parameters of
each bivariate copula in the decomposition. Additional arguments for this
method are:
selectCopula
Function provided by the user to select the
copulas in the pair-copula construction. This function should return
a copula
object and expect the following arguments.
vine
Vine object being constructed.
j, i
Indexes of the copula under selection in the matrix of the
copulas
slot of the vine.
x, y
Bivariate sample.
The default value is function (vine, j, i, x, y) indepCopula()
that assigns the independence copula to all the arcs of the vine.
trees
Maximum number of dependence trees of the vine. Independence
copulas will be used in all the arcs of the following trees. The final number
of dependence trees could be smaller because of the use of a truncation method.
The default value is ncol(data) - 1
.
truncMethod
Method used to automatically truncate the vine if
enough dependence is captured in a given number of trees. Supported methods
are "AIC"
and "BIC"
. See (Brechmann, 2010; Brechmann et al., 2010)
for information about these methods. The default value is ""
that
means no truncation.
optimMethod
optim
method used in the optimization
of the log-likelihood function. If ""
is specified the optimization
is disabled and the vine calculated using the sequential estimation procedure
is returned. The default value is "Nelder-Mead"
.
optimControl
List of control parameters for optim
.
The default value is list()
.
A vineFit
object or a subclass with specific
information about inference method used. The vine
slot of this object
contains the fitted Vine
object.
Aas, K. and Czado, C. and Frigessi, A. and Bakken, H. (2009) Pair-copula constructions of multiple dependence. Insurance: Mathematics and Economics 44, 182–198.
Brechmann, E. C. (2010) Truncated and simplified regular vines and their applications. Diploma thesis. Technische Universitaet Muenchen.
Brechmann, E. C. and Czado, C. and Aas, K. (2010) Truncated regular vines in high dimensions with application to financial data. Norwegian Computing Center, NR. Note SAMBA/60/10.
CVine
,
DVine
,
vineFit
,
vineFitML
.
data <- matrix(runif(5 * 100), ncol = 5, nrow = 100) colnames(data) <- c("A", "B", "C", "D", "E") selectCopula <- function (vine, j, i, x, y) { data <- cbind(x, y) fit <- fitCopula(normalCopula(), data, method = "itau") fit@copula } fit <- vineFit("DVine", data, method = "ml", selectCopula = selectCopula, optimMethod = "") show(fit) show(fit@vine)
data <- matrix(runif(5 * 100), ncol = 5, nrow = 100) colnames(data) <- c("A", "B", "C", "D", "E") selectCopula <- function (vine, j, i, x, y) { data <- cbind(x, y) fit <- fitCopula(normalCopula(), data, method = "itau") fit@copula } fit <- vineFit("DVine", data, method = "ml", selectCopula = selectCopula, optimMethod = "") show(fit) show(fit@vine)
Base class of all classes providing information about vine inference.
Objects of this class (or subclasses) are created by calling the
vineFit
function.
vine
:Object of class Vine
. Fitted vine.
observations
:Object of class numeric
. Number of
observations in the sample.
method
:Object of class character
. Inference method.
signature(object = "vineFit")
:
Print the result of the vine inference.
Extends the vineFit
class to include information
about the Maximum Likelihood inference.
See vineFit
for information about inherited slots.
optimMethod
:Object of class character
.
optim
method.
optimConv
:Object of class numeric
. optim
convergence code (0 indicates successful completion).
startParams
:Object of class numeric
. Vector with the
parameters of the copulas in the pair-copula construction calculated using
the sequential estimation procedure.
finalParams
:Object of class numeric
. Vector with the
parameters of the copulas in the pair-copula construction after the
maximization of the log-likelihood.
signature(object = "vineFitML")
:
Print information about the fitted vine.
vineFit
,
vineFit
,
vineParameters
.
Goodness-of-fit tests to verify whether the dependence structure of a sample is appropriately modeled by vine model.
vineGoF(vine, data, method = "PIT", ...)
vineGoF(vine, data, method = "PIT", ...)
vine |
A |
data |
Data matrix of pseudo-observations. |
method |
Goodness-of-fit method. Supported values:
|
... |
Additional arguments for the goodness-of-fit method. |
The "PIT"
(Probability Integral Transform) method uses the
vinePIT
function to transform the data into variables which
are independent and Uniform(0,1) and then use a hypothesis
test to verify whether the resulting variables are independent and
Uniform(0,1). The additional parameter statistic
specifies
the test to be applied for this purpose.
statistic
Statistic used to verify if the transformed variables
are independent and Uniform(0,1). The default value is "Breymann"
and supported methods are:
"Breymann"
Test proposed in the Section 7.1 of (Aas et al., 2009). See (Breymann et al., 2003) for more information.
A vineGoF
or a subclass with specific information about
the goodness-of-fit method used. The statistic
slot of this object
contains the value of the statistic and pvalue
the p-value.
Aas, K. and Czado, C. and Frigessi, A. and Bakken, H. (2009) Pair-copula constructions of multiple dependence. Insurance: Mathematics and Economics 44, 182–198.
Breymann, W. and Dias, A. and Embrechts, P. (2003) Dependence structures for multivariate high-frequency data in finance. Quantitative Finance 1, 1–14.
copula <- normalCopula(c(-0.25, -0.21, 0.34, 0.51, -0.07, -0.18), dispstr = "un", dim = 4) data <- rCopula(100, copula) selectCopula <- function (vine, j, i, x, y) { data <- cbind(x, y) fit <- fitCopula(normalCopula(), data, method = "itau") fit@copula } normalCVine <- vineFit("CVine", data, method = "ml", selectCopula = selectCopula, optimMethod = "")@vine normalDVine <- vineFit("DVine", data, method = "ml", selectCopula = selectCopula, optimMethod = "")@vine show(normalCVine) show(normalDVine) normalCVineGof <- vineGoF(normalCVine, data, method = "PIT", statistic = "Breymann") normalDVineGof <- vineGoF(normalDVine, data, method = "PIT", statistic = "Breymann") show(normalCVineGof) show(normalDVineGof)
copula <- normalCopula(c(-0.25, -0.21, 0.34, 0.51, -0.07, -0.18), dispstr = "un", dim = 4) data <- rCopula(100, copula) selectCopula <- function (vine, j, i, x, y) { data <- cbind(x, y) fit <- fitCopula(normalCopula(), data, method = "itau") fit@copula } normalCVine <- vineFit("CVine", data, method = "ml", selectCopula = selectCopula, optimMethod = "")@vine normalDVine <- vineFit("DVine", data, method = "ml", selectCopula = selectCopula, optimMethod = "")@vine show(normalCVine) show(normalDVine) normalCVineGof <- vineGoF(normalCVine, data, method = "PIT", statistic = "Breymann") normalDVineGof <- vineGoF(normalDVine, data, method = "PIT", statistic = "Breymann") show(normalCVineGof) show(normalDVineGof)
Base class of all classes containing information about vine goodness-of-fit
tests. Objects of this class (or subclasses) are created by calling the
vineGoF
function.
method
:Object of class character
.
Goodness-of-fit method.
statistic
:Object of class numeric
.
Value of the test statistic.
pvalue
:Object of class numeric
. P-value.
signature(object = "vineGoF")
:
Print the result of the goodness-of-fit test.
Evaluate the log-likelihood of a Vine
.
vineLogLik(vine, data)
vineLogLik(vine, data)
vine |
A |
data |
Data matrix of pseudo-observations. |
dimension <- 3 copulas <- matrix(list(normalCopula(0.5), claytonCopula(2.75), NULL, NULL), ncol = dimension - 1, nrow = dimension - 1, byrow = TRUE) vine <- DVine(dimension = dimension, trees = 1, copulas = copulas) data <- matrix(runif(dimension * 100), ncol = dimension, nrow = 100) vineLogLik(vine, data)
dimension <- 3 copulas <- matrix(list(normalCopula(0.5), claytonCopula(2.75), NULL, NULL), ncol = dimension - 1, nrow = dimension - 1, byrow = TRUE) vine <- DVine(dimension = dimension, trees = 1, copulas = copulas) data <- matrix(runif(dimension * 100), ncol = dimension, nrow = 100) vineLogLik(vine, data)
Select an order of the variables. The order of the variables determines the bivariate dependencies that will be explicit modeled in the first tree of the vine.
vineOrder(type, data, method = "greedy", ...)
vineOrder(type, data, method = "greedy", ...)
type |
Type of vine. Supported values: |
data |
Data matrix of pseudo-observations. |
method |
Ordering method. Supported values: |
... |
Additional arguments for the order method. |
In D-vines, the order of the variables determines the structure of all the trees of the vine. This is not the case for C-vines where the root node of each tree can be selected.
The "random"
method returns a random permutation of the variables.
The "greedy"
method returns an order of the variables that intends to
capture as much dependence as possible in the first tree of the vine. The
method finds the order of the variables that defines a tree that maximizes
a given dependence measure used as edge weights. For C-vines, it is determined
iteratively checking each variable as root node. For D-vines, it is equivalent
to solve the traveling salesman problem (TSP), see (Brechmann, 2010)
for details. The TSP is solved using the cheapest insertion algorithm
implemented by the solve_TSP
function of the TSP package.
The following are additional parameters for this method.
according
Dependence measure. The default value is
"kendall"
and supported values are:
"kendall"
Absolute value of Kendall's .
"spearman"
Absolute value of Spearman's .
"pearson"
Absolute value of Pearson's product moment correlation coefficient.
"df"
Smaller degrees of freedom of a bivariate t copula.
A vector with the ordered indexes of the variables. This vector should be
used to reorder the variables of the data
matrix.
Brechmann, E. C. (2010) Truncated and simplified regular vines and their applications. Diploma thesis. Technische Universitaet Muenchen.
data <- matrix(runif(5 * 100), ncol = 5, nrow = 500) vineOrder("CVine", data, method = "random") vineOrder("DVine", data, method = "greedy", according = "spearman")
data <- matrix(runif(5 * 100), ncol = 5, nrow = 500) vineOrder("CVine", data, method = "random") vineOrder("DVine", data, method = "greedy", according = "spearman")
Retrieve or set the parameters of a Vine
.
vineParameters(vine) vineParameters(vine) <- value
vineParameters(vine) vineParameters(vine) <- value
vine |
A |
value |
Vector with the parameters of the copulas in the pair-copula
construction. This vector is the result of the concatenation of the
|
dimension <- 5 copulas <- matrix(c(list(tCopula(-0.25, df = 2), tCopula(-0.5, df = 4), tCopula(0.25, df = 6), tCopula(0.5, df = 8)), rep(list(NULL), 12)), ncol = dimension - 1, nrow = dimension - 1, byrow = TRUE) vine <- DVine(dimension = dimension, trees = 1, copulas = copulas) dimnames(vine) <- c("A", "B", "C", "D", "E") vineParameters(vine) show(vine) vineParameters(vine) <- c(-0.25, 3, -0.5, 5, 0.25, 7, 0.5, 9) vineParameters(vine) show(vine)
dimension <- 5 copulas <- matrix(c(list(tCopula(-0.25, df = 2), tCopula(-0.5, df = 4), tCopula(0.25, df = 6), tCopula(0.5, df = 8)), rep(list(NULL), 12)), ncol = dimension - 1, nrow = dimension - 1, byrow = TRUE) vine <- DVine(dimension = dimension, trees = 1, copulas = copulas) dimnames(vine) <- c("A", "B", "C", "D", "E") vineParameters(vine) show(vine) vineParameters(vine) <- c(-0.25, 3, -0.5, 5, 0.25, 7, 0.5, 9) vineParameters(vine) show(vine)
Probability integral transform (PIT) of (Rosenblatt, 1952) for vine models.
The PIT converts a set of dependent variables into a new set of variables
which are independent and uniformly distributed in under the
hypothesis that the data follows a given multivariate distribution.
vinePIT(vine, u)
vinePIT(vine, u)
vine |
A |
u |
Vector with one component for each variable of the vine or a matrix with one column for each variable of the vine. |
A matrix with one column for each variable of the vine and one row for each observation.
signature(vine = "CVine")
PIT algorithm for
CVine
objects based on the Algorithm 5 of
(Aas et al., 2009).
signature(vine = "DVine")
PIT algorithm for
DVine
objects based on the Algorithm 6 of
(Aas et al., 2009).
Aas, K. and Czado, C. and Frigessi, A. and Bakken, H. (2009) Pair-copula constructions of multiple dependence. Insurance: Mathematics and Economics 44, 182–198.
Rosenblatt, M. (1952) Remarks on multivariate transformation. Annals of Mathematical Statistics 23, 1052–1057.
dimension <- 3 copulas <- matrix(list(normalCopula(0.5), claytonCopula(2.75), NULL, NULL), ncol = dimension - 1, nrow = dimension - 1, byrow = TRUE) vine <- CVine(dimension = dimension, trees = 1, copulas = copulas) data <- matrix(runif(dimension * 100), ncol = dimension, nrow = 100) vinePIT(vine, data)
dimension <- 3 copulas <- matrix(list(normalCopula(0.5), claytonCopula(2.75), NULL, NULL), ncol = dimension - 1, nrow = dimension - 1, byrow = TRUE) vine <- CVine(dimension = dimension, trees = 1, copulas = copulas) data <- matrix(runif(dimension * 100), ncol = dimension, nrow = 100) vinePIT(vine, data)