log                   package:base                   R Documentation

_L_o_g_a_r_i_t_h_m_s _a_n_d _E_x_p_o_n_e_n_t_i_a_l_s

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

     'log' computes logarithms, by default natural logarithms,  'log10'
     computes common (i.e., base 10) logarithms, and 'log2' computes
     binary (i.e., base 2) logarithms. The general form 'log(x, base)'
     computes logarithms with base 'base'.

     'log1p(x)' computes log(1+x) accurately also for |x| << 1 (and
     less accurately when x is approximately -1).

     'exp' computes the exponential function.

     'expm1(x)' computes exp(x) - 1 accurately also for |x| << 1.

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

     log(x, base = exp(1))
     logb(x, base = exp(1))
     log10(x)
     log2(x)

     log1p(x)

     exp(x)
     expm1(x)

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

       x: a numeric or complex vector.

    base: a positive or complex number: the base with respect to which
          logarithms are computed.  Defaults to e='exp(1)'.

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

     All except 'logb' are generic functions: methods can be defined
     for them individually or via the 'Math' group generic.

     'log10' and 'log2' are only convenience wrappers, but logs to
     bases 10 and 2 (whether computed _via_ 'log' or the wrappers) will
     be computed more efficiently and accurately where supported by the
     OS. Methods can be set for them individually (and otherwise
     methods for 'log' will be used).

     'logb' is a wrapper for 'log' for compatibility with S.  If (S3 or
     S4) methods are set for 'log' they will be dispatched. Do not set
     S4 methods on 'logb' itself.

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

     A vector of the same length as 'x' containing the transformed
     values.  'log(0)' gives '-Inf', and negative values give 'NaN'.

_S_4 _m_e_t_h_o_d_s:

     'exp', 'expm1', 'log', 'log10', 'log2' and 'log1p' are S4 generic
     and are members of the 'Math' group generic.

     Note that this means that the S4 generic for 'log' has a signature
     with only one argument, 'x', but that 'base' can be passed to
     methods (but will not be used for method selection).  On the other
     hand, if you only set a method for the 'Math' group generic then
     'base' argument of 'log' will be ignored for your class.

_N_o_t_e:

     'log' and 'logb' are the same thing in R, but 'logb' is preferred
     if 'base' is specified, for S-PLUS compatibility.

_S_o_u_r_c_e:

     'log1p' and 'expm1' may be taken from the operating system, but if
     not available there are based on the Fortran subroutine 'dlnrel'
     by W. Fullerton of Los Alamos Scientific Laboratory (see <URL:
     http://www.netlib.org/slatec/fnlib/dlnrel.f> and (for small x) a
     single Newton step for the solution of 'log1p(y) = x'
     respectively.

_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. (for 'log', 'log10' and
     'exp'.)

     Chambers, J. M. (1998) _Programming with Data. A Guide to the S
     Language_. Springer. (for 'logb'.)

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

     'Trig', 'sqrt', 'Arithmetic'.

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

     log(exp(3))
     log10(1e7)# = 7

     x <- 10^-(1+2*1:9)
     cbind(x, log(1+x), log1p(x), exp(x)-1, expm1(x))

