% File src/library/base/man/kappa.Rd % Part of the R package, http://www.R-project.org % Copyright 1995-2007 R Core Development Team % Distributed under GPL 2 or later \name{kappa} \title{Estimate the Condition Number} \usage{ kappa(z, \dots) \method{kappa}{lm}(z, \dots) \method{kappa}{default}(z, exact = FALSE, \dots) \method{kappa}{qr}(z, \dots) kappa.tri(z, exact = FALSE, \dots) } \alias{kappa} \alias{kappa.default} \alias{kappa.lm} \alias{kappa.qr} \alias{kappa.tri} \arguments{ \item{z}{A matrix or a the result of \code{\link{qr}} or a fit from a class inheriting from \code{"lm"}.} \item{exact}{logical. Should the result be exact?} \item{\dots}{further arguments passed to or from other methods.} } \description{ An estimate of the condition number of a matrix or of the \eqn{R} matrix of a \eqn{QR} decomposition, perhaps of a linear fit. The condition number is defined as the ratio of the largest to the smallest \emph{non-zero} singular value of the matrix. } \details{ If \code{exact = FALSE} (the default) the condition number is estimated by a cheap approximation. Following S, this uses the LINPACK routine \file{dtrco.f}. However, in \R (or S) the exact calculation is also likely to be quick enough. \code{kappa.tri} is an internal function called by \code{kappa.qr}. } \value{ The condition number, \eqn{kappa}, or an approximation if \code{exact = FALSE}. } \references{ Chambers, J. M. (1992) \emph{Linear models.} Chapter 4 of \emph{Statistical Models in S} eds J. M. Chambers and T. J. Hastie, Wadsworth \& Brooks/Cole. } \author{ The design was inspired by (but differs considerably from) the S function of the same name described in Chambers (1992). } \seealso{ \code{\link{svd}} for the singular value decomposition and \code{\link{qr}} for the \eqn{QR} one. } \examples{ kappa(x1 <- cbind(1,1:10))# 15.71 kappa(x1, exact = TRUE) # 13.68 kappa(x2 <- cbind(x1,2:11))# high! [x2 is singular!] hilbert <- function(n) { i <- 1:n; 1 / outer(i - 1, i, "+") } sv9 <- svd(h9 <- hilbert(9))$ d kappa(h9)# pretty high! kappa(h9, exact = TRUE) == max(sv9) / min(sv9) kappa(h9, exact = TRUE) / kappa(h9) # .677 (i.e., rel.error = 32\%) } \keyword{math}