vinecop | R Documentation |
Automated fitting and model selection for vine copula models with continuous or discrete data. Selection of the structure is performed using the algorithm of Dissmann et al. (2013).
vinecop( data, var_types = rep("c", NCOL(data)), family_set = "all", structure = NA, par_method = "mle", nonpar_method = "constant", mult = 1, selcrit = "aic", weights = numeric(), psi0 = 0.9, presel = TRUE, trunc_lvl = Inf, tree_crit = "tau", threshold = 0, keep_data = FALSE, show_trace = FALSE, cores = 1 )
data |
a matrix or data.frame with at least two columns, containing the (pseudo-)observations for the two variables (copula data should have approximately uniform margins). More columns are required for discrete models, see Details. |
var_types |
variable types, a length d vector; e.g., |
family_set |
a character vector of families; see |
structure |
an |
par_method |
the estimation method for parametric models, either |
nonpar_method |
the estimation method for nonparametric models, either
|
mult |
multiplier for the smoothing parameters of nonparametric families. Values larger than 1 make the estimate more smooth, values less than 1 less smooth. |
selcrit |
criterion for family selection, either |
weights |
optional vector of weights for each observation. |
psi0 |
prior probability of a non-independence copula (only used for
|
presel |
whether the family set should be thinned out according to symmetry characteristics of the data. |
trunc_lvl |
the truncation level of the vine copula; |
tree_crit |
the criterion for tree selection, one of |
threshold |
for thresholded vine copulas; |
keep_data |
whether the data should be stored (necessary for using
|
show_trace |
logical; whether a trace of the fitting progress should be printed. |
cores |
number of cores to use; if more than 1, estimation of pair copulas within a tree is done in parallel. |
If there are missing data (i.e., NA
entries), incomplete observations are
discarded before fitting a pair-copula. This is done on a pair-by-pair basis
so that the maximal available information is used.
The dependence measures used to select trees (default: Kendall's tau) are corrected for ties (see wdm::wdm).
Let n
be the number of observations and d
the number of variables.
When at least one variable is discrete, two types of
"observations" are required in data
: the first n x d
block
contains realizations of F_{X_j}(X_j). The second n x d
block contains realizations of F_{X_j}(X_j^-). The minus indicates a
left-sided limit of the cdf. For, e.g., an integer-valued variable, it holds
F_{X_j}(X_j^-) = F_{X_j}(X_j - 1). For continuous variables the left
limit and the cdf itself coincide. Respective columns can be omitted in the
second block.
It is possible to fix the vine structure only in the first trees and select
the remaining ones automatically. To specify only the first k
trees, supply
a k
-truncated rvine_structure()
or rvine_matrix()
. All trees up to
trunc_lvl
will then be selected automatically.
Objects inheriting from vinecop
and vinecop_dist
for vinecop()
. In
addition to the entries provided by vinecop_dist()
, there are:
threshold
, the (set or estimated) threshold used for thresholding the
vine.
data
(optionally, if keep_data = TRUE
was used), the dataset that was
passed to vinecop()
.
controls
, a list
with fit controls that was passed to vinecop()
.
nobs
, the number of observations that were used to fit the model.
Dissmann, J. F., E. C. Brechmann, C. Czado, and D. Kurowicka (2013). Selecting and estimating regular vine copulae and application to financial returns. Computational Statistics & Data Analysis, 59 (1), 52-69.
vinecop()
, dvinecop()
, pvinecop()
, rvinecop()
,
plot.vinecop()
, contour.vinecop()
## simulate dummy data x <- rnorm(30) * matrix(1, 30, 5) + 0.5 * matrix(rnorm(30 * 5), 30, 5) u <- pseudo_obs(x) ## fit and select the model structure, family and parameters fit <- vinecop(u) summary(fit) plot(fit) contour(fit) ## select by log-likelihood criterion from one-paramter families fit <- vinecop(u, family_set = "onepar", selcrit = "bic") summary(fit) ## Gaussian D-vine fit <- vinecop(u, structure = dvine_structure(1:5), family = "gauss") plot(fit) contour(fit) ## Partial structure selection with only first tree specified structure <- rvine_structure(order = 1:5, list(rep(5, 4))) structure fit <- vinecop(u, structure = structure, family = "gauss") plot(fit) ## 1-truncated model with random structure fit <- vinecop(u, structure = rvine_structure_sim(5), trunc_lvl = 1) contour(fit) ## Model for discrete data x <- qpois(u, 1) # transform to Poisson margins # we require two types of observations (see Details) u_disc <- cbind(ppois(x, 1), ppois(x - 1, 1)) fit <- vinecop(u_disc, var_types = rep("d", 5)) ## Model for mixed data x <- qpois(u[, 1], 1) # transform first variable to Poisson margin # we require two types of observations (see Details) u_disc <- cbind(ppois(x, 1), u[, 2:5], ppois(x - 1, 1)) fit <- vinecop(u_disc, var_types = c("d", rep("c", 4)))
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.