#include <IndexIVFPQ.h>
 
  
 | Public Types | |
| enum | Alloc_type_t { Alloc_type_none, Alloc_type_new, Alloc_type_mmap } | 
| how were the compact tables allocated?  More... | |
|  Public Types inherited from faiss::Index | |
| typedef long | idx_t | 
| all indices are this type | |
| Public Member Functions | |
| IndexIVFPQCompact (const IndexIVFPQ &other) | |
| void | search_preassigned (idx_t n, const float *x, idx_t k, const idx_t *assign, const float *centroid_dis, float *distances, idx_t *labels, bool store_pairs) const override | 
| void | add (idx_t, const float *) override | 
| the three following functions will fail at runtime | |
| void | reset () override | 
| removes all elements from the database. | |
| void | train (idx_t, const float *) override | 
| Trains the quantizer and calls train_residual to train sub-quantizers. | |
|  Public Member Functions inherited from faiss::IndexIVFPQ | |
| IndexIVFPQ (Index *quantizer, size_t d, size_t nlist, size_t M, size_t nbits_per_idx) | |
| void | add_with_ids (idx_t n, const float *x, const long *xids=nullptr) override | 
| void | add_core_o (idx_t n, const float *x, const long *xids, float *residuals_2, const long *precomputed_idx=nullptr) | 
| void | train_residual (idx_t n, const float *x) override | 
| trains the product quantizer | |
| void | train_residual_o (idx_t n, const float *x, float *residuals_2) | 
| same as train_residual, also output 2nd level residuals | |
| void | reconstruct_from_offset (long list_no, long offset, float *recons) const override | 
| size_t | find_duplicates (idx_t *ids, size_t *lims) const | 
| void | encode (long key, const float *x, uint8_t *code) const | 
| void | encode_multiple (size_t n, long *keys, const float *x, uint8_t *codes, bool compute_keys=false) const | 
| void | decode_multiple (size_t n, const long *keys, const uint8_t *xcodes, float *x) const | 
| inverse of encode_multiple | |
| void | precompute_table () | 
| build precomputed table  More... | |
|  Public Member Functions inherited from faiss::IndexIVF | |
| IndexIVF (Index *quantizer, size_t d, size_t nlist, MetricType metric=METRIC_L2) | |
| virtual void | search (idx_t n, const float *x, idx_t k, float *distances, idx_t *labels) const override | 
| void | reconstruct (idx_t key, float *recons) const override | 
| void | reconstruct_n (idx_t i0, idx_t ni, float *recons) const override | 
| void | search_and_reconstruct (idx_t n, const float *x, idx_t k, float *distances, idx_t *labels, float *recons) const override | 
| long | remove_ids (const IDSelector &sel) override | 
| Dataset manipulation functions. | |
| virtual void | merge_from (IndexIVF &other, idx_t add_id) | 
| virtual void | copy_subset_to (IndexIVF &other, int subset_type, long a1, long a2) const | 
| size_t | get_list_size (size_t list_no) const | 
| void | make_direct_map (bool new_maintain_direct_map=true) | 
| double | imbalance_factor () const | 
| 1= perfectly balanced, >1: imbalanced | |
| void | print_stats () const | 
| display some stats about the inverted lists | |
|  Public Member Functions inherited from faiss::Index | |
| Index (idx_t d=0, MetricType metric=METRIC_L2) | |
| virtual void | range_search (idx_t n, const float *x, float radius, RangeSearchResult *result) const | 
| void | assign (idx_t n, const float *x, idx_t *labels, idx_t k=1) | 
| void | compute_residual (const float *x, float *residual, idx_t key) const | 
| void | display () const | 
|  Public Member Functions inherited from faiss::Level1Quantizer | |
| void | train_q1 (size_t n, const float *x, bool verbose, MetricType metric_type) | 
| Trains the quantizer and calls train_residual to train sub-quantizers. | |
| Level1Quantizer (Index *quantizer, size_t nlist) | |
| Public Attributes | |
| Alloc_type_t | alloc_type | 
| uint32_t * | limits | 
| size nlist + 1 | |
| uint32_t * | compact_ids | 
| size ntotal | |
| uint8_t * | compact_codes | 
| size ntotal * code_size | |
| char * | mmap_buffer | 
| long | mmap_length | 
|  Public Attributes inherited from faiss::IndexIVFPQ | |
| bool | by_residual | 
| Encode residual or plain vector? | |
| int | use_precomputed_table | 
| if by_residual, build precompute tables | |
| ProductQuantizer | pq | 
| produces the codes | |
| bool | do_polysemous_training | 
| reorder PQ centroids after training? | |
| PolysemousTraining * | polysemous_training | 
| if NULL, use default | |
| size_t | scan_table_threshold | 
| use table computation or on-the-fly? | |
| int | polysemous_ht | 
| Hamming thresh for polysemous filtering. | |
| std::vector< float > | precomputed_table | 
|  Public Attributes inherited from faiss::IndexIVF | |
| size_t | nprobe | 
| number of probes at query time | |
| size_t | max_codes | 
| max nb of codes to visit to do a query | |
| std::vector< std::vector< long > > | ids | 
| Inverted lists for indexes. | |
| size_t | code_size | 
| code size per vector in bytes | |
| std::vector< std::vector < uint8_t > > | codes | 
| bool | maintain_direct_map | 
| map for direct access to the elements. Enables reconstruct(). | |
| std::vector< long > | direct_map | 
|  Public Attributes inherited from faiss::Index | |
| int | d | 
| vector dimension | |
| idx_t | ntotal | 
| total nb of indexed vectors | |
| bool | verbose | 
| verbosity level | |
| bool | is_trained | 
| set if the Index does not require training, or if training is done already | |
| MetricType | metric_type | 
| type of metric this index uses for search | |
|  Public Attributes inherited from faiss::Level1Quantizer | |
| Index * | quantizer | 
| quantizer that maps vectors to inverted lists | |
| size_t | nlist | 
| number of possible key values | |
| char | quantizer_trains_alone | 
| bool | own_fields | 
| whether object owns the quantizer | |
| ClusteringParameters | cp | 
| to override default clustering params | |
| Index * | clustering_index | 
| to override index used during clustering | |
Index with 32-bit ids and flat tables. Must be constructed from an exisiting IndexIVFPQ. Cannot be copy-constructed/assigned. The actual data is stored in the compact_* tables, the ids and codes tables are not used.
Definition at line 194 of file IndexIVFPQ.h.
how were the compact tables allocated?
| Enumerator | |
|---|---|
| Alloc_type_none | alloc from outside | 
| Alloc_type_new | was allocated with new | 
| Alloc_type_mmap | was mmapped | 
Definition at line 199 of file IndexIVFPQ.h.
| 
 | overridevirtual | 
search a set of vectors, that are pre-quantized by the IVF quantizer. Fill in the corresponding heaps with the query results. search() calls this.
| n | nb of vectors to query | 
| x | query vectors, size nx * d | 
| assign | coarse quantization indices, size nx * nprobe | 
| centroid_dis | distances to coarse centroids, size nx * nprobe | 
| distance | output distances, size n * k | 
| labels | output labels, size n * k | 
| store_pairs | store inv list index + inv list offset instead in upper/lower 32 bit of result, instead of ids (used for reranking). | 
Reimplemented from faiss::IndexIVFPQ.
Definition at line 1576 of file IndexIVFPQ.cpp.
 1.8.5
 1.8.5