| kiener3 {FatTailsR} | R Documentation | 
Asymmetric Kiener Distribution K3
Description
Density, distribution function, quantile function, random generation, value-at-risk, expected shortfall (+ signed left/right tail mean) and additional formulae for asymmetric Kiener distribution K3.
Usage
dkiener3(x, m = 0, g = 1, k = 3.2, d = 0, log = FALSE)
pkiener3(q, m = 0, g = 1, k = 3.2, d = 0, lower.tail = TRUE,
  log.p = FALSE)
qkiener3(p, m = 0, g = 1, k = 3.2, d = 0, lower.tail = TRUE,
  log.p = FALSE)
rkiener3(n, m = 0, g = 1, k = 3.2, d = 0)
dpkiener3(p, m = 0, g = 1, k = 3.2, d = 0, log = FALSE)
dqkiener3(p, m = 0, g = 1, k = 3.2, d = 0, log = FALSE)
lkiener3(x, m = 0, g = 1, k = 3.2, d = 0)
dlkiener3(lp, m = 0, g = 1, k = 3.2, d = 0, log = FALSE)
qlkiener3(lp, m = 0, g = 1, k = 3.2, d = 0, lower.tail = TRUE)
varkiener3(p, m = 0, g = 1, k = 3.2, d = 0, lower.tail = TRUE,
  log.p = FALSE)
ltmkiener3(p, m = 0, g = 1, k = 3.2, d = 0, lower.tail = TRUE,
  log.p = FALSE)
rtmkiener3(p, m = 0, g = 1, k = 3.2, d = 0, lower.tail = TRUE,
  log.p = FALSE)
dtmqkiener3(p, m = 0, g = 1, k = 3.2, d = 0, lower.tail = TRUE,
  log.p = FALSE)
eskiener3(p, m = 0, g = 1, k = 3.2, d = 0, lower.tail = TRUE,
  log.p = FALSE, signedES = FALSE)
Arguments
| x | vector of quantiles. | 
| m | numeric. The median. | 
| g | numeric. The scale parameter, preferably strictly positive. | 
| k | numeric. The tail parameter, preferably strictly positive. | 
| d | numeric. The distortion parameter between left and right tails. | 
| log | logical. If TRUE, densities are given in log scale. | 
| q | vector of quantiles. | 
| lower.tail | logical. If TRUE, use p. If FALSE, use 1-p. | 
| log.p | logical. If TRUE, probabilities p are given as log(p). | 
| p | vector of probabilities. | 
| n | number of observations. If length(n) > 1, the length is taken to be the number required. | 
| lp | vector of logit of probabilities. | 
| signedES | logical. FALSE (default) returns positive numbers for 
left and right tails. TRUE returns negative number 
(=  | 
Details
Kiener distributions use the following parameters, some of them being redundant. 
See aw2k and pk2pk for the formulas and 
the conversion between parameters:
-  m(mu) is the median of the distribution,.
-  g(gamma) is the scale parameter.
-  a(alpha) is the left tail parameter.
-  k(kappa) is the harmonic mean ofaandwand describes a global tail parameter.
-  w(omega) is the right tail parameter.
-  d(delta) is the distortion parameter.
-  e(epsilon) is the eccentricity parameter.
Kiener distributions K3(m, g, k, d, ...) are distributions 
with asymmetrical left and right fat tails described by a global tail 
parameter k and a distortion parameter d. 
Distributions K3 (kiener3) 
with parameters k (kappa) and d (delta) and
distributions K4 (kiener4)
with parameters k (kappa) and e (epsilon))
have been created to disantangle the parameters 
a (alpha) and w (omega) of distributions of 
distribution K2 (kiener2). 
The tiny difference between distributions K3 and K4 (d = e/k) 
has not yet been fully evaluated. Both should be tested at that moment.
k is the harmonic mean of a and w and represents a 
global tail parameter.
d is a distortion parameter between the left tail parameter
a and the right tail parameter w.
It verifies the inequality: -k < d < k 
(whereas e of distribution K4 verifies -1 < e < 1).
The conversion functions (see aw2k) are:
1/k = (1/a + 1/w)/2 
  d = (-1/a + 1/w)/2 
