Nothing
dquantile <-
function (x, tau, quant, lower = -Inf)
{
if (length(tau) != length(quant))
stop("\"tau\" and \"quant\" must be same length")
if (any(tau < 0) | any(tau > 1))
stop("\"tau\" must be in range [0, 1]")
quant[quant < lower] <- lower
if (is.unsorted(tau) | is.unsorted(quant)) {
warning("sorting \"tau\" or \"quant\"")
tau <- sort(tau)
quant <- sort(quant)
}
if (any(x < lower)) {
warning("\"x\" < lower limit; replacing values with \"lower\"")
x[x < lower] <- lower
}
if ((lower != -Inf) & (!(0 %in% tau))) {
quant <- c(lower, quant)
tau <- c(0, tau)
}
dq <- function(x, tau, quant) {
n <- length(quant)
d <- 0
z1 <- (tau[2]-tau[1])/(quant[2]-quant[1])
b1 <- tau[1]/z1
zn <- (tau[n]-tau[n-1])/(quant[n]-quant[n-1])
bn <- (1-tau[n])/zn
run <- TRUE
if (x < quant[1]) {
d <- z1*exp(-abs(x-quant[1])/b1)
run <- FALSE
}
if (x >= quant[n]) {
d <- zn*exp(-abs(x-quant[n])/bn)
run <- FALSE
}
if (run) {
for (j in 2:n) {
if (quant[j] > x) {
d <- (tau[j]-tau[j-1])/(quant[j]-quant[j-1])
break
}
}
}
d
}
d <- sapply(x, dq, tau = tau, quant = quant)
if((lower != -Inf) & any(x == lower)) {
d[x == lower] <- max(tau[quant == lower])
}
d
}
pquantile <-
function(q, tau, quant, lower = -Inf, ...)
{
if (length(tau) != length(quant))
stop("\"tau\" and \"quant\" must be same length")
if (any(tau < 0) | any(tau > 1))
stop("\"tau\" must be in range [0, 1]")
quant[quant < lower] <- lower
if (is.unsorted(tau) | is.unsorted(quant)) {
warning("sorting \"tau\" or \"quant\"")
tau <- sort(tau)
quant <- sort(quant)
}
if ((lower != -Inf) & (!(0 %in% tau))) {
quant <- c(lower, quant)
tau <- c(0, tau)
} else if (lower == -Inf) {
tau <- tau[quant != -Inf]
quant <- quant[quant != -Inf]
}
p <- q
p[q >= lower] <- approx(x = quant, y = tau, xout = q[q >= lower],
ties = max)$y
pq.lu <- function(q, tau, quant, ...) {
if (q < quant[1]){
p <- integrate(dquantile, lower = -Inf, upper = q,
tau = tau, quant = quant, ...)$value
} else {
p <- integrate(dquantile, lower = quant[length(quant)],
upper = q, tau = tau, quant = quant,
...)$value + tau[length(quant)]
}
p
}
if (any(is.na(p))) {
p[is.na(p)] <- sapply(q[is.na(p)], pq.lu, tau = tau,
quant = quant, ...)
}
if (any(q < lower)) {
warning("\"q\" < lower limit")
p[q < lower] <- NA
}
if (lower == -Inf) p[q == -Inf] <- 0
p[q == Inf] <- 1
p
}
qquantile <-
function(p, tau, quant, lower = -Inf, tol = .Machine$double.eps^0.25,
maxiter = 1000, range.mult = 1.1, max.error = 100, ...)
{
if (length(tau) != length(quant))
stop("\"tau\" and \"quant\" must be same length")
if (any(tau < 0) | any(tau > 1))
stop("\"tau\" must be in range [0, 1]")
if (any(p < 0) | any(p > 1))
stop("\"p\" must be in range [0, 1]")
quant[quant < lower] <- lower
if (is.unsorted(tau) | is.unsorted(quant)) {
warning("sorting \"tau\" or \"quant\"")
tau <- sort(tau)
quant <- sort(quant)
}
if ((lower != -Inf) & (!(0 %in% tau))) {
quant <- c(lower, quant)
tau <- c(0, tau)
} else if (lower == -Inf) {
tau <- tau[quant != -Inf]
quant <- quant[quant != -Inf]
}
q <- approx(x = tau, y = quant, xout = p)$y
qq.lu <- function(p, tau, quant, min.max, tol, maxiter, ...) {
cost <- function(q, p, tau, quant, ...){
pp <- pquantile(q, tau = tau, quant = quant, ...)
pp-p
}
if(p < tau[1]){
q <- uniroot(f = cost, lower = min(min.max),
upper = quant[1], tol = tol,
maxiter = maxiter, p = p, tau = tau,
quant = quant, ...)$root
} else {
q <- uniroot(f = cost, lower = quant[length(quant)],
upper = max(min.max), tol = tol,
maxiter = maxiter, p = p, tau = tau,
quant = quant, ...)$root
}
q
}
if (any(is.na(q))) {
error <- TRUE
n.error <- 0
quant.range <- diff(range(quant))
while (error & (n.error < max.error)) {
quant.range <- range.mult*quant.range
min.max <- c(quant[1] - quant.range,
quant[length(quant)] + quant.range)
qq <- try(sapply(p[is.na(q)], qq.lu, tau = tau,
quant = quant, min.max = min.max,
tol = tol, maxiter = maxiter, ...),
silent = TRUE)
error <- inherits(qq, "try-error")
n.error <- n.error + 1
}
if (error) stop("n.error > max.error")
q[is.na(q)] <- qq
}
if (lower == -Inf) q[p == 0] <- -Inf
q[p == 1] <- Inf
q
}
rquantile <-
function(n, tau, quant, lower = -Inf, tol = .Machine$double.eps^0.25,
maxiter = 1000, range.mult = 1.1, max.error = 100, ...)
{
if (length(tau) != length(quant))
stop("\"tau\" and \"quant\" must be same length")
if (any(tau < 0) | any(tau > 1))
stop("\"tau\" must be in range [0, 1]")
quant[quant < lower] <- lower
if (is.unsorted(tau) | is.unsorted(quant)) {
warning("sorting \"tau\" or \"quant\"")
tau <- sort(tau)
quant <- sort(quant)
}
q <- qquantile(runif(n), tau = tau, quant = quant,
lower = lower, tol = tol, maxiter = maxiter,
range.mult = range.mult, max.error = max.error,
...)
q
}
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.