13 #include "Clustering_c.h"
14 #include "IndexIVF_c.h"
16 #include "macros_impl.h"
25 DEFINE_GETTER(
IndexIVF,
size_t, nlist)
27 DEFINE_GETTER(IndexIVF,
size_t, nprobe)
29 DEFINE_GETTER_PERMISSIVE(IndexIVF, FaissIndex*, quantizer)
36 DEFINE_GETTER(IndexIVF,
char, quantizer_trains_alone)
39 DEFINE_GETTER(IndexIVF,
int, own_fields)
41 using faiss::IndexIVF;
43 int faiss_IndexIVF_merge_from(
44 FaissIndexIVF* index, FaissIndexIVF* other, idx_t add_id) {
46 reinterpret_cast<IndexIVF*
>(index)->merge_from(
47 *reinterpret_cast<IndexIVF*>(other), add_id);
51 int faiss_IndexIVF_copy_subset_to(
52 const FaissIndexIVF* index, FaissIndexIVF* other,
int subset_type,
long a1,
55 reinterpret_cast<const IndexIVF*
>(index)->copy_subset_to(
56 *reinterpret_cast<IndexIVF*>(other), subset_type, a1, a2);
60 int faiss_IndexIVF_search_preassigned (
const FaissIndexIVF* index,
61 idx_t n,
const float *x, idx_t k,
const idx_t *assign,
62 const float *centroid_dis,
float *distances, idx_t *labels,
65 reinterpret_cast<const IndexIVF*
>(index)->search_preassigned(
66 n, x, k, assign, centroid_dis, distances, labels, store_pairs);
70 size_t faiss_IndexIVF_get_list_size(
const FaissIndexIVF* index,
size_t list_no) {
71 return reinterpret_cast<const IndexIVF*
>(index)->get_list_size(list_no);
74 int faiss_IndexIVF_make_direct_map(FaissIndexIVF* index,
75 int new_maintain_direct_map) {
77 reinterpret_cast<IndexIVF*
>(index)->make_direct_map(
78 static_cast<bool>(new_maintain_direct_map));
82 double faiss_IndexIVF_imbalance_factor (
const FaissIndexIVF* index) {
87 void faiss_IndexIVF_print_stats (
const FaissIndexIVF* index) {
88 reinterpret_cast<const IndexIVF*
>(index)->print_stats();
double imbalance_factor(int k, const int *hist)
same, takes a histogram as input