1/a = 1/k - d 
1/w = 1/k + d
d (and e) should be of the same sign than the skewness. 
A negative value  d < 0  implies  a < w  and indicates a left  
tail heavier than the right tail. A positive value  d > 0  implies 
 a > w  and a right tail heavier than the left tail.  
m is the median of the distribution. g is the scale parameter 
and the inverse of the density at the median:  g = 1 / 8 / f(m) .
As a first estimate, it is approximatively one fourth of the standard 
deviation  g  \approx \sigma / 4  but is independant from it.
The d, p functions have no explicit forms. They are provided here for 
convenience. They are estimated from a reverse optimization on the quantile 
function and can be (very) slow, depending the number of points to estimate. 
We recommand to use the quantile function as far as possible.
WARNING: Results may become inconsistent when k is
smaller than 1 or for very large absolute values of d. 
Hopefully, this case seldom happens in finance.
qkiener3 function is defined for p in (0, 1) by: 
 qkiener3(p, m, g, k, d) = 
              m + 2 * g * k * sinh(logit(p) / k) * exp(d * logit(p)) 
rkiener3 generates n random quantiles.
In addition to the classical d, p, q, r functions, the prefixes dp, dq, l, dl, ql are also provided.
dpkiener3 is the density function calculated from the probability p. 
The formula is adapted from distribution K2. It is defined for p in (0, 1) by: 
 dpkiener3(p, m, g, k, d) = 
         p * (1 - p) / k / g / ( exp(-logit(p)/a)/a + exp(logit(p)/w)/w 
with a and w defined from k and d 
with the formula presented above.
dqkiener3 is the derivate of the quantile function calculated from 
the probability p. The formula is adapted from distribution K2. 
It is defined for p in (0, 1) by: 
 dqkiener3(p, m, g, k, d) = 
         k * g / p / (1 - p) * ( exp(-logit(p)/a)/a + exp(logit(p)/w)/w ) 
with a and w defined above. 
lkiener3 function is estimated from a reverse optimization and can 
be (very) slow depending the number of points to estimate. Initialization 
is done with a symmetric distribution lkiener1 
of parameter k (thus  d = 0). Then optimization is performed  
to take into account the true value of d. 
The results can then be compared to the empirical probability logit(p).
WARNING: Results may become inconsistent when k is
smaller than 1 or for very large absolute values of d. 
Hopefully, this case seldom happens in finance.
dlkiener3 is the density function calculated from the logit of the 
probability lp = logit(p). The formula is adapted from distribution K2. 
it is defined for lp in (-Inf, +Inf) by: 
 dlkiener3(lp, m, g, k, d) = 
          p * (1 - p) / k / g / ( exp(-lp/a)/a + exp(lp/w)/w ) 
with a and w defined above. 
qlkiener3 is the quantile function calculated from the logit of the 
probability. It is defined for lp in (-Inf, +Inf) by: 
 qlkiener3(lp, m, g, k, d) = 
          m + 2 * g * k * sinh(lp / k) * exp(d * lp) 
varkiener3 designates the Value a-risk and turns negative numbers 
into positive numbers with the following rule:
 varkiener3 <- if(p <= 0.5) { - qkiener3 } else { qkiener3 } 
Usual values in finance are p = 0.01, p = 0.05, p = 0.95 and 
p = 0.99. lower.tail = FALSE uses 1-p rather than p.
ltmkiener3, rtmkiener3 and eskiener3 are respectively the 
left tail mean, the right tail mean and the expected shortfall of the distribution 
(sometimes called average VaR, conditional VaR or tail VaR). 
Left tail mean is the integrale from -Inf to p of the quantile function 
qkiener3 divided by p.
Right tail mean is the integrale from p to +Inf of the quantile function 
qkiener3 divided by 1-p.
Expected shortfall turns negative numbers into positive numbers with the following rule:
 eskiener3 <- if(p <= 0.5) { - ltmkiener3 } else { rtmkiener3 } 
Usual values in finance are p = 0.01, p = 0.025, p = 0.975 and 
p = 0.99. lower.tail = FALSE uses 1-p rather than p.
dtmqkiener3 is the difference between the left tail mean and the quantile 
when (p <= 0.5) and the difference between the right tail mean and the quantile 
when (p > 0.5). It is in quantile unit and is an indirect measure of the tail curvature.
References
P. Kiener, Explicit models for bilateral fat-tailed distributions and applications in finance with the package FatTailsR, 8th R/Rmetrics Workshop and Summer School, Paris, 27 June 2014. Download it from: https://www.inmodelia.com/exemples/2014-0627-Rmetrics-Kiener-en.pdf
P. Kiener, Fat tail analysis and package FatTailsR, 9th R/Rmetrics Workshop and Summer School, Zurich, 27 June 2015. Download it from: https://www.inmodelia.com/exemples/2015-0627-Rmetrics-Kiener-en.pdf
C. Acerbi, D. Tasche, Expected shortfall: a natural coherent alternative to Value at Risk, 9 May 2001. Download it from: https://www.bis.org/bcbs/ca/acertasc.pdf
See Also
Symmetric Kiener distribution K1 kiener1, 
asymmetric Kiener distributions K2, K4 and K7
kiener2, kiener4, kiener7, 
conversion functions aw2k,  
estimation function fitkienerX, 
regression function regkienerLX.
Examples
require(graphics)
### Example 1
pp <- c(ppoints(11, a = 1), NA, NaN) ; pp
lp <- logit(pp) ; lp
qkiener3(  p = pp, m = 2, g = 1.5, k = aw2k(4, 6), d = aw2d(4, 6))
qlkiener3(lp = lp, m = 2, g = 1.5, k = aw2k(4, 6), d = aw2d(4, 6))
dpkiener3( p = pp, m = 2, g = 1.5, k = aw2k(4, 6), d = aw2d(4, 6))
dlkiener3(lp = lp, m = 2, g = 1.5, k = aw2k(4, 6), d = aw2d(4, 6))
dqkiener3( p = pp, m = 2, g = 1.5, k = aw2k(4, 6), d = aw2d(4, 6))
### Example 2
k       <- 4.8
d       <- 0.042
set.seed(2014)
mainTC  <- paste("qkiener3(p, m = 0, g = 1, k = ", k, ", d = ", d, ")")
mainsum <- paste("cumulated qkiener3(p, m = 0, g = 1, k = ", k, ", d = ", d, ")")
T       <- 500
C       <- 4
TC      <- qkiener3(p = runif(T*C), m = 0, g = 1, k = k, d = d)
matTC   <- matrix(TC, nrow = T, ncol = C, dimnames = list(1:T, letters[1:C]))
head(matTC)
plot.ts(matTC, main = mainTC)
#
matsum  <- apply(matTC, MARGIN=2, cumsum) 
head(matsum)
plot.ts(matsum, plot.type = "single", main = mainsum)
### End example 2
### Example 3 (four plots: probability, density, logit, logdensity)
x     <- q  <- seq(-15, 15, length.out=101)
k     <- 3.2
d     <- c(-0.1, -0.03, -0.01, 0.01, 0.03, 0.1) ; names(d) <- d
olty  <- c(2, 1, 2, 1, 2, 1, 1)
olwd  <- c(1, 1, 2, 2, 3, 3, 2)
ocol  <- c(2, 2, 4, 4, 3, 3, 1)
lleg  <- c("logit(0.999) = 6.9", "logit(0.99)   = 4.6", "logit(0.95)   = 2.9", 
           "logit(0.50)   = 0", "logit(0.05)   = -2.9", "logit(0.01)   = -4.6", 
           "logit(0.001) = -6.9  ")
op    <- par(mfrow=c(2,2), mgp=c(1.5,0.8,0), mar=c(3,3,2,1))
plot(x, pkiener3(x, k = 3.2, d = 0), type = "l", lwd = 3, ylim = c(0, 1),
     xaxs = "i", yaxs = "i", xlab = "", ylab = "", 
     main = "pkiener3(q, m, g, k=3.2, d=...)")
for (i in 1:length(d)) lines(x, pkiener3(x, k = 3.2, d = d[i]), 
       lty = olty[i], lwd = olwd[i], col = ocol[i] )
legend("topleft", title = expression(delta), legend = c(d, "0"), 
       cex = 0.7, inset = 0.02, lty = olty, lwd = olwd, col = ocol )
plot(x, dkiener3(x, k = 3.2, d = 0), type = "l", lwd = 3, ylim = c(0, 0.14),
     xaxs = "i", yaxs = "i", xlab = "", ylab = "", 
     main = "dkiener3(q, m, g, k=3.2, d=...)")
for (i in 1:length(d)) lines(x, dkiener3(x, k = 3.2, d = d[i]), 
       lty = olty[i], lwd = olwd[i], col = ocol[i] )
legend("topright", title = expression(delta), legend = c(d, "0"), 
       cex = 0.7, inset = 0.02, lty = olty, lwd = olwd, col = ocol )
plot(x, lkiener3(x, k = 3.2, d = 0), type = "l", lwd =3, ylim = c(-7.5, 7.5), 
     yaxt="n", xaxs = "i", yaxs = "i", xlab = "", ylab = "", 
     main = "logit(pkiener3(q, m, g, k=3.2, d=...))")
axis(2, las=1, at=c(-6.9, -4.6, -2.9, 0, 2.9, 4.6, 6.9) )
for (i in 1:length(d)) lines(x, lkiener3(x, k = 3.2, d = d[i]),  
       lty = olty[i], lwd = olwd[i], col = ocol[i] )
legend("topleft", legend = lleg, cex = 0.7, inset = 0.02 )
legend("bottomright", title = expression(delta), legend = c(d, "0"), 
       cex = 0.7, inset = 0.02, lty = c(olty), lwd = c(olwd), col = c(ocol) )
plot(x, dkiener3(x, k = 3.2, d = 0, log = TRUE), type = "l", lwd = 3, 
     ylim = c(-8, -1.5), xaxs = "i", yaxs = "i", xlab = "", ylab = "", 
     main = "log(dkiener3(q, m, g, k=2, d=...))")
for (i in 1:length(d)) lines(x, dkiener3(x, k = 3.2, d = d[i], log=TRUE), 
       lty = olty[i], lwd = olwd[i], col = ocol[i] )
legend("bottom", title = expression(delta), legend = c(d, "0"), 
       cex = 0.7, inset = 0.02, lty = olty, lwd = olwd, col = ocol )
### End example 3
### Example 4 (four plots: quantile, derivate, density and quantiles from p)
p     <- ppoints(199, a=0)
d     <- c(-0.1, -0.03, -0.01, 0.01, 0.03, 0.1) ; names(d) <- d
op    <- par(mfrow=c(2,2), mgp=c(1.5,0.8,0), mar=c(3,3,2,1))
plot(p, qlogis(p, scale = 2), type = "l", lwd = 2, xlim = c(0, 1),
      ylim = c(-15, 15), xaxs = "i", yaxs = "i", xlab = "", ylab = "", 
     main = "qkiener3(p, m, g, k=3.2, d=...)")
for (i in 1:length(d)) lines(p, qkiener3(p, k = 3.2, d = d[i]), 
          lty = olty[i], lwd = olwd[i], col = ocol[i] )
legend("topleft", title = expression(delta), legend = c(d, "qlogis(x/2)"), 
          inset = 0.02, lty = olty, lwd = olwd, col = ocol, cex = 0.7 )
plot(p, 2/p/(1-p), type = "l", lwd = 2, xlim = c(0, 1), ylim = c(0, 100),
     xaxs = "i", yaxs = "i", xlab = "", ylab = "", 
     main = "dqkiener3(p, m, g, k=3.2, d=...)")
for (i in 1:length(d)) lines(p, dqkiener3(p, k = 3.2, d = d[i]), 
          lty = olty[i], lwd = olwd[i], col = ocol[i] )
legend("top", title = expression(delta), legend = c(d, "p*(1-p)/2"), 
          inset = 0.02, lty = olty, lwd = olwd, col = ocol, cex = 0.7 )
plot(qlogis(p, scale = 2), p*(1-p)/2, type = "l", lwd = 2, xlim = c(-15, 15), 
     ylim = c(0, 0.14), xaxs = "i", yaxs = "i", xlab = "", ylab = "", 
     main = "qkiener3, dpkiener3(p, m, g, k=3.2, d=...)")
for (i in 1:length(d)) { 
     lines(qkiener3(p, k = 3.2, d = d[i]), dpkiener3(p, k = 3.2, d = d[i]),
           lty = olty[i], lwd = olwd[i], col = ocol[i] ) }
legend("topleft", title = expression(delta), legend = c(d, "p*(1-p)/2"), 
          inset = 0.02, lty = olty, lwd = olwd, col = ocol, cex = 0.7 )
plot(qlogis(p, scale = 2), p, type = "l", lwd = 2, xlim = c(-15, 15), 
     ylim = c(0, 1), xaxs = "i", yaxs = "i", xlab = "", ylab = "", 
     main = "inverse axis qkiener3(p, m, g, k=3.2, d=...)")
for (i in 1:length(d)) lines(qkiener3(p, k = 3.2, d = d[i]), p,
          lty = olty[i], lwd = olwd[i], col = ocol[i] )
legend("topleft", title = expression(delta), legend = c(d, "qlogis(x/2)"), 
          inset = 0.02, lty = olty, lwd = olwd, col = ocol, cex = 0.7 )
### End example 4
### Example 5 (q and VaR, ltm, rtm, and ES)
pp <- c(0.001, 0.0025, 0.005, 0.01, 0.025, 0.05, 
        0.10, 0.20, 0.35, 0.5, 0.65, 0.80, 0.90,
        0.95, 0.975, 0.99, 0.995, 0.9975, 0.999)
m <- -10 ; g <- 1 ; k <- 4 ; d <- 0.06 
a <- dk2a(d, k) ; w <- dk2w(d, k) ; e <- dk2e(d, k)
round(c(m = m, g = g, a = a, k = k, w = w, d = d, e = e), 2) 
plot(qkiener3(  pp, m=m, k=k, d=d), pp, type ="b")
round(cbind(p = pp, "1-p" = 1-pp,
	q   =   qkiener3(pp, m, g, k, d),
	ltm = ltmkiener3(pp, m, g, k, d),
	rtm = rtmkiener3(pp, m, g, k, d),
	ES  =  eskiener3(pp, m, g, k, d),
	VaR = varkiener3(pp, m, g, k, d)), 4)
round(kmean(c(m, g, k, d), model = "K3"), 4) # limit value for ltm and rtm
round(cbind(p = pp, "1-p" = 1-pp,
	q   =   qkiener3(pp, m, g, k, d, lower.tail = FALSE),
	ltm = ltmkiener3(pp, m, g, k, d, lower.tail = FALSE),
	rtm = rtmkiener3(pp, m, g, k, d, lower.tail = FALSE),
	ES  =  eskiener3(pp, m, g, k, d, lower.tail = FALSE),
	VaR = varkiener3(pp, m, g, k, d, lower.tail = FALSE)), 4)
### End example 5