Title: | Matrix Completion, Imputation, and Inpainting Methods |
---|---|
Description: | Filling in the missing entries of a partially observed data is one of fundamental problems in various disciplines of mathematical science. For many cases, data at our interests have canonical form of matrix in that the problem is posed upon a matrix with missing values to fill in the entries under preset assumptions and models. We provide a collection of methods from multiple disciplines under Matrix Completion, Imputation, and Inpainting. See Davenport and Romberg (2016) <doi:10.1109/JSTSP.2016.2539100> for an overview of the topic. |
Authors: | Kisung You [aut, cre] |
Maintainer: | Kisung You <[email protected]> |
License: | MIT + file LICENSE |
Version: | 0.2.3 |
Built: | 2024-12-12 07:12:50 UTC |
Source: | CRAN |
Filling in the missing entries of a partially observed data is one of fundamental problems in various disciplines of mathematical science. For many cases, data at our interests have canonical form of matrix in that the problem is posed upon a matrix with missing values to fill in the entries under preset assumptions and models. We provide a collection of methods from multiple disciplines under Matrix Completion, Imputation, and Inpainting. Currently, we have following methods implemented,
Name of Function | Method |
fill.HardImpute |
Generalized Spectral Regularization |
fill.KNNimpute |
Weighted -nearest Neighbors |
fill.nuclear |
Nuclear Norm Optimization |
fill.OptSpace |
OptSpace |
fill.simple |
Simple Rules of Mean, Median, and Random |
fill.SoftImpute |
Spectral Regularization |
fill.SVDimpute |
Iterative Regression against Right Singular Vectors |
fill.SVT |
Singular Value Thresholding for Nuclear Norm Optimization |
fill.USVT |
Universal Singular Value Thresholding |
x
aux.rndmissing
randomly selects % of entries from
a given data matrix and turns them into missing entries, i.e., their values
become
NA
.
aux.rndmissing(A, x = 0.1)
aux.rndmissing(A, x = 0.1)
A |
an |
x |
percentage of turning current entries into missing ( |
an data matrix with missing entries at proportion
.
# load lena64 image matrix data(lena64) # generate 10% of missing values lena64_miss <- aux.rndmissing(lena64) # visualize par(mfrow=c(1,2)) image(lena64, axes=FALSE, main="original image") image(lena64_miss, axes=FALSE, main="10% missing entries")
# load lena64 image matrix data(lena64) # generate 10% of missing values lena64_miss <- aux.rndmissing(lena64) # visualize par(mfrow=c(1,2)) image(lena64, axes=FALSE, main="original image") image(lena64_miss, axes=FALSE, main="10% missing entries")
If the assumed underlying model has sufficiently many zeros, the LASSO type
shrinkage estimator is known to overestimate the number of non-zero coefficients.
fill.HardImpute
aims at overcoming such difficulty via low-rank assumption
and hard thresholding idea, well-known concept in conventional regression analysis.
In algorithmic aspect, it takes output of SoftImpute
as warm-start matrices
for iterative estimation process.
fill.HardImpute( A, lambdas = c(10, 1, 0.1), maxiter = 100, tol = 0.001, rk = (min(dim(A)) - 1) )
fill.HardImpute( A, lambdas = c(10, 1, 0.1), maxiter = 100, tol = 0.001, rk = (min(dim(A)) - 1) )
A |
an |
lambdas |
a length- |
maxiter |
maximum number of iterations to be performed. |
tol |
stopping criterion for an incremental progress. |
rk |
assumed rank of the matrix. |
a named list containing
an cubic array after completion at each
lambda
value.
Mazumder R, Hastie T, Tibshirani R (2010). “Spectral Regularization Algorithms for Learning Large Incomplete Matrices.” J. Mach. Learn. Res., 11, 2287–2322. ISSN 1532-4435.
## load image data of 'lena128' data(lena128) ## transform 5% of entries into missing A <- aux.rndmissing(lena128, x=0.05) ## apply the method with 3 rank conditions fill1 <- fill.HardImpute(A, lambdas=c(500,100,50), rk=10) fill2 <- fill.HardImpute(A, lambdas=c(500,100,50), rk=50) fill3 <- fill.HardImpute(A, lambdas=c(500,100,50), rk=100) ## visualize only the last ones from each run opar <- par(no.readonly=TRUE) par(mfrow=c(2,2), pty="s") image(A, col=gray((0:100)/100), axes=FALSE, main="5% missing") image(fill1$X[,,3], col=gray((0:100)/100), axes=FALSE, main="Rank 10") image(fill2$X[,,3], col=gray((0:100)/100), axes=FALSE, main="Rank 50") image(fill3$X[,,3], col=gray((0:100)/100), axes=FALSE, main="Rank 100") par(opar)
## load image data of 'lena128' data(lena128) ## transform 5% of entries into missing A <- aux.rndmissing(lena128, x=0.05) ## apply the method with 3 rank conditions fill1 <- fill.HardImpute(A, lambdas=c(500,100,50), rk=10) fill2 <- fill.HardImpute(A, lambdas=c(500,100,50), rk=50) fill3 <- fill.HardImpute(A, lambdas=c(500,100,50), rk=100) ## visualize only the last ones from each run opar <- par(no.readonly=TRUE) par(mfrow=c(2,2), pty="s") image(A, col=gray((0:100)/100), axes=FALSE, main="5% missing") image(fill1$X[,,3], col=gray((0:100)/100), axes=FALSE, main="Rank 10") image(fill2$X[,,3], col=gray((0:100)/100), axes=FALSE, main="Rank 50") image(fill3$X[,,3], col=gray((0:100)/100), axes=FALSE, main="Rank 100") par(opar)
One of the simplest idea to guess missing entry is to use
portion of the data that has most similar characteristics across
all covariates. fill.KNNimpute
follows such reasoning in that
it finds -nearest neighbors based on observed variables and
uses weighted average of nearest elements to fill in the missing entry.
Note that when there are many missing entries, it's possible that there are
no surrogates to be computed upon. Therefore, if there exists an entire
row or column full of missing entries, the algorithm stops.
fill.KNNimpute(A, k = ceiling(nrow(A)/2))
fill.KNNimpute(A, k = ceiling(nrow(A)/2))
A |
an |
k |
the number of neighbors to use. |
a named list containing
an matrix after completion.
Troyanskaya O, Cantor M, Sherlock G, Brown P, Hastie T, Tibshirani R, Botstein D, Altman RB (2001). “Missing value estimation methods for DNA microarrays.” Bioinformatics, 17(6), 520–525. ISSN 1367-4803.
## load image data of 'lena128' data(lena128) ## transform 5% of entries into missing set.seed(5) A <- aux.rndmissing(lena128, x=0.05) ## apply the method with 3 different neighborhood size fill1 <- fill.KNNimpute(A, k=5) fill2 <- fill.KNNimpute(A, k=25) fill3 <- fill.KNNimpute(A, k=50) ## visualize only the last ones from each run opar <- par(no.readonly=TRUE) par(mfrow=c(2,2), pty="s") image(A, col=gray((0:100)/100), axes=FALSE, main="5% missing") image(fill1$X, col=gray((0:100)/100), axes=FALSE, main="5-neighbor") image(fill2$X, col=gray((0:100)/100), axes=FALSE, main="25-neighbor") image(fill3$X, col=gray((0:100)/100), axes=FALSE, main="50-neighbor") par(opar)
## load image data of 'lena128' data(lena128) ## transform 5% of entries into missing set.seed(5) A <- aux.rndmissing(lena128, x=0.05) ## apply the method with 3 different neighborhood size fill1 <- fill.KNNimpute(A, k=5) fill2 <- fill.KNNimpute(A, k=25) fill3 <- fill.KNNimpute(A, k=50) ## visualize only the last ones from each run opar <- par(no.readonly=TRUE) par(mfrow=c(2,2), pty="s") image(A, col=gray((0:100)/100), axes=FALSE, main="5% missing") image(fill1$X, col=gray((0:100)/100), axes=FALSE, main="5-neighbor") image(fill2$X, col=gray((0:100)/100), axes=FALSE, main="25-neighbor") image(fill3$X, col=gray((0:100)/100), axes=FALSE, main="50-neighbor") par(opar)
In many circumstances, it is natural to assume that there exists an underlying low-rank structure. The assumption of low-rank property leads to an optimization problem for matrix completion problem,
where means the
-th entry of data matrix
is not missing. The objective
function can be further relaxed by nuclear norm
where is
-th singular value of the matrix
. Note that
for modeling purpose, we adopted closeness parameter
tolerance
for equality constraint.
CVXR package was used in implementation. Computational efficiency may not be guaranteed for large data matrix.
fill.nuclear(A, tolerance = 0.001)
fill.nuclear(A, tolerance = 0.001)
A |
an |
tolerance |
level of tolerance for entrywise equality condition. |
a named list containing
an matrix after completion.
solution of the minimization problem; approximate rank.
“optimal” denotes the problem was solved. See psolve
for more details on solvability.
the number of iterations taken.
type of solver used by CVXR.
Candès EJ, Recht B (2009). “Exact Matrix Completion via Convex Optimization.” Foundations of Computational Mathematics, 9(6), 717–772. ISSN 1615-3375, 1615-3383.
## Not run: ## load image data of 'lena64' data(lena64) ## transform 5% of entries into missing A <- aux.rndmissing(lena64, x=0.05) ## apply the method filled <- fill.nuclear(A) ## visualize opar <- par(no.readonly=TRUE) par(mfrow=c(1,2), pty="s") image(A, col=gray((0:100)/100), axes=FALSE, main="5% missing") image(filled$X, col=gray((0:100)/100), axes=FALSE, main="processed") par(opar) ## End(Not run)
## Not run: ## load image data of 'lena64' data(lena64) ## transform 5% of entries into missing A <- aux.rndmissing(lena64, x=0.05) ## apply the method filled <- fill.nuclear(A) ## visualize opar <- par(no.readonly=TRUE) par(mfrow=c(1,2), pty="s") image(A, col=gray((0:100)/100), axes=FALSE, main="5% missing") image(filled$X, col=gray((0:100)/100), axes=FALSE, main="processed") par(opar) ## End(Not run)
OptSpace is an algorithm for matrix completion when a matrix is partially observed. It
performs what authors called trimming and projection repeatedly based on
singular value decompositions. Original implementation is borrowed from ROptSpace package,
which was independently developed by the maintainer. See OptSpace
for more details.
fill.OptSpace(A, ropt = NA, niter = 50, tol = 1e-06)
fill.OptSpace(A, ropt = NA, niter = 50, tol = 1e-06)
A |
an |
ropt |
|
niter |
maximum number of iterations allowed. |
tol |
stopping criterion for reconstruction in Frobenius norm. |
a named list containing
an matrix after completion.
a vector of reconstruction errors for each successive iteration.
Keshavan RH, Montanari A, Oh S (2010). “Matrix Completion From a Few Entries.” IEEE Transactions on Information Theory, 56(6), 2980–2998. ISSN 0018-9448.
## Not run: ## load image data of 'lena64' data(lena64) ## transform 5% of entries into missing A <- aux.rndmissing(lena64, x=0.05) ## apply the method with different rank assumptions filled10 <- fill.OptSpace(A, ropt=10) filled20 <- fill.OptSpace(A, ropt=20) ## visualize opar <- par(no.readonly=TRUE) par(mfrow=c(1,3), pty="s") image(A, col=gray((0:100)/100), axes=FALSE, main="5% missing") image(filled10$X, col=gray((0:100)/100), axes=FALSE, main="rank 10") image(filled20$X, col=gray((0:100)/100), axes=FALSE, main="rank 20") par(opar) ## End(Not run)
## Not run: ## load image data of 'lena64' data(lena64) ## transform 5% of entries into missing A <- aux.rndmissing(lena64, x=0.05) ## apply the method with different rank assumptions filled10 <- fill.OptSpace(A, ropt=10) filled20 <- fill.OptSpace(A, ropt=20) ## visualize opar <- par(no.readonly=TRUE) par(mfrow=c(1,3), pty="s") image(A, col=gray((0:100)/100), axes=FALSE, main="5% missing") image(filled10$X, col=gray((0:100)/100), axes=FALSE, main="rank 10") image(filled20$X, col=gray((0:100)/100), axes=FALSE, main="rank 20") par(opar) ## End(Not run)
One of the most simplest ways to fill in the missing entries is
to apply any simple rule for each variable. In this example, we provide
3 options, "mean"
, "median"
, and "random"
. It assumes
that every column has at least one non-missing entries in that for each column,
the rule is applied from the subset of non-missing values.
fill.simple(A, method = c("mean", "median", "random"))
fill.simple(A, method = c("mean", "median", "random"))
A |
an |
method |
simple rule to fill in the missing entries in a columnwise manner. |
a named list containing
an matrix after completion.
Gelman A, Hill J (2007). Data analysis using regression and multilevel/hierarchical models, Analytical methods for social research. Cambridge University Press, Cambridge ; New York. ISBN 978-0-521-86706-1 978-0-521-68689-1, OCLC: ocm67375137.
## load image data of 'lena128' data(lena128) ## transform 5% of entries into missing A <- aux.rndmissing(lena128, x=0.05) ## apply all three methods#' fill1 <- fill.simple(A, method="mean") fill2 <- fill.simple(A, method="median") fill3 <- fill.simple(A, method="random") ## visualize opar <- par(no.readonly=TRUE) par(mfrow=c(2,2), pty="s") image(A, col=gray((0:100)/100), axes=FALSE, main="original") image(fill1$X, col=gray((0:100)/100), axes=FALSE, main="method:mean") image(fill2$X, col=gray((0:100)/100), axes=FALSE, main="method:median") image(fill3$X, col=gray((0:100)/100), axes=FALSE, main="method:random") par(opar)
## load image data of 'lena128' data(lena128) ## transform 5% of entries into missing A <- aux.rndmissing(lena128, x=0.05) ## apply all three methods#' fill1 <- fill.simple(A, method="mean") fill2 <- fill.simple(A, method="median") fill3 <- fill.simple(A, method="random") ## visualize opar <- par(no.readonly=TRUE) par(mfrow=c(2,2), pty="s") image(A, col=gray((0:100)/100), axes=FALSE, main="original") image(fill1$X, col=gray((0:100)/100), axes=FALSE, main="method:mean") image(fill2$X, col=gray((0:100)/100), axes=FALSE, main="method:median") image(fill3$X, col=gray((0:100)/100), axes=FALSE, main="method:random") par(opar)
fill.SoftImpute
implements convex relaxation techniques to generate
a sequence of regularized low-rank solutions for matrix completion problems.
For the nuclear norm optimization problem, it uses soft thresholding technique
iteratively in that the algorithm returns several matrices in accordance with
the provided vector of regularization parameters (
lambdas
).
fill.SoftImpute(A, lambdas = c(10, 1, 0.1), maxiter = 100, tol = 0.001)
fill.SoftImpute(A, lambdas = c(10, 1, 0.1), maxiter = 100, tol = 0.001)
A |
an |
lambdas |
a length- |
maxiter |
maximum number of iterations to be performed. |
tol |
stopping criterion for an incremental progress. |
a named list containing
an cubic array after completion at each
lambda
value.
Mazumder R, Hastie T, Tibshirani R (2010). “Spectral Regularization Algorithms for Learning Large Incomplete Matrices.” J. Mach. Learn. Res., 11, 2287–2322. ISSN 1532-4435.
## load image data of 'lena128' data(lena128) ## transform 5% of entries into missing A <- aux.rndmissing(lena128, x=0.05) ## apply the method with 3 lambda values fill <- fill.SoftImpute(A, lambdas=c(500,100,50)) ## visualize opar <- par(no.readonly=TRUE) par(mfrow=c(2,2), pty="s") image(A, col=gray((0:100)/100), axes=FALSE, main="5% missing") image(fill$X[,,1], col=gray((0:100)/100), axes=FALSE, main="lambda=500") image(fill$X[,,2], col=gray((0:100)/100), axes=FALSE, main="lambda=100") image(fill$X[,,3], col=gray((0:100)/100), axes=FALSE, main="lambda=50") par(opar)
## load image data of 'lena128' data(lena128) ## transform 5% of entries into missing A <- aux.rndmissing(lena128, x=0.05) ## apply the method with 3 lambda values fill <- fill.SoftImpute(A, lambdas=c(500,100,50)) ## visualize opar <- par(no.readonly=TRUE) par(mfrow=c(2,2), pty="s") image(A, col=gray((0:100)/100), axes=FALSE, main="5% missing") image(fill$X[,,1], col=gray((0:100)/100), axes=FALSE, main="lambda=500") image(fill$X[,,2], col=gray((0:100)/100), axes=FALSE, main="lambda=100") image(fill$X[,,3], col=gray((0:100)/100), axes=FALSE, main="lambda=50") par(opar)
Singular Value Decomposition (SVD) is the best low-rank approximation of a given matrix.
fill.SVDimpute
exploits such idea. First, it starts with simple filling using
column mean values for filling. Second, it finds SVD of a current matrix. Then,
each row vector is regressed upon top- right singular vectors. Missing entries are
then filled with predicted estimates.
fill.SVDimpute(A, k = ceiling(ncol(A)/2), maxiter = 100, tol = 0.01)
fill.SVDimpute(A, k = ceiling(ncol(A)/2), maxiter = 100, tol = 0.01)
A |
an |
k |
the number of regressors to be used. |
maxiter |
maximum number of iterations to be performed. |
tol |
stopping criterion for an incremental progress. |
a named list containing
an matrix after completion.
Troyanskaya O, Cantor M, Sherlock G, Brown P, Hastie T, Tibshirani R, Botstein D, Altman RB (2001). “Missing value estimation methods for DNA microarrays.” Bioinformatics, 17(6), 520–525. ISSN 1367-4803.
## Not run: ## load image data of 'lena128' data(lena128) ## transform 5% of entries into missing set.seed(5) A <- aux.rndmissing(lena128, x=0.05) ## apply the method with 3 different number of regressors fill1 <- fill.SVDimpute(A, k=5) fill2 <- fill.SVDimpute(A, k=25) fill3 <- fill.SVDimpute(A, k=50) ## visualize only the last ones from each run opar <- par(no.readonly=TRUE) par(mfrow=c(2,2), pty="s") image(A, col=gray((0:100)/100), axes=FALSE, main="5% missing") image(fill1$X, col=gray((0:100)/100), axes=FALSE, main="5 regressors") image(fill2$X, col=gray((0:100)/100), axes=FALSE, main="25 regressors") image(fill3$X, col=gray((0:100)/100), axes=FALSE, main="50 regressors") par(opar) ## End(Not run)
## Not run: ## load image data of 'lena128' data(lena128) ## transform 5% of entries into missing set.seed(5) A <- aux.rndmissing(lena128, x=0.05) ## apply the method with 3 different number of regressors fill1 <- fill.SVDimpute(A, k=5) fill2 <- fill.SVDimpute(A, k=25) fill3 <- fill.SVDimpute(A, k=50) ## visualize only the last ones from each run opar <- par(no.readonly=TRUE) par(mfrow=c(2,2), pty="s") image(A, col=gray((0:100)/100), axes=FALSE, main="5% missing") image(fill1$X, col=gray((0:100)/100), axes=FALSE, main="5 regressors") image(fill2$X, col=gray((0:100)/100), axes=FALSE, main="25 regressors") image(fill3$X, col=gray((0:100)/100), axes=FALSE, main="50 regressors") par(opar) ## End(Not run)
fill.SVT
is an iterative updating scheme for Nuclear Norm Minimization problem. An unconstrained
parahrase of the problem introduced in fill.nuclear
is
where if it is observed, or
otherwise.
It performs iterative shrinkage on newly computed singular values.
fill.SVT(A, lambda = 1, maxiter = 100, tol = 0.001)
fill.SVT(A, lambda = 1, maxiter = 100, tol = 0.001)
A |
an |
lambda |
a regularization parameter. |
maxiter |
maximum number of iterations to be performed. |
tol |
stopping criterion for an incremental progress. |
a named list containing
an matrix after completion.
Cai J, Candès EJ, Shen Z (2010). “A Singular Value Thresholding Algorithm for Matrix Completion.” SIAM Journal on Optimization, 20(4), 1956–1982. ISSN 1052-6234, 1095-7189.
## Not run: ## load image data of 'lena128' data(lena128) ## transform 5% of entries into missing A <- aux.rndmissing(lena128, x=0.05) ## apply the method fill1 <- fill.SVT(A, lambda=0.1) fill2 <- fill.SVT(A, lambda=1.0) fill3 <- fill.SVT(A, lambda=20) ## visualize opar <- par(no.readonly=TRUE) par(mfrow=c(2,2), pty="s") image(A, col=gray((0:100)/100), axes=FALSE, main="5% missing") image(fill1$X, col=gray((0:100)/100), axes=FALSE, main="lbd=0.1") image(fill2$X, col=gray((0:100)/100), axes=FALSE, main="lbd=1") image(fill3$X, col=gray((0:100)/100), axes=FALSE, main="lbd=10") par(opar) ## End(Not run)
## Not run: ## load image data of 'lena128' data(lena128) ## transform 5% of entries into missing A <- aux.rndmissing(lena128, x=0.05) ## apply the method fill1 <- fill.SVT(A, lambda=0.1) fill2 <- fill.SVT(A, lambda=1.0) fill3 <- fill.SVT(A, lambda=20) ## visualize opar <- par(no.readonly=TRUE) par(mfrow=c(2,2), pty="s") image(A, col=gray((0:100)/100), axes=FALSE, main="5% missing") image(fill1$X, col=gray((0:100)/100), axes=FALSE, main="lbd=0.1") image(fill2$X, col=gray((0:100)/100), axes=FALSE, main="lbd=1") image(fill3$X, col=gray((0:100)/100), axes=FALSE, main="lbd=10") par(opar) ## End(Not run)
fill.USVT
is a matrix estimation method suitable for low-rank structure. In the context of
our package, we provide this method under the matrix completion problem category. It aims at
exploiting the idea of thresholding the singular values to minimize the mean-squared error, defined as
where is an
matrix with some missing values and
is an estimate.
fill.USVT(A, eta = 0.01)
fill.USVT(A, eta = 0.01)
A |
an |
eta |
control for thresholding |
a named list containing
an estimated matrix after completion, which is
in the equation above.
Chatterjee S (2015). “Matrix estimation by Universal Singular Value Thresholding.” Ann. Statist., 43(1), 177–214.
## Not run: ## load image data of 'lena128' data(lena128) ## transform 5% of entries into missing set.seed(5) A <- aux.rndmissing(lena128, x=0.05) ## apply the method with 3 different control 'eta' fill1 <- fill.USVT(A, eta=0.01) fill2 <- fill.USVT(A, eta=0.5) fill3 <- fill.USVT(A, eta=0.99) ## visualize only the last ones from each run opar <- par(no.readonly=TRUE) par(mfrow=c(2,2), pty="s") image(A, col=gray((0:100)/100), axes=FALSE, main="5% missing") image(fill1$X, col=gray((0:100)/100), axes=FALSE, main="eta=0.01") image(fill2$X, col=gray((0:100)/100), axes=FALSE, main="eta=0.5") image(fill3$X, col=gray((0:100)/100), axes=FALSE, main="eta=0.99") par(opar) ## End(Not run)
## Not run: ## load image data of 'lena128' data(lena128) ## transform 5% of entries into missing set.seed(5) A <- aux.rndmissing(lena128, x=0.05) ## apply the method with 3 different control 'eta' fill1 <- fill.USVT(A, eta=0.01) fill2 <- fill.USVT(A, eta=0.5) fill3 <- fill.USVT(A, eta=0.99) ## visualize only the last ones from each run opar <- par(no.readonly=TRUE) par(mfrow=c(2,2), pty="s") image(A, col=gray((0:100)/100), axes=FALSE, main="5% missing") image(fill1$X, col=gray((0:100)/100), axes=FALSE, main="eta=0.01") image(fill2$X, col=gray((0:100)/100), axes=FALSE, main="eta=0.5") image(fill3$X, col=gray((0:100)/100), axes=FALSE, main="eta=0.99") par(opar) ## End(Not run)
Lena is probably one of the most well-known example in image processing and computer vision.
data(lena128)
data(lena128)
matrix of size
USC SIPI Image Database.
Gonzalez, Rafael C. and Woods, Richard E. (2017) Digital Image Processing (4th ed.). ISBN 0133356728.
data(lena128) image(lena128, col=gray((0:100)/100), axes=FALSE, main="lena128")
data(lena128) image(lena128, col=gray((0:100)/100), axes=FALSE, main="lena128")
Lena is probably one of the most well-known example in image processing and computer vision.
data(lena256)
data(lena256)
matrix of size
USC SIPI Image Database.
Gonzalez, Rafael C. and Woods, Richard E. (2017) Digital Image Processing (4th ed.). ISBN 0133356728.
data(lena256) image(lena256, col=gray((0:100)/100), axes=FALSE, main="lena256")
data(lena256) image(lena256, col=gray((0:100)/100), axes=FALSE, main="lena256")
Lena is probably one of the most well-known example in image processing and computer vision.
data(lena64)
data(lena64)
matrix of size
USC SIPI Image Database.
Gonzalez, Rafael C. and Woods, Richard E. (2017) Digital Image Processing (4th ed.). ISBN 0133356728.
data(lena64) image(lena64, col=gray((0:100)/100), axes=FALSE, main="lena64")
data(lena64) image(lena64, col=gray((0:100)/100), axes=FALSE, main="lena64")