rank                  package:base                  R Documentation

_S_a_m_p_l_e _R_a_n_k_s

_D_e_s_c_r_i_p_t_i_o_n:

     Returns the sample ranks of the values in a numeric vector. Ties,
     i.e., equal values, result in ranks being averaged, by default.

_U_s_a_g_e:

     rank(x, na.last = TRUE, ties.method = c("average", "first", "random"))

_A_r_g_u_m_e_n_t_s:

       x: a numeric vector.

 na.last: for controlling the treatment of 'NA's. If 'TRUE', missing
          values in the data are put last; if 'FALSE', they are put
          first; if 'NA', they are removed; if '"keep"' they are kept.

ties.method: a character string specifying how ties are treated, see
          below; can be abbreviated.

_D_e_t_a_i_l_s:

     If all components are different, the ranks are well defined, with
     values in '1:n' where 'n <- length(x)' and we assume no 'NA's for
     the moment.  Otherwise, with some values equal, called 'ties', the
     argument 'ties.method' determines the result at the corresponding
     indices.  The '"first"' method results in a permutation with
     increasing values at each index set of ties.  The '"random"'
     method puts these in random order whereas the default,
     '"average"', replaces them by their mean.

_R_e_f_e_r_e_n_c_e_s:

     Becker, R. A., Chambers, J. M. and Wilks, A. R. (1988) _The New S
     Language_. Wadsworth & Brooks/Cole.

_S_e_e _A_l_s_o:

     'order' and 'sort'.

_E_x_a_m_p_l_e_s:

     (r1 <- rank(x1 <- c(3, 1, 4, 15, 92)))
     x2 <- c(3, 1, 4, 1, 5, 9, 2, 6, 5, 3, 5)
     names(x2) <- letters[1:11]
     (r2 <- rank(x2)) # ties are averaged

     ## rank() is "idempotent": rank(rank(x)) == rank(x) :
     stopifnot(rank(r1) == r1, rank(r2) == r2)

     ## ranks without averaging
     rank(x2, ties.method= "first")  # first occurrence wins
     rank(x2, ties.method= "random") # ties broken at random
     rank(x2, ties.method= "random") # and again

