swh:1:snp:16c54c84bc54885e783d4424d714e5cc82f479a1
Raw File
Tip revision: 6964fff892ea20af9633cd7279891c0c431e80bf authored by Roger Koenker on 26 January 2022, 17:32:42 UTC
version 5.87
Tip revision: 6964fff
q489.Rd
\name{q489}
\alias{q489}
\title{Even Quicker Sample Quantiles }
\description{
The function \code{q489} computes a single sample quantile using a 
fortran implementation of the Floyd and Rivest (1975) algorithm.
In contrast to the more elaborate function \code{kuantile} that uses
the Kiweil (2005) implementation it does not attempt to replicate the
nine varieties of quantiles as documented in the base function.
\code{quantile}
}
\usage{
q489(x, tau = .5) 
}
\arguments{
  \item{x}{numeric vector}
  \item{tau}{the quantile of intereste.}
}
\details{ This is a direct translation of the Algol 68 implementation of
Floyd and Rivest (1975), implemented in Ratfor.  For the median, average 
case behavior requires \eqn{1.5 n + O((n log n)^{1/2})} comparisons. 
In preliminary experiments it seems to be somewhat faster in large samples
than the implementation \code{kuantile} of Kiwiel (2005). See  Knuth (1998)
for further details. No provision is made for non-uniqueness of the quantile.
so, when \eqn{\tau n} is an integer there may be some discrepancy.}  
\value{
  A scalar quantile of the same length as the vector p.
}
\references{ 
R.W. Floyd and R.L. Rivest: "Algorithm 489: The Algorithm
        SELECT---for Finding the $i$th Smallest of $n$ Elements",
        Comm. ACM 18, 3 (1975) 173,

K.C. Kiwiel: On Floyd and Rivest's SELECT Algorithm, Theoretical
      Computer Sci. 347 (2005) 214-238.

D. Knuth, The Art of Computer Programming, Volume 3, Sorting and 
	Searching, 2nd Ed., (1998), Addison-Wesley.
}
\author{ R.W.Floyd and R.L.Rivest, R implementation:  Roger Koenker }
\seealso{\code{\link{quantile}}}
\examples{
     medx <- q489(rnorm(1001))
}
\keyword{univar}
back to top