Learn R Programming

copBasic (version 2.2.7)

copBasic-package: Basic Theoretical Copula, Empirical Copula, and Various Utility Functions

Description

The copBasic package is oriented around bivariate copula theory and mathematical operations closely follow the recommended texts of Nelsen (2006) and Joe (2014) as well as select other references. Another recommended text is Salvadori et al. (2007) and Hofert et al. (2018) and are cited herein, but about half of that excellent book concerns univariate applications. The primal objective of copBasic is to provide a study of numerous results shown by authoritative texts on copulas. It is intended that the package will help other copula students in self study, potential course work, and applied circumstances.

Notes on copulas that are supported. The author has focused on pedagogical aspects of copulas, and this package is a diary of sorts beginning in fall 2008. Originally, the author did not implement many copulas in the copBasic in order to deliberately avoid redundancy to that support such as it exists on the R CRAN. Though as time has progressed, other copulas have been added occasionally based on needs of the user community, need to show some specific concept in the general theory, or test algorithms. For example, the Clayton copula (CLcop) was a late arriving addition the package (c.2017), which was added to assist a specific user; the Frank copula (FRcop was added in December 2024 because of an inquiry on using copBasic for vine copula (see vine example under FRcop).

The language and vocabulary of copulas are formidable even within the realm of bivariate or bicopula as design basis for the package. Often “vocabulary” words are often emphasized in italics, which is used extensively and usually near the opening of function-by-function documentation to identify vocabulary words, such as survival copula (see surCOP). This syntax tries to mimic and accentuate the terminology in Nelsen (2006), Joe (2014), and generally most other texts. Italics are used to draw connections between concepts.

In conjunction with the summary of functions in copBasic-package, the extensive cross referencing to functions and expansive keyword indexing should be beneficial. The author had no experience with copulas prior to a chance happening upon Nelsen (2006) in c.2008. The copBasic package is a personal tour de force in self-guided learning. Over time, this package and user's manual have been helpful to others.

Helpful Navigation of Copulas Implemented in the copBasic Package

Some entry points to the copulas implemented are listed in the Table of Copulas:

NameSymbolFunctionConcept
Lower-bounds copula\(\mathbf{W}(u,v)\)Wcopula
Independence copula\(\mathbf{\Pi}(u,v)\)Pcopula
Upper-bounds copula\(\mathbf{M}(u,v)\)Mcopula
Fréchet Family copula\(\mathbf{FF}(u,v)\)FRECHETcopcopula
Ali--Mikhail--Haq copula\(\mathbf{AMH}(u,v)\)AMHcopcopula
Clayton copula\(\mathbf{CL}(u,v)\)CLcopcopula
Copula of uniform circle\(\mathbf{CIRC}(u,v)\)CIRCcopcopula
Farlie--Gumbel--Morgenstern (generalized)\(\mathbf{FGM}(u,v)\)FGMcopcopula
Frank\(\mathbf{FR}(u,v)\)FRcopcopula
Galambos copula\(\mathbf{GL}(u,v)\)GLcopcopula
Gumbel--Hougaard copula\(\mathbf{GH}(u,v)\)GHcopcopula
Hüsler--Reiss copula\(\mathbf{HR}(u,v)\)HRcopcopula
Joe B5 (the “Joe”) copula\(\mathbf{B5}(u,v)\)JOcopB5copula
Nelsen eq.4-2-12 copula\(\mathbf{N4212cop}(u,v)\)N4212copcopula
Ordinal Sums by Copula\(\mathbf{C}_\mathcal{J}(u,v)\)ORDSUMcopcopula
Pareto copula\(\mathbf{PA}(u,v)\)PLcopcopula
Plackett copula\(\mathbf{PL}(u,v)\)PLcopcopula
PSP copula\(\mathbf{PSP}(u,v)\)PSPcopula
Raftery copula\(\mathbf{RF}(u,v)\)RFcopcopula
Rayleigh copula\(\mathbf{RAY}(u,v)\)RAYcopcopula
g-EV copula (Gaussian extreme value)\(\mathbf{gEV}(u,v)\)gEVcopcopula
t-EV copula (t-distribution extreme value)\(\mathbf{tEV}(u,v)\)tEVcopcopula

A few comments on notation herein are needed. A bold math typeface is used to represent a copula function or family such as \(\mathbf{\Pi}\) (see P) for the independence copula. The syntax \(\mathcal{R}\times\mathcal{R} \equiv \mathcal{R}^2\) denotes the orthogonal domain of two real numbers, and \([0,1]\times [0,1]\) \(\equiv\) \(\mathcal{I}\times\mathcal{I} \equiv \mathcal{I}^2\) denotes the orthogonal domain on the unit square of probabilities. Limits of integration \([0,1]\) or \([0,1]^2\) involving copulas are thus shown as \(\mathcal{I}\) and \(\mathcal{I}^2\), respectively.

Random variables \(X\) and \(Y\) respectively denote the horizontal and vertical directions in \(\mathcal{R}^2\). Their probabilistic counterparts are uniformly distributed random variables on \([0,1]\), are respectively denoted as \(U\) and \(V\), and necessarily also are the respective directions in \(\mathcal{I}^2\) (\(U\) denotes the horizontal, \(V\) denotes the vertical). Often realizations of these random variables are respectively \(x\) and \(y\) for \(X\) and \(Y\) and \(u\) and \(v\) for \(U\) and \(V\).

There is an obvious difference between nonexceedance probability \(F\) and its complement, which is exceedance probability defined as \(1-F\). Both \(u\) and \(v\) herein are in nonexceedance probability. Arguments to many functions herein are u \(= u\) and v \(= v\) and are almost exclusively nonexceedance but there are instances for which the probability arguments are u \(= 1 - u = u'\) and v \(= 1 - v = v'\).

Several of the functions listed above are measures of “bivariate association.” Two of the measures (Kendall Tau, tauCOP; Spearman Rho, rhoCOP) are widely known. R provides native support for their sample estimation of course, but each function can be used to call the cor() function in R for parallelism to the other measures of this package. The other measures (Blomqvist Beta, Gini Gamma, Hoeffding Phi, Schweizer--Wolff Sigma, Spearman Footrule) support sample estimation by specially formed calls to their respective functions: blomCOP, giniCOP, hoefCOP, wolfCOP, and footCOP. Gini Gamma (giniCOP) documentation (also joeskewCOP) shows extensive use of theoretical and sample computations for these and other functions.

Helpful Navigation of the copBasic Package

Some other entry points into the package are listed in the following table:

NameSymbolFunctionConcept
Copula\(\mathbf{C}(u,v)\)COPcopula theory
\(\cdots\)\(\mathbf{C}(u,v)\)COP(..., reflect=*)reflection
\(\cdots\)\(\mathbf{C}(u,v)\)COP(..., reflect=*)rotation
Survival copula\(\hat{\mathbf{C}}(u',v')\)surCOPcopula theory
Joint survival function\(\overline{\mathbf{C}}(u,v)\)surfuncCOPcopula theory
Co-copula\(\mathbf{C}^\star(u',v')\)coCOPcopula theory
Dual of a copula\(\tilde{\mathbf{C}}(u,v)\)duCOPcopula theory
Primary copula diagonal\(\delta(t)\)diagCOPcopula theory
Secondary copula diagonal\(\delta^\star(t)\)diagCOPcopula theory
Inverse copula diagonal\(\delta^{(-1)}(f)\)diagCOPatfcopula theory
Joint probability\({-}{-}\)jointCOPcopula theory
Bivariate L-moments\(\delta^{[\ldots]}_{k;\mathbf{C}}\)bilmoms and lcomCOPbivariate moments
Bivariate L-comoments\(\tau^{[\ldots]}_{k;\mathbf{C}}\)bilmoms and lcomCOPbivariate moments
Blomqvist Beta\(\beta_\mathbf{C}\)blomCOPbivariate association
Gini Gamma\(\gamma_\mathbf{C}\)giniCOPbivariate association
Hoeffding Phi\(\Phi_\mathbf{C}\)hoefCOPbivariate association
Nu-Skew\(\nu_\mathbf{C}\)nuskewCOPbivariate moments
Nu-Star (skew)\(\nu^\star_\mathbf{C}\)nustarCOPbivariate moments
Lp distance to independence\(\Phi_\mathbf{C} \rightarrow L_p\)LpCOPbivariate association
Permutation-Mu\(\mu_{\infty\mathbf{C}}^\mathrm{permsym}\)LzCOPpermsympermutation asymmetry
Kendall Tau\(\tau_\mathbf{C}\)tauCOPbivariate association
Kendall Measure\(K_\mathbf{C}(z)\)kmeasCOPcopula theory
Kendall Function\(F_K(z)\)kfuncCOPcopula theory
Inverse Kendall Function\(F_K^{(-1)}(z)\)kfuncCOPinvcopula theory
An L-moment of \(F_K(z)\)\(\lambda_r(F_K)\)kfuncCOPlmomL-moment theory
L-moments of \(F_K(z)\)\(\lambda_r(F_K)\)kfuncCOPlmomsL-moment theory
Semi-correlations (negatives)\(\rho_N^{-}(a)\)semicorCOPbivariate tail association
Semi-correlations (positives)\(\rho_N^{+}(a)\)semicorCOPbivariate tail association
Spearman Footrule\(\psi_\mathbf{C}\)footCOPbivariate association
Spearman Rho\(\rho_\mathbf{C}\)rhoCOPbivariate association
Schweizer--Wolff Sigma\(\sigma_\mathbf{C}\)wolfCOPbivariate association
Density of a copula\(c(u,v)\)densityCOPcopula density
Density visualization\({-}{-}\)densityCOPplotcopula density
Empirical copula\(\mathbf{C}_n(u,v)\)EMPIRcopcopula
Empirical simulation\({-}{-}\)EMPIRsimcopula simulation
Empirical simulation\({-}{-}\)EMPIRsimvcopula simulation
Empirical copulatic surface\({-}{-}\)EMPIRgridcopulatic surface
Parametric copulatic surface\({-}{-}\)gridCOPcopulatic surface
Parametric simulation\({-}{-}\)simCOP or rCOPcopula simulation
Parametric simulation\({-}{-}\)simCOPmicrocopula simulation
Maximum likelihood\(\mathcal{L}(\Theta_d)\)mleCOPcopula fitting
Akaike information criterion\(\mathrm{AIC}_\mathbf{C}\)aicCOPgoodness-of-fit
Bayesian information criterion\(\mathrm{BIC}_\mathbf{C}\)bicCOPgoodness-of-fit
Root mean square error\(\mathrm{RMSE}_\mathbf{C}\)rmseCOPgoodness-of-fit
Another goodness-of-fit\(T_n\)statTngoodness-of-fit

Concerning goodness-of-fit and although not quite the same as copula properties (such as “correlation”) per se as the coefficients aforementioned in the prior paragraph, three goodness-of-fit metrics of a copula compared to the empirical copula, which are all based the mean square error (MSE), are aicCOP, bicCOP, and rmseCOP. This triad of functions is useful for making decisions on whether a copula is more favorable than another to a given dataset. However, because they are genetically related by using MSE and if these are used for copula fitting by minimization, the fits will be identical. A statement of “not quite the same” is made because the previously described copula properties are generally defined as types of deviations from other copulas (such as P). Another goodness-of-fit statistic is statTn, which is based on magnitude summation of fitted copula difference from the empirical copula. These four (aicCOP, bicCOP, rmseCOP, and statTn) collectively are relative simple and readily understood measures. These bulk sample statistics are useful, but generally thought to not capture the nuances of tail behavior (semicorCOP and taildepCOP might be useful).

Bivariate skewness measures are supported in the functions joeskewCOP (nuskewCOP and nustarCOP) and uvlmoms (uvskew). Extensive discussion and example computations of bivariate skewness are provided in the joeskewCOP documentation. Lastly, so-called bivariate L-moments and bivariate L-comoments of a copula are directly computable in bilmoms (though that function using Monte Carlo integration is deprecated) and lcomCOP (direct numerical integration). The lcomCOP function is the theoretical counterpart to the sample L-comoments provided in the lmomco package.

Bivariate random simulation methods by several functions are identified in the previous table. The copBasic package explicitly uses only conditional simulation also known as the conditional distribution method for random variate generation following Nelsen (2006, pp. 40--41) (see also simCOPmicro, simCOP). The numerical derivatives (derCOP and derCOP2) and their inversions (derCOPinv and derCOPinv2) represent the foundation of the conditional simulation. There are other methods in the literature and available in other R packages, and a comparison of some methods is made in the Examples section of the Gumbel--Hougaard copula (GHcop).

Several functions in copBasic make the distinction between \(V\) with respect to (wrt) \(U\) and \(U\) wrt \(V\), and a guide for the nomenclature involving wrt distinctions is listed in the following table:

NameSymbolFunctionConcept
Copula inversion\(V\) wrt \(U\)COPinvcopula operator
Copula inversion\(U\) wrt \(V\)COPinv2copula operator
Copula derivative\(\delta \mathbf{C}/\delta u\)derCOPcopula operator
Copula derivative\(\delta \mathbf{C}/\delta v\)derCOP2copula operator
Copula derivative inversion\(V\) wrt \(U\)derCOPinvcopula operator
Copula derivative inversion\(U\) wrt \(V\)derCOPinv2copula operator
Joint curves\(t \mapsto \mathbf{C}(u=U, v)\)joint.curvesCOPcopula theory
Joint curves\(t \mapsto \mathbf{C}(u, v=V)\)joint.curvesCOP2copula theory
Level curves\(t \mapsto \mathbf{C}(u=U, v)\)level.curvesCOPcopula theory
Level curves\(t \mapsto \mathbf{C}(u, v=V)\)level.curvesCOP2copula theory
Level set\(V\) wrt \(U\)level.setCOPcopula theory
Level set\(U\) wrt \(V\)level.setCOP2copula theory
Median regression\(V\) wrt \(U\)med.regressCOPcopula theory
Median regression\(U\) wrt \(V\)med.regressCOP2copula theory
Quantile regression\(V\) wrt \(U\)qua.regressCOPcopula theory
Quantile regression\(U\) wrt \(V\)qua.regressCOP2copula theory
Copula section\(t \mapsto \mathbf{C}(t,a)\)sectionCOPcopula theory
Copula section\(t \mapsto \mathbf{C}(a,t)\)sectionCOPcopula theory

The previous two tables do not include all of the myriad of special functions to support similar operations on empirical copulas. All empirical copula operators and utilities are prepended with EMPIR in the function name. An additional note concerning package nomenclature is that an appended “2” to a function name indicates \(U\) wrt \(V\) (e.g. EMPIRgridderinv2 for an inversion of the partial derivatives \(\delta \mathbf{C}/\delta v\) across the grid of the empirical copula).

Some additional functions to compute often salient features or characteristics of copulas or bivariate data, including functions for bivariate inference or goodness-of-fit, are listed in the following table:

NameSymbolFunctionConcept
Left-tail decreasing\(V\) wrt \(U\)isCOP.LTDbivariate association
Left-tail decreasing\(U\) wrt \(V\)isCOP.LTDbivariate association
Right-tail increasing\(V\) wrt \(U\)isCOP.RTIbivariate association
Right-tail increasing\(U\) wrt \(V\)isCOP.RTIbivariate association
Pseudo-polar representation\((\widehat{S},\widehat{W})\)psepolarextremal dependency
Tail concentration function\(q_\mathbf{C}(t)\)tailconCOPbivariate tail association
Tail (lower) dependency\(\lambda^L_\mathbf{C}\)taildepCOPbivariate tail association
Tail (upper) dependency\(\lambda^U_\mathbf{C}\)taildepCOPbivariate tail association
Tail (lower) order\(\kappa^L_\mathbf{C}\)tailordCOPbivariate tail association
Tail (upper) order\(\kappa^U_\mathbf{C}\)tailordCOPbivariate tail association
Neg'ly quadrant dependencyNQDisCOP.PQDbivariate association
Pos'ly quadrant dependencyPQDisCOP.PQDbivariate association
Permutation symmetry\(\mathrm{permsym}\)isCOP.permsymcopula symmetry
Radial symmetry\(\mathrm{radsym}\)isCOP.radsymcopula symmetry
Skewness (Joe, 2014)\(\eta(p; \psi)\)uvskewbivariate skewness
Kullback--Leibler Divergence\(\mathrm{KL}(f \mid g)\)kullCOPbivariate inference
KL sample size\(n_{f\!g}\)kullCOPbivariate inference
The Vuong Procedure\({-}{-}\)vuongCOPbivariate inference
Spectral measure\(H(w)\)spectralmeasextremal dependency inference
Stable tail dependence\(\widehat{l}(x,y)\)stabtaildepfextremal dependency inference
L-comoments (samp. distr.)\({-}{-}\)lcomCOPpvexperimental bivariate inference

The Table of Probabilities that follows lists important relations between various joint probability concepts, the copula, nonexceedance probabilities \(u\) and \(v\), and exceedance probabilities \(u'\) and \(v'\). A compact summary of these probability relations has obvious usefulness. The notation \([\ldots, \ldots]\) is to read as \([\ldots \mathrm{\ and\ } \ldots]\), and the \([\ldots \mid \ldots]\) is to be read as \([\ldots \mathrm{\ given\ } \ldots]\).

ProbabilityandSymbol Convention
\(\mathrm{Pr}[\,U \le u, V \le v\,]\)\(=\)\(\mathbf{C}(u,v)\) --- The copula, COP
\(\mathrm{Pr}[\,U > u, V > v\,]\)\(=\)\(\hat{\mathbf{C}}(u',v')\) --- The survival copula, surCOP
\(\mathrm{Pr}[\,U \le u, V > v\,]\)\(=\)\(u - \mathbf{C}(u,v')\)
\(\mathrm{Pr}[\,U > u, V \le v\,]\)\(=\)\(v - \mathbf{C}(u',v)\)
\(\mathrm{Pr}[\,U \le u \mid V \le v\,]\)\(=\)\(\mathbf{C}(u,v)/v\)
\(\mathrm{Pr}[\,V \le v \mid U \le u\,]\)\(=\)\(\mathbf{C}(u,v)/u\)
\(\mathrm{Pr}[\,U \le u \mid V > v\,]\)\(=\)\(\bigl(u - \mathbf{C}(u,v)\bigr)/(1 - v)\)
\(\mathrm{Pr}[\,V \le v \mid U > u\,]\)\(=\)\(\bigl(v - \mathbf{C}(u,v)\bigr)/(1 - u)\)
\(\mathrm{Pr}[\,U > u \mid V > v\,]\)\(=\)\(\hat{\mathbf{C}}(u',v')/u' = \overline{\mathbf{C}}(u,v)/(1-u)\)
\(\mathrm{Pr}[\,V > v \mid U > u\,]\)\(=\)\(\hat{\mathbf{C}}(u',v')/v' = \overline{\mathbf{C}}(u,v)/(1-v)\)
\(\mathrm{Pr}[\,V \le v \mid U = u\,]\)\(=\)\(\delta \mathbf{C}(u,v)/\delta u\) --- Partial derivative, derCOP
\(\mathrm{Pr}[\,U \le u \mid V = v\,]\)\(=\)\(\delta \mathbf{C}(u,v)/\delta v\) --- Partial derivative, derCOP2
\(\mathrm{Pr}[\,U > u \mathrm{\ or\ } V > v\,]\)\(=\)\(\mathbf{C}^\star(u',v') = 1 - \mathbf{C}(u',v')\) --- The co-copula, coCOP
\(\mathrm{Pr}[\,U \le u \mathrm{\ or\ } V \le v\,]\)\(=\)\(\tilde{\mathbf{C}}(u,v) = u + v - \mathbf{C}(u,v)\) --- The dual of a copula, duCOP
\(E[\,U \mid V = v\,]\)\(=\)\(\int_0^1 (1 - \delta \mathbf{C}(u,v)/\delta v)\,\mathrm{d}u\) --- Expectation of U given V, EuvCOP
\(E[\,V \mid U = u\,]\)\(=\)\(\int_0^1 (1 - \delta \mathbf{C}(u,v)/\delta u)\,\mathrm{d}v\) --- Expectation of V given U, EvuCOP

The function jointCOP has considerable demonstration in its Note section of the joint and and joint or relations shown through simulation and counting scenarios. Also there is a demonstration in the Note section of function duCOP on application of the concepts of joint and conditions, joint or conditions, and importantly joint mutually exclusive or conditions.

Copula Construction Methods

Permutation asymmetry can be added to a copula by breveCOP. One, two, or more copulas can be “composited,” “combined,” or “multiplied” in interesting ways to create highly unique bivariate relations and as a result, complex dependence structures can be formed. The package provides three main functions for copula composition: composite1COP composites a single copula with two compositing parameters (Khoudraji device with independence), composite2COP (Khoudraji device) composites two copulas with two compositing parameters, and composite3COP composites two copulas with four compositing parameters. Also two copulas can be combined through a weighted convex combination using convex2COP with a single weighting parameter, and even \(N\) number of copulas can be combined by weights using convexCOP. So-called “gluing” two copula by a parameter is provided by glueCOP. Multiplication of two copulas to form a third is supported by prod2COP. All eight functions for compositing, combining, or multipling copulas are compatible with joint probability simulation (simCOP), measures of association (e.g. \(\rho_\mathbf{C}\)), and presumably all other copula operations using copBasic features. Finally, ordinal sums of copula are provided by ORDSUMcop and ORDSUWcop as particularly interesting methods of combining copulas.

No. of copulasCombining ParametersFunctionConcept
1\(\beta\)breveCOPadding permuation asymmetry
1\(\alpha, \beta\)composite1COPcopula combination
1\(\alpha, \beta\)khoudraji1COPcopula combination
1\(\alpha, \beta\)khoudrajiPCOPcopula combination
2\(\alpha, \beta\)composite2COPcopula combination
2\(\alpha, \beta\)khoudraji2COPcopula combination
2\(\alpha, \beta, \kappa, \gamma\)composite3COPcopula combination
2\(\alpha, (1-\alpha)\)convex2COPweighted copula combination
\(N\)\(\omega_{i \in N}\)convexCOPweighted copula combination
2\(\gamma\)glueCOPgluing of coupla
2\(\bigl(\mathbf{C}_1 \ast \mathbf{C}_2 \bigr)\)prod2COPcopula multiplication
\(N\)\(\mathbf{C}_{\mathcal{J}i}\) for \(\mathcal{J}_{i \in N}\) partitionsORDSUMcopM-ordinal sums of copulas
\(N\)\(\mathbf{C}_{\mathcal{J}i}\) for \(\mathcal{J}_{i \in N}\) partitionsORDSUWcopW-ordinal sums of copulas

Useful Copula Relations by Visualization

There are a myriad of relations amongst variables computable through copulas, and these were listed in the Table of Probabilities earlier in this documentation. There is a script located in the inst/doc directory of the copBasic sources titled CopulaRelations_BaseFigure_inR.txt. This script demonstrates, using the PSP copula, relations between the copula (COP), survival copula (surCOP), joint survival function of a copula (surfuncCOP), co-copula (coCOP), and dual of a copula function (duCOP). The script performs simulation and manual counts observations meeting various criteria in order to compute their empirical probabilities. The script produces a base figure, which after extending in editing software, is suitable for educational description and is provided at the end of this documentation.

A Review of “Return Periods” using Copulas

Risk analyses of natural hazards are commonly expressed as annual return periods \(T\) in years, which are defined for a nonexceedance probability \(q\) as \(T = 1/(1-q)\). In bivariate analysis, there immediately emerge two types of return periods representing \(T_{q;\,\mathrm{coop}}\) and \(T_{q;\,\mathrm{dual}}\) conditions between nonexceedances of the two hazard sources (random variables) \(U\) and \(V\). It is usual in many applications for \(T\) to be expressed equivalently as a probability \(q\) in common for both variables.

Incidentally, the \(\mathrm{Pr}[\,U > u \mid V > v\,]\) and \(\mathrm{Pr}[\,V > v \mid U > u\,]\) probabilities also are useful for conditional return period computations following Salvadori et al. (2007, pp. 159--160) but are not further considered here. Also the \(F_K(w)\) (Kendall Function or Kendall Measure of a copula) is the core tool for secondary return period computations (see kfuncCOP).

Let the copula \(\mathbf{C}(u,v; \Theta)\) for nonexceedances \(u\) and \(v\) be set for some copula family (formula) by a parameter vector \(\Theta\). The copula family and parameters define the joint coupling (loosely meant the dependency/correlation) between hazards \(U\) and \(V\). If “failure” occurs if either or both hazards \(U\) and \(V\) are at probability \(q\) threshold (\(u = v = 1 - 1/T = q\)) for \(T\)-year return period, then the real return period of failure is defined using either the copula \(\mathbf{C}(q,q; \Theta)\) or the co-copula \(\mathbf{C}^\star(q',q'; \Theta)\) for exceedance probability \(q' = 1 - q\) is

$$T_{q;\,\mathrm{coop}} = \frac{1}{1 - \mathbf{C}(q, q; \Theta)} = \frac{1}{\mathbf{C}^\star(1-q, 1-q; \Theta)}\mbox{\ and}$$ $$T_{q;\,\mathrm{coop}} \equiv \frac{1}{\mathrm{cooperative\ risk}}\mbox{.}$$

Or in words, the hazard sources collaborate or cooperate to cause failure. If failure occurs, however, if and only if both hazards \(U\) and \(V\) occur simultaneously (the hazards must “dually work together” or be “conjunctive”), then the real return period is defined using either the dual of a copula (function) \(\tilde{\mathbf{C}}(q,q; \Theta)\), the joint survival function \(\overline{\mathbf{C}}(q,q;\Theta)\), or survival copula \(\hat{\mathbf{C}}(q',q'; \Theta)\) as

$$T_{q;\,\mathrm{dual}} = \frac{1}{1 - \tilde{\mathbf{C}}(q,q; \Theta)} = \frac{1}{\overline{\mathbf{C}}(q,q;\Theta)} = \frac{1}{\hat{\mathbf{C}}(q',q';\Theta)} \mbox{\ and}$$ $$T_{q;\,\mathrm{dual}} \equiv \frac{1}{\mathrm{complement\ of\ dual\ protection}}\mbox{.}$$

Numerical demonstration is informative. Salvadori et al. (2007, p. 151) show for a Gumbel--Hougaard copula (GHcop) having \(\Theta =\) 3.055 and \(T =\) 1,000 years (\(q = 0.999\)) that \(T_{q;\,\mathrm{coop}} = 797.1\) years and that \(T_{q;\,\mathrm{dual}}\) = 1,341.4 years, which means that average return periods between “failures” are $$T_{q;\,\mathrm{coop}} \le T \le T_{q;\,\mathrm{dual}}\mbox{\ and thus}$$ $$797.1 \le T \le 1314.4\mbox{\ years.}$$

With the following code, these bounding return-period values are readily computed and verified using the prob2T() function from the lmomco package along with copBasic functions COP (generic functional interface to a copula) and duCOP (dual of a copula):


  q <- lmomco::T2prob(1000)
  lmomco::prob2T(  COP(q,q, cop=GHcop, para=3.055)) #  797.110
  lmomco::prob2T(duCOP(q,q, cop=GHcop, para=3.055)) # 1341.438

An early source (in 2005) by some of those authors cited on p. 151 of Salvadori et al. (2007; their citation “[67]”) shows \(T_{q;\,\mathrm{dual}} = 798\) years---a rounding error seems to have been committed. Finally just for reference, a Gumbel--Hougaard copula having \(\Theta = 3.055\) corresponds to an analytical Kendall Tau (see GHcop) of \(\tau \approx 0.673\), which can be verified through numerical integration available from tauCOP as:


  tauCOP(cop=GHcop, para=3.055, brute=TRUE) # 0.6726542

Thus, a “better understanding of the statistical characteristics of [multiple hazard sources] requires the study of their joint distribution” (Salvadori et al., 2007, p. 150).

Interaction of copBasic to Copulas in Other Packages

Originally, the copBasic package was not intended to be a port of the numerous bivariate copulas or over re-implementation other bivariate copulas available in R though as the package passed its 10th year in 2018, the original intent changed. It is useful to point out a demonstration showing an implementation of the Gaussian copula from the copula package, which is shown in the Note section of med.regressCOP in a circumstance of ordinary least squares linear regression compared to median regression of a copula as well as prediction limits of both regressions. Another demonstration in context of maximum pseudo-log-likelihood estimation of copula parameters is seen in the Note section mleCOP, and also see “API to the copula package” or “package copula (comparison to)” entries in the Index of this user manual.

Arguments

Author

William Asquith william.asquith@ttu.edu

References

Cherubini, U., Luciano, E., and Vecchiato, W., 2004, Copula methods in finance: Hoboken, NJ, Wiley, 293 p.

Hernández-Maldonado, V., Díaz-Viera, M., and Erdely, A., 2012, A joint stochastic simulation method using the Bernstein copula as a flexible tool for modeling nonlinear dependence structures between petrophysical properties: Journal of Petroleum Science and Engineering, v. 90--91, pp. 112--123.

Joe, H., 2014, Dependence modeling with copulas: Boca Raton, CRC Press, 462 p.

Hofert, M., Kojadinovic, I., Mächler, M., and Yan, J., 2018, Elements of copula modeling with R: Dordrecht, Netherlands, Springer.

Nelsen, R.B., 2006, An introduction to copulas: New York, Springer, 269 p.

Salvadori, G., De Michele, C., Kottegoda, N.T., and Rosso, R., 2007, Extremes in nature---An approach using copulas: Dordrecht, Netherlands, Springer, Water Science and Technology Library 56, 292 p.