https://github.com/cran/Matrix
Tip revision: fa5fcbb39f1499e9b06aa67ad7c81f05a86aeeec authored by Doug and Martin on 09 August 2011, 00:00:00 UTC
version 0.9996875-2
version 0.9996875-2
Tip revision: fa5fcbb
rankMatrix.Rd
\name{rankMatrix}
\Rdversion{1.1}
\alias{rankMatrix}
\title{Rank of a Matrix}
\description{
Compute the rank of matrix, a well-defined functional in theory,
somewhat ambigous in practice. We provide several methods, the
default corresponding to Matlab's definition.
}
\usage{
rankMatrix(x, tol = NULL,
method = c("tolNorm2", "qrLINPACK", "useGrad", "maybeGrad"),
sval = svd(x, 0, 0)$d)
}
\arguments{
\item{x}{numeric matrix, of dimension \eqn{n \times m}{n x m}, say.}
\item{tol}{nonnegative number specifying a tolerance for
\dQuote{practically zero} with specific meaning depending on
\code{method}; by default, \code{max(dim(x)) *
\link{.Machine}$double.eps * abs(max(sval))} is according to
Matlab's default (for its only \code{method} "tolNorm2").}
\item{method}{a character string specifying the computational method,
can be abbreviated:
\describe{
\item{tolNorm2}{the number of singular values \code{>= tol};}
\item{qrLINPACK}{= \code{\link{qr}(x, tol, LAPACK=FALSE)$rank};
this used to be \emph{the} recommended way to compute a matrix
rank for a while in the past. For this method, \code{sval} are
not used (nor computed).}
\item{useGrad}{considering the \dQuote{gradient} of the
(decreasing) singular values, the index of the \emph{smallest} gap.}
\item{maybeGrad}{choosing method \code{"useGrad"} only when that
seems \emph{reasonable}; otherwise using \code{"tolNorm2"}.}
%% FIXME say more
}
}
\item{sval}{numeric vector of non-increasing singular values of
\code{x}; typically unspecified and computed from \code{x}.}
}
% \details{
% FIXME
% }
\value{
positive integer in \code{1:min(dim(x))}, with attributes detailing
the method used.
}
% \references{
% %% ~put references to the literature/web site here ~
% }
\author{Martin Maechler; for the "*Grad" methods, building on
suggestions by Ravi Varadhan.
}
\seealso{
\code{\link{qr}}, \code{\link{svd}}.
}
\examples{
rankMatrix(cbind(1, 0, 1:3)) # 2
(meths <- eval(formals(rankMatrix)$method))
## a "border" case:
H12 <- Hilbert(12)
rankMatrix(H12, tol = 1e-20) # 12; but 11 with default method & tol.
sapply(meths, function(.m.) rankMatrix(H12, method = .m.))
## tolNorm2 qrLINPACK useGrad maybeGrad
## 11 12 11 11
}
\keyword{algebra}
\keyword{array}