13 #ifndef FAISS_INDEX_IVFPQ_H
14 #define FAISS_INDEX_IVFPQ_H
44 std::vector < std::vector<uint8_t> > codes;
52 size_t M,
size_t nbits_per_idx);
54 virtual void set_typename ()
override;
57 idx_t n,
const float *x,
58 const long *xids =
nullptr)
override;
64 const long *xids,
float *residuals_2,
65 const long *precomputed_idx =
nullptr);
69 float *distances,
idx_t *labels)
const override;
71 virtual void reset ()
override;
108 void encode (
long key,
const float * x, uint8_t * code)
const;
112 const float * x, uint8_t * codes)
const;
132 const float * coarse_dis,
134 bool store_pairs =
false)
const;
149 long a1,
long a2)
const;
164 size_t n_hamming_pass;
169 size_t assign_cycles;
170 size_t search_cycles;
171 size_t refine_cycles;
174 size_t init_query_cycles;
175 size_t init_list_cycles;
198 size_t M,
size_t nbits_per_idx,
199 size_t M_refine,
size_t nbits_per_idx_refine);
201 virtual void set_typename ()
override;
203 virtual void reset()
override;
215 const long *precomputed_idx =
nullptr);
223 float *distances,
idx_t *labels)
const override;
261 const float * coarse_dis,
263 bool store_pairs =
false)
const override;
266 virtual void add (
idx_t,
const float *)
override;
267 virtual void reset ()
override;
268 virtual void train (
idx_t,
const float *)
override;
uint32_t * compact_ids
size ntotal
uint8_t * compact_codes
size ntotal * code_size
void precompute_table()
build precomputed table
void copy_subset_to(IndexIVFPQ &other, int subset_type, long a1, long a2) const
virtual void reconstruct(idx_t key, float *recons) const override
ProductQuantizer refine_pq
3rd level quantizer
PolysemousTraining * polysemous_training
if NULL, use default
virtual void add(idx_t, const float *) override
the three following functions will fail at runtime
virtual void search_knn_with_key(size_t nx, const float *qx, const long *keys, const float *coarse_dis, float_maxheap_array_t *res, bool store_pairs=false) const override
virtual void reconstruct_n(idx_t i0, idx_t ni, float *recons) const override
virtual void merge_from_residuals(IndexIVF &other) override
used to implement merging
void train_residual_o(idx_t n, const float *x, float *residuals_2)
same as train_residual, also output 2nd level residuals
bool do_polysemous_training
reorder PQ centroids after training?
size_t scan_table_threshold
use table computation or on-the-fly?
virtual void train_residual(idx_t n, const float *x) override
trains the two product quantizers
void add_core(idx_t n, const float *x, const long *xids, const long *precomputed_idx=nullptr)
same as add_with_ids, but optionally use the precomputed list ids
uint32_t * limits
size nlist + 1
std::vector< float > precomputed_table
int polysemous_ht
Hamming thresh for polysemous filtering.
virtual void search_knn_with_key(size_t nx, const float *qx, const long *keys, const float *coarse_dis, float_maxheap_array_t *res, bool store_pairs=false) const
virtual void reset() override
removes all elements from the database.
virtual void add_with_ids(idx_t n, const float *x, const long *xids=nullptr) override
std::vector< std::vector< long > > ids
Inverted lists for indexes.
Index * quantizer
quantizer that maps vectors to inverted lists
size_t max_codes
max nb of codes to visit to do a query
Alloc_type_t
how were the compact tables allocated?
std::vector< uint8_t > refine_codes
corresponding codes
virtual long remove_ids(const IDSelector &sel) override
virtual void train_residual(idx_t n, const float *x) override
trains the product quantizer
virtual void train(idx_t, const float *) override
Trains the quantizer and calls train_residual to train sub-quantizers.
long idx_t
all indices are this type
virtual void reset() override
removes all elements from the database.
optimizes the order of indices in a ProductQuantizer
virtual void merge_from_residuals(IndexIVF &other) override
used to implement merging
bool by_residual
Encode residual or plain vector?
ProductQuantizer pq
produces the codes
size_t nlist
number of possible key values
virtual void reconstruct_n(idx_t i0, idx_t ni, float *recons) const override
void add_core_o(idx_t n, const float *x, const long *xids, float *residuals_2, const long *precomputed_idx=nullptr)
size_t code_size
code size per vector in bytes
virtual long remove_ids(const IDSelector &sel) override
virtual void reset() override
removes all elements from the database.
void encode_multiple(size_t n, const long *keys, const float *x, uint8_t *codes) const
same as encode, for multiple points at once
virtual void add_with_ids(idx_t n, const float *x, const long *xids) override
virtual void search(idx_t n, const float *x, idx_t k, float *distances, idx_t *labels) const override
virtual void search(idx_t n, const float *x, idx_t k, float *distances, idx_t *labels) const override
size_t find_duplicates(idx_t *ids, size_t *lims) const
float k_factor
factor between k requested in search and the k requested from the IVFPQ
int use_precomputed_table
if by_residual, build precompute tables