Nothing
#' @name weibullgpdcon
#'
#' @title Weibull Bulk and GPD Tail Extreme Value Mixture Model with Single Continuity Constraint
#'
#' @description Density, cumulative distribution function, quantile function and
#' random number generation for the extreme value mixture model with Weibull for bulk
#' distribution upto the threshold and conditional GPD above threshold with continuity at threshold. The parameters
#' are the weibull shape \code{wshape} and scale \code{wscale}, threshold \code{u}
#' GPD shape \code{xi} and tail fraction \code{phiu}.
#'
#' @inheritParams weibullgpd
#'
#' @details Extreme value mixture model combining Weibull distribution for the bulk
#' below the threshold and GPD for upper tail with continuity at threshold.
#'
#' The user can pre-specify \code{phiu}
#' permitting a parameterised value for the tail fraction \eqn{\phi_u}. Alternatively, when
#' \code{phiu=TRUE} the tail fraction is estimated as the tail fraction from the
#' weibull bulk model.
#'
#' The cumulative distribution function with tail fraction \eqn{\phi_u} defined by the
#' upper tail fraction of the Weibull bulk model (\code{phiu=TRUE}), upto the
#' threshold \eqn{0 < x \le u}, given by:
#' \deqn{F(x) = H(x)}
#' and above the threshold \eqn{x > u}:
#' \deqn{F(x) = H(u) + [1 - H(u)] G(x)}
#' where \eqn{H(x)} and \eqn{G(X)} are the Weibull and conditional GPD
#' cumulative distribution functions (i.e. \code{pweibull(x, wshape, wscale)} and
#' \code{pgpd(x, u, sigmau, xi)}) respectively.
#'
#' The cumulative distribution function for pre-specified \eqn{\phi_u}, upto the
#' threshold \eqn{0 < x \le u}, is given by:
#' \deqn{F(x) = (1 - \phi_u) H(x)/H(u)}
#' and above the threshold \eqn{x > u}:
#' \deqn{F(x) = \phi_u + [1 - \phi_u] G(x)}
#' Notice that these definitions are equivalent when \eqn{\phi_u = 1 - H(u)}.
#'
#' The continuity constraint means that \eqn{(1 - \phi_u) h(u)/H(u) = \phi_u g(u)}
#' where \eqn{h(x)} and \eqn{g(x)} are the Weibull and conditional GPD
#' density functions (i.e. \code{dweibull(x, wshape, wscale)} and
#' \code{dgpd(x, u, sigmau, xi)}) respectively. The resulting GPD scale parameter is then:
#' \deqn{\sigma_u = \phi_u H(u) / [1 - \phi_u] h(u)}.
#' In the special case of where the tail fraction is defined by the bulk model this reduces to
#' \deqn{\sigma_u = [1 - H(u)] / h(u)}.
#'
#' The Weibull is defined on the non-negative reals, so the threshold must be positive.
#'
#' See \code{\link[evmix:gpd]{gpd}} for details of GPD upper tail component and
#'\code{\link[stats:Weibull]{dweibull}} for details of weibull bulk component.
#'
#' @return \code{\link[evmix:weibullgpdcon]{dweibullgpdcon}} gives the density,
#' \code{\link[evmix:weibullgpdcon]{pweibullgpdcon}} gives the cumulative distribution function,
#' \code{\link[evmix:weibullgpdcon]{qweibullgpdcon}} gives the quantile function and
#' \code{\link[evmix:weibullgpdcon]{rweibullgpdcon}} gives a random sample.
#'
#' @note All inputs are vectorised except \code{log} and \code{lower.tail}.
#' The main inputs (\code{x}, \code{p} or \code{q}) and parameters must be either
#' a scalar or a vector. If vectors are provided they must all be of the same length,
#' and the function will be evaluated for each element of vector. In the case of
#' \code{\link[evmix:weibullgpdcon]{rweibullgpdcon}} any input vector must be of length \code{n}.
#'
#' Default values are provided for all inputs, except for the fundamentals
#' \code{x}, \code{q} and \code{p}. The default sample size for
#' \code{\link[evmix:weibullgpdcon]{rweibullgpdcon}} is 1.
#'
#' Missing (\code{NA}) and Not-a-Number (\code{NaN}) values in \code{x},
#' \code{p} and \code{q} are passed through as is and infinite values are set to
#' \code{NA}. None of these are not permitted for the parameters.
#'
#' Error checking of the inputs (e.g. invalid probabilities) is carried out and
#' will either stop or give warning message as appropriate.
#'
#' @references
#' \url{http://en.wikipedia.org/wiki/Weibull_distribution}
#'
#' \url{http://en.wikipedia.org/wiki/Generalized_Pareto_distribution}
#'
#' Scarrott, C.J. and MacDonald, A. (2012). A review of extreme value
#' threshold estimation and uncertainty quantification. REVSTAT - Statistical
#' Journal 10(1), 33-59. Available from \url{http://www.ine.pt/revstat/pdf/rs120102.pdf}
#'
#' Behrens, C.N., Lopes, H.F. and Gamerman, D. (2004). Bayesian analysis of extreme
#' events with threshold estimation. Statistical Modelling. 4(3), 227-244.
#'
#' @author Yang Hu and Carl Scarrott \email{carl.scarrott@@canterbury.ac.nz}
#'
#' @section Acknowledgments: Thanks to Ben Youngman, Exeter University, UK for reporting a bug in the \code{\link[evmix:weibullgpdcon]{rweibullgpdcon}} function.
#'
#' @seealso \code{\link[evmix:gpd]{gpd}} and \code{\link[stats:Weibull]{dweibull}}
#' @aliases weibullgpdcon dweibullgpdcon pweibullgpdcon qweibullgpdcon rweibullgpdcon
#' @family weibullgpd
#' @family weibullgpdcon
#' @family itmweibullgpd
#' @family fweibullgpdcon
#'
#' @examples
#' \dontrun{
#' set.seed(1)
#' par(mfrow = c(2, 2))
#'
#' x = rweibullgpdcon(1000)
#' xx = seq(-0.1, 6, 0.01)
#' hist(x, breaks = 100, freq = FALSE, xlim = c(-1, 6))
#' lines(xx, dweibullgpdcon(xx))
#'
#' # three tail behaviours
#' plot(xx, pweibullgpdcon(xx), type = "l")
#' lines(xx, pweibullgpdcon(xx, xi = 0.3), col = "red")
#' lines(xx, pweibullgpdcon(xx, xi = -0.3), col = "blue")
#' legend("bottomright", paste("xi =",c(0, 0.3, -0.3)),
#' col=c("black", "red", "blue"), lty = 1)
#'
#' x = rweibullgpdcon(1000, phiu = 0.2)
#' hist(x, breaks = 100, freq = FALSE, xlim = c(-1, 6))
#' lines(xx, dweibullgpdcon(xx, phiu = 0.2))
#'
#' plot(xx, dweibullgpdcon(xx, xi=0, phiu = 0.2), type = "l")
#' lines(xx, dweibullgpdcon(xx, xi=-0.2, phiu = 0.2), col = "red")
#' lines(xx, dweibullgpdcon(xx, xi=0.2, phiu = 0.2), col = "blue")
#' legend("topright", c("xi = 0", "xi = 0.2", "xi = -0.2"),
#' col=c("black", "red", "blue"), lty = 1)
#' }
#'
NULL
#' @export
#' @aliases weibullgpdcon dweibullgpdcon pweibullgpdcon qweibullgpdcon rweibullgpdcon
#' @rdname weibullgpdcon
# probability density function for weibull bulk with GPD for upper tail
# with continuity at threshold
dweibullgpdcon <- function(x, wshape = 1, wscale = 1, u = qweibull(0.9, wshape, wscale),
xi = 0, phiu = TRUE, log = FALSE) {
# Check properties of inputs
check.quant(x, allowna = TRUE, allowinf = TRUE)
check.posparam(wshape, allowvec = TRUE)
check.posparam(wscale, allowvec = TRUE)
check.posparam(u, allowvec = TRUE)
check.param(xi, allowvec = TRUE)
check.phiu(phiu, allowvec = TRUE)
check.logic(log)
n = check.inputn(c(length(x), length(wshape), length(wscale),
length(u), length(xi), length(phiu)), allowscalar = TRUE)
if (any(is.infinite(x))) warning("infinite quantiles set to NA")
x[is.infinite(x)] = NA # user will have to deal with infinite cases
x = rep(x, length.out = n)
wshape = rep(wshape, length.out = n)
wscale = rep(wscale, length.out = n)
u = rep(u, length.out = n)
xi = rep(xi, length.out = n)
pu = pweibull(u, wshape, wscale)
if (is.logical(phiu)) {
phiu = 1 - pu
} else {
phiu = rep(phiu, length.out = n)
}
phib = (1 - phiu) / pu
d = x # pass through NA/NaN as entered
sigmau = phiu / (phib * dweibull(u, wshape, wscale))
check.posparam(sigmau, allowvec = TRUE)
dweibullgpd(x, wshape, wscale, u, sigmau, xi, phiu, log)
}
#' @export
#' @aliases weibullgpdcon dweibullgpdcon pweibullgpdcon qweibullgpdcon rweibullgpdcon
#' @rdname weibullgpdcon
# cumulative distribution function for weibull bulk with GPD for upper tail
# with continuity at threshold
pweibullgpdcon <- function(q, wshape = 1, wscale = 1, u = qweibull(0.9, wshape, wscale),
xi = 0, phiu = TRUE, lower.tail = TRUE) {
# Check properties of inputs
check.quant(q, allowna = TRUE, allowinf = TRUE)
check.posparam(wshape, allowvec = TRUE)
check.posparam(wscale, allowvec = TRUE)
check.posparam(u, allowvec = TRUE)
check.param(xi, allowvec = TRUE)
check.phiu(phiu, allowvec = TRUE)
check.logic(lower.tail)
n = check.inputn(c(length(q), length(wshape), length(wscale),
length(u), length(xi), length(phiu)), allowscalar = TRUE)
if (any(is.infinite(q))) warning("infinite quantiles set to NA")
q[is.infinite(q)] = NA # user will have to deal with infinite cases
q = rep(q, length.out = n)
wshape = rep(wshape, length.out = n)
wscale = rep(wscale, length.out = n)
u = rep(u, length.out = n)
xi = rep(xi, length.out = n)
pu = pweibull(u, wshape, wscale)
if (is.logical(phiu)) {
phiu = 1 - pu
} else {
phiu = rep(phiu, length.out = n)
}
phib = (1 - phiu) / pu
sigmau = phiu / (phib * dweibull(u, wshape, wscale))
check.posparam(sigmau, allowvec = TRUE)
pweibullgpd(q, wshape, wscale, u, sigmau, xi, phiu, lower.tail)
}
#' @export
#' @aliases weibullgpdcon dweibullgpdcon pweibullgpdcon qweibullgpdcon rweibullgpdcon
#' @rdname weibullgpdcon
# inverse cumulative distribution function for weibull bulk with GPD for upper tail
# with continuity at threshold
qweibullgpdcon <- function(p, wshape = 1, wscale = 1, u = qweibull(0.9, wshape, wscale),
xi = 0, phiu = TRUE, lower.tail = TRUE) {
# Check properties of inputs
check.prob(p, allowna = TRUE)
check.posparam(wshape, allowvec = TRUE)
check.posparam(wscale, allowvec = TRUE)
check.posparam(u, allowvec = TRUE)
check.param(xi, allowvec = TRUE)
check.phiu(phiu, allowvec = TRUE)
check.logic(lower.tail)
n = check.inputn(c(length(p), length(wshape), length(wscale),
length(u), length(xi), length(phiu)), allowscalar = TRUE)
p = rep(p, length.out = n)
wshape = rep(wshape, length.out = n)
wscale = rep(wscale, length.out = n)
u = rep(u, length.out = n)
xi = rep(xi, length.out = n)
pu = pweibull(u, wshape, wscale)
if (is.logical(phiu)) {
phiu = 1 - pu
} else {
phiu = rep(phiu, length.out = n)
}
phib = (1 - phiu) / pu
sigmau = phiu / (phib * dweibull(u, wshape, wscale))
check.posparam(sigmau, allowvec = TRUE)
qweibullgpd(p, wshape, wscale, u, sigmau, xi, phiu, lower.tail)
}
#' @export
#' @aliases weibullgpdcon dweibullgpdcon pweibullgpdcon qweibullgpdcon rweibullgpdcon
#' @rdname weibullgpdcon
# random number generation for weibull bulk with GPD for upper tail
# with continuity at threshold
rweibullgpdcon <- function(n = 1, wshape = 1, wscale = 1, u = qweibull(0.9, wshape, wscale),
xi = 0, phiu = TRUE) {
# Check properties of inputs
check.n(n)
check.posparam(wshape, allowvec = TRUE)
check.posparam(wscale, allowvec = TRUE)
check.posparam(u, allowvec = TRUE)
check.param(xi, allowvec = TRUE)
check.phiu(phiu, allowvec = TRUE)
n = check.inputn(c(n, length(wshape), length(wscale), length(u), length(xi), length(phiu)),
allowscalar = TRUE)
if (any(xi == 1)) stop("shape cannot be 1")
qweibullgpdcon(runif(n), wshape, wscale, u, xi, phiu)
}
Any scripts or data that you put into this service are public.
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.