Learn R Programming

copula (version 0.999-15)

estim.misc: Various Estimators for (Nested) Archimedean Copulas

Description

Various Estimators for (Nested) Archimedean Copulas, namely,

Usage

ebeta(u, cop, interval = initOpt(cop@copula@name), ...) edmle(u, cop, interval = initOpt(cop@copula@name), warn=TRUE, ...) etau(u, cop, method = c("tau.mean", "theta.mean"), warn=TRUE, ...)

Arguments

u
$n x d$-matrix of (pseudo-)observations (each value in $[0,1]$) from the copula, where $n$ denotes the sample size and $d$ the dimension.
cop
outer_nacopula to be estimated (currently only Archimedean copulas are provided).
interval
bivariate vector denoting the interval where optimization takes place. The default is computed as described in Hofert et al. (2013).
method
a character string specifying the method (only for etau), which has to be one (or a unique abbreviation) of

warn
logical indicating if warnings are printed:

...
additional arguments passed to cor (for etau, but see ‘Details’), to optimize (for edmle), or to safeUroot (for ebeta).

Value

Details

For ebeta, the parameter is estimated with a method-of-moments-like procedure such that the population version of the multivariate Blomqvist's beta matches its sample version.

Note that the copula diagonal is a distribution function and the maximum of all components of a random vector following the copula is distributed according to this distribution function. For edmle, the parameter is estimated via maximum-likelihood estimation based on the diagonal.

For etau, if no additional arguments are provided to cor(*, method="kendall") (see ...), the much faster cor.fk() from package \href{https://CRAN.R-project.org/package=#1}{\pkg{#1}}pcaPPpcaPP is used. Furthermore, method="tau.mean" means that the average of sample versions of Kendall's tau are computed first and then the parameter is determined such that the population version of Kendall's tau matches this average (if possible); the method="theta.mean" stands for first computing all pairwise Kendall's tau estimators and then returning the mean of these estimators.

For more details, see Hofert et al. (2013).

Note that these estimators should be used with care; see the performance results in Hofert et al. (2013). In particular, etau should be used with the (default) method "tau.mean" since "theta.mean" is both slower and more prone to errors.

References

Hofert, M., Mächler, M., and McNeil, A. J. (2013). Archimedean Copulas in High Dimensions: Estimators and Numerical Challenges Motivated by Financial Applications. Journal de la Société Française de Statistique 154(1), 25--63.

See Also

The more sophisticated estimators emle (Maximum Likelihood) and emde (Minimum Distance). enacopula (wrapper for different estimators).

Examples

Run this code
tau <- 0.25
(theta <- copGumbel@iTau(tau)) # 4/3
d <- 20
(cop <- onacopulaL("Gumbel", list(theta,1:d)))

set.seed(1)
n <- 200
U <- rnacopula(n, cop)

system.time(theta.hat.beta <- ebeta(U, cop=cop))
theta.hat.beta$root

system.time(theta.hat.dmle <- edmle(U, cop=cop))
theta.hat.dmle$minimum

system.time(theta.hat.etau <- etau(U, cop=cop, method="tau.mean"))
theta.hat.etau

system.time(theta.hat.etau. <- etau(U, cop=cop, method="theta.mean"))
theta.hat.etau.

Run the code above in your browser using DataLab