rep                   package:base                   R Documentation

_R_e_p_l_i_c_a_t_e _E_l_e_m_e_n_t_s _o_f _V_e_c_t_o_r_s _a_n_d _L_i_s_t_s

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

     'rep' replicates the values in 'x'.  It is a generic function, and
     the (internal) default method is described here.

     'rep.int' is a faster simplified version for the most common case.

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

     rep(x, ...)

     rep.int(x, times)

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

       x: a vector (of any mode including a list) or a pairlist or a
          factor or (except for 'rep.int') a 'POSIXct' or 'POSIXlt' or
          'date' object.

     ...: further arguments to be passed to or from other methods. For
          the internal default method these can include:

          '_t_i_m_e_s' A vector giving the number of times to repeat each
               element if of length 'length(x)', or to repeat the whole
               vector if of length 1.

          '_l_e_n_g_t_h._o_u_t' non-negative integer. The desired length of the
               output vector.  Ignored if 'NA' or invalid.

          '_e_a_c_h' non-negative integer.  Each element of 'x' is repeated
               'each' times.  Treated as '1' if 'NA' or invalid.

   times: see '...'.

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

     The default behaviour is as if the call was 'rep(x, times=1,
     length.out=NA, each=1)'.  Normally just one of the additional
     arguments is specified, but if 'each' is specified with either of
     the other two, its replication is performed first, and then that
     implied by 'times' or 'length.out'.

     If 'times' consists of a single integer, the result consists of
     the whole input repeated this many times.  If 'times' is a vector
     of the same length as 'x' (after replication by 'each'), the
     result consists of 'x[1]' repeated 'times[1]' times, 'x[2]'
     repeated 'times[2]' times and so on.

     'length.out' may be given in place of 'times', in which case 'x'
     is repeated as many times as is necessary to create a vector of
     this length.  If both are given, 'length.out' takes priority and
     'times' is ignored.

     Non-integer values of 'times' will be truncated towards zero. If
     'times' is a computed quantity it is prudent to add a small fuzz.

     If 'x' has length zero and 'length.out' is supplied and is
     positive, the values are filled in using the extraction rules,
     that is by an 'NA' of the appropriate class for an atomic vector
     ('0' for raw vectors) and 'NULL' for a list.

_V_a_l_u_e:

     An object of the same type as 'x' (except that 'rep' will coerce
     pairlists to vector lists).

     'rep.int' returns no attributes.

     The default method of 'rep' gives the result names (which will
     almost always contain duplicates) if 'x' had names, but retains no
     other attributes except for factors.

_N_o_t_e:

     Function 'rep.int' is a simple case handled by internal code, and
     provided as a separate function purely for S compatibility.

     Function 'rep' is a primitive, but (partial) matching of argument
     names is performed as for normal functions. You can no longer pass
     a missing argument to. e.g. 'length.out'.

_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:

     'seq', 'sequence', 'replicate'.

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

     rep(1:4, 2)
     rep(1:4, each = 2)       # not the same.
     rep(1:4, c(2,2,2,2))     # same as second.
     rep(1:4, c(2,1,2,1))
     rep(1:4, each = 2, len = 4)    # first 4 only.
     rep(1:4, each = 2, len = 10)   # 8 integers plus two recycled 1's.
     rep(1:4, each = 2, times = 3)  # length 24, 3 complete replications

     rep(1, 40*(1-.8)) # length 7 on most platforms
     rep(1, 40*(1-.8)+1e-7) # better

     ## replicate a list
     fred <- list(happy = 1:10, name = "squash")
     rep(fred, 5)

     # date-time objects
     x <- .leap.seconds[1:3]
     rep(x, 2)
     rep(as.POSIXlt(x), rep(2, 3))

     ## named factor
     x <- factor(LETTERS[1:4]); names(x) <- letters[1:4]
     x
     rep(x, 2)
     rep(x, each=2)
     rep.int(x, 2)  # no names

