An R implementation of the Uniform Manifold Approximation and Projection (UMAP) method for dimensionality reduction of McInnes et al. (2018). Also included are the supervised and metric (out-of-sample) learning extensions to the basic method. Translated from the Python implementation.
February 24 2025 uwot
version 0.2.3 has been released to CRAN. This release mainly fixes some bugs, including one that was causing an error with an upcoming version of R-devel. One new feature: set rng_type = "deterministic"
to use a deterministic sampling of vertices during the optimization phase which will give faster and more reproducible output at the cost of accuracy. The idea for this came straight from Leland McInnes via Reddit.
April 21 2024 As ordained by prophecy, version 0.2.2 of uwot
has been released to CRAN. RSpectra
is back as a main dependency and I thought I had worked out a clever scheme to avoid the failures seen in some installations with the irlba
/Matrix
interactions. This releases fixes the problem on all the systems I have access to (including GitHub Actions CI) but some CRAN checks remain failing. How embarrassing. That said, if you have had issues, it's possible this new release will help you too.
uwot
makes use of C++ code which must be compiled. You may have to carry out a few extra steps before being able to build this package:
Windows: install Rtools and ensure C:\Rtools\bin
is on your path.
Mac OS X: using a custom ~/.R/Makevars
may cause linking errors. This sort of thing is a potential problem on all platforms but seems to bite Mac owners more. The R for Mac OS X FAQ may be helpful here to work out what you can get away with. To be on the safe side, I would advise building uwot
without a custom Makevars
.
install.packages("devtools") devtools::install_github("jlmelville/uwot")
library(uwot) # umap2 is a version of the umap() function with better defaults iris_umap <- umap2(iris) # but you can still use the umap function (which most of the existing # documentation does) iris_umap <- umap(iris) # Load mnist from somewhere, e.g. # devtools::install_github("jlmelville/snedata") # mnist <- snedata::download_mnist() mnist_umap <- umap(mnist, n_neighbors = 15, min_dist = 0.001, verbose = TRUE) plot( mnist_umap, cex = 0.1, col = grDevices::rainbow(n = length(levels(mnist$Label)))[as.integer(mnist$Label)] |> grDevices::adjustcolor(alpha.f = 0.1), main = "R uwot::umap", xlab = "", ylab = "" ) # I recommend the following optional packages # for faster or more flexible nearest neighbor search: install.packages(c("RcppHNSW", "rnndescent")) library(RcppHNSW) library(rnndescent) # Installing RcppHNSW will allow the use of the usually faster HNSW method: mnist_umap_hnsw <- umap(mnist, n_neighbors = 15, min_dist = 0.001, nn_method = "hnsw") # nndescent is also available mnist_umap_nnd <- umap(mnist, n_neighbors = 15, min_dist = 0.001, nn_method = "nndescent") # umap2 will choose HNSW by default if available mnist_umap2 <- umap2(mnist)
https://jlmelville.github.io/uwot/. For more examples see the get started doc. There are plenty of articles describing various aspects of the package.
If you want to cite the use of uwot, then use the output of running citation("uwot")
(you can do this with any R package).
uwot
's arrival on CRAN.uwot
uses the RcppProgress package to show a text-based progress bar when verbose = TRUE
.RetroSearch is an open source project built by @garambo | Open a GitHub Issue
Search and Browse the WWW like it's 1997 | Search results from DuckDuckGo
HTML:
3.2
| Encoding:
UTF-8
| Version:
0.7.4