A library for efficient similarity search and clustering of dense vectors.
 
 
 
 
 
 
Go to file
Eduardo Pinho 2bfbead8f1 [C API] Update for compatibility with v1.5 (#858)
* [c_api] Update impl and interface for v1.5

- move IndexShards to dedicated module IndexShards_c.{h|cpp}
- remove getter/setters to unreachable fields
- reimplement faiss_IndexIVF_imbalance_factor (to use invlists)
- minor IndexIVF documentation tweaks
- Remove QueryResult, provide RangeQueryResult

* [c_api] Document FaissErrorCode

* [c_api] Update GPU impl and interface for v1.5

- Remove unavailable method setTempMemoryFraction

* [c_api] Relicense to MIT

In accordance to the rest of the project
2019-06-12 15:46:08 +02:00
.github Update ISSUE_TEMPLATE.md 2018-06-25 16:18:50 -07:00
.travis Add conda packages metadata + tests. (#769) 2019-04-05 11:50:39 +02:00
acinclude Add conda packages metadata + tests. (#769) 2019-04-05 11:50:39 +02:00
benchs Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
build-aux Refactor makefiles and add configure script (#466) 2018-06-02 08:35:30 +02:00
c_api [C API] Update for compatibility with v1.5 (#858) 2019-06-12 15:46:08 +02:00
conda Prepare for v1.5.2 release 2019-05-28 16:22:38 +02:00
demos Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
docs Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
example_makefiles Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
gpu Fix Makefile in gpu/test (#843) 2019-05-29 14:32:05 +02:00
misc Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
python Prepare for v1.5.2 release 2019-05-28 16:22:38 +02:00
tests Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
tutorial Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
.dockerignore
.gitignore Refactor makefiles and add configure script (#466) 2018-06-02 08:35:30 +02:00
.travis.yml Add conda packages metadata + tests. (#769) 2019-04-05 11:50:39 +02:00
AutoTune.cpp Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
AutoTune.h Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
AuxIndexStructures.cpp Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
AuxIndexStructures.h Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
CODE_OF_CONDUCT.md OSS Automated Fix: Addition of Code of Conduct 2019-03-22 11:13:52 -07:00
CONTRIBUTING.md
Clustering.cpp Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
Clustering.h Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
Dockerfile Configure install paths in Dockerfile. (#772) 2019-04-07 23:22:43 +02:00
FaissAssert.h Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
FaissException.cpp Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
FaissException.h Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
HNSW.cpp Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
HNSW.h Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
Heap.cpp Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
Heap.h Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
INSTALL.md Update INSTALL.md 2019-04-11 11:24:35 +02:00
IVFlib.cpp Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
IVFlib.h Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
Index.cpp Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
Index.h Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
IndexBinary.cpp Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
IndexBinary.h Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
IndexBinaryFlat.cpp Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
IndexBinaryFlat.h Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
IndexBinaryFromFloat.cpp Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
IndexBinaryFromFloat.h Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
IndexBinaryHNSW.cpp Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
IndexBinaryHNSW.h Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
IndexBinaryIVF.cpp Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
IndexBinaryIVF.h Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
IndexFlat.cpp Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
IndexFlat.h Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
IndexHNSW.cpp Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
IndexHNSW.h Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
IndexIVF.cpp Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
IndexIVF.h Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
IndexIVFFlat.cpp Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
IndexIVFFlat.h Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
IndexIVFPQ.cpp Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
IndexIVFPQ.h Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
IndexIVFSpectralHash.cpp Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
IndexIVFSpectralHash.h Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
IndexLSH.cpp Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
IndexLSH.h Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
IndexPQ.cpp Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
IndexPQ.h Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
IndexReplicas.cpp Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
IndexReplicas.h Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
IndexScalarQuantizer.cpp Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
IndexScalarQuantizer.h Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
IndexShards.cpp Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
IndexShards.h Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
InvertedLists.cpp Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
InvertedLists.h Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
LICENSE Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
Makefile Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
MetaIndexes.cpp Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
MetaIndexes.h Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
OnDiskInvertedLists.cpp Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
OnDiskInvertedLists.h Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
PolysemousTraining.cpp Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
PolysemousTraining.h Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
ProductQuantizer.cpp Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
ProductQuantizer.h Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
README.md Update README.md (#849) 2019-05-31 21:02:17 +02:00
ThreadedIndex-inl.h Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
ThreadedIndex.h Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
VectorTransform.cpp Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
VectorTransform.h Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
WorkerThread.cpp Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
WorkerThread.h Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
configure Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
configure.ac Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
depend Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
hamming.cpp Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
hamming.h Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
index_io.cpp Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
index_io.h Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
makefile.inc.in Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
utils.cpp Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
utils.h Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00
utils_simd.cpp Facebook sync (May 2019) + relicense (#838) 2019-05-28 16:17:22 +02:00

README.md

Faiss

Faiss is a library for efficient similarity search and clustering of dense vectors. It contains algorithms that search in sets of vectors of any size, up to ones that possibly do not fit in RAM. It also contains supporting code for evaluation and parameter tuning. Faiss is written in C++ with complete wrappers for Python/numpy. Some of the most useful algorithms are implemented on the GPU. It is developed by Facebook AI Research.

NEWS

NEW: version 1.5.2 (2019-05-27) the license was relaxed to MIT from BSD+Patents. Read LICENSE for details.

NEW: version 1.5.0 (2018-12-19) GPU binary flat index and binary HNSW index

NEW: version 1.4.0 (2018-08-30) no more crashes in pure Python code

NEW: version 1.3.0 (2018-07-12) support for binary indexes

NEW: latest commit (2018-02-22) supports on-disk storage of inverted indexes, see demos/demo_ondisk_ivf.py

NEW: latest commit (2018-01-09) includes an implementation of the HNSW indexing method, see benchs/bench_hnsw.py

NEW: there is now a Facebook public discussion group for Faiss users at https://www.facebook.com/groups/faissusers/

NEW: on 2017-07-30, the license on Faiss was relaxed to BSD from CC-BY-NC. Read LICENSE for details.

Introduction

Faiss contains several methods for similarity search. It assumes that the instances are represented as vectors and are identified by an integer, and that the vectors can be compared with L2 distances or dot products. Vectors that are similar to a query vector are those that have the lowest L2 distance or the highest dot product with the query vector. It also supports cosine similarity, since this is a dot product on normalized vectors.

Most of the methods, like those based on binary vectors and compact quantization codes, solely use a compressed representation of the vectors and do not require to keep the original vectors. This generally comes at the cost of a less precise search but these methods can scale to billions of vectors in main memory on a single server.

The GPU implementation can accept input from either CPU or GPU memory. On a server with GPUs, the GPU indexes can be used a drop-in replacement for the CPU indexes (e.g., replace IndexFlatL2 with GpuIndexFlatL2) and copies to/from GPU memory are handled automatically. Results will be faster however if both input and output remain resident on the GPU. Both single and multi-GPU usage is supported.

Building

The library is mostly implemented in C++, with optional GPU support provided via CUDA, and an optional Python interface. The CPU version requires a BLAS library. It compiles with a Makefile and can be packaged in a docker image. See INSTALL.md for details.

How Faiss works

Faiss is built around an index type that stores a set of vectors, and provides a function to search in them with L2 and/or dot product vector comparison. Some index types are simple baselines, such as exact search. Most of the available indexing structures correspond to various trade-offs with respect to

  • search time
  • search quality
  • memory used per index vector
  • training time
  • need for external data for unsupervised training

The optional GPU implementation provides what is likely (as of March 2017) the fastest exact and approximate (compressed-domain) nearest neighbor search implementation for high-dimensional vectors, fastest Lloyd's k-means, and fastest small k-selection algorithm known. The implementation is detailed here.

Full documentation of Faiss

The following are entry points for documentation:

Authors

The main authors of Faiss are:

Reference

Reference to cite when you use Faiss in a research paper:

@article{JDH17,
  title={Billion-scale similarity search with GPUs},
  author={Johnson, Jeff and Douze, Matthijs and J{\'e}gou, Herv{\'e}},
  journal={arXiv preprint arXiv:1702.08734},
  year={2017}
}

Join the Faiss community

For public discussion of Faiss or for questions, there is a Facebook public discussion group at https://www.facebook.com/groups/faissusers/

We monitor the issues page of the repository. You can report bugs, ask questions, etc.

License

Faiss is MIT-licensed.