Compute quantiles
Usage
fast_quantile(x, prob = 0.5, na.rm = FALSE, ...)
fast_median(x, na.rm = FALSE, ...)
fast_mvquantile(x, prob = 0.5, na.rm = FALSE, ...)
fast_mvmedian(x, na.rm = FALSE, ...)Value
fast_quantile and fast_median calculate univariate
quantiles (single-value return); fast_mvquantile and fast_mvmedian
calculate multivariate quantiles (for each column, result lengths equal to
the number of columns).
Examples
fast_quantile(runif(1000), 0.1)
#> [1] 0.1157489
fast_median(1:100)
#> [1] 50.5
x <- matrix(rnorm(100), ncol = 2)
fast_mvquantile(x, 0.2)
#> [1] -0.8980551 -1.1179596
fast_mvmedian(x)
#> [1] -0.3705184 -0.2642868
# Compare speed for vectors (usually 30% faster)
x <- rnorm(10000)
microbenchmark::microbenchmark(
fast_median = fast_median(x),
base_median = median(x),
# bioc_median = Biobase::rowMedians(matrix(x, nrow = 1)),
times = 100, unit = "milliseconds"
)
#> Unit: milliseconds
#> expr min lq mean median uq max neval
#> fast_median 0.098136 0.1471135 0.1593886 0.1633425 0.1750350 0.197082 100
#> base_median 0.104425 0.1168240 0.1476553 0.1350605 0.1706785 0.308288 100
# Multivariate cases
# (5~7x faster than base R)
# (3~5x faster than Biobase rowMedians)
x <- matrix(rnorm(100000), ncol = 20)
microbenchmark::microbenchmark(
fast_median = fast_mvmedian(x),
base_median = apply(x, 2, median),
# bioc_median = Biobase::rowMedians(t(x)),
times = 10, unit = "milliseconds"
)
#> Unit: milliseconds
#> expr min lq mean median uq max neval
#> fast_median 0.703695 0.762132 0.8003162 0.791871 0.854910 0.899046 10
#> base_median 2.888110 2.949471 2.9790870 2.964113 2.978484 3.236728 10