import faiss
from faiss.contrib.evaluation import knn_intersection_measure
from faiss.contrib import datasets
ds = datasets.SyntheticDataset(64, 50000, 100000, 10000)
d = 64
index_fp16 = faiss.index_factory(d, 'PQ32x4fs,Refine(SQfp16)')
index_fp16.train(ds.get_train())
index_fp16.add(ds.get_database())
index_sq8 = faiss.index_factory(d, 'PQ32x4fs,Refine(SQ8)')
index_sq8.train(ds.get_train())
index_sq8.add(ds.get_database())
k_factor = 3.0
params = faiss.IndexRefineSearchParameters(k_factor=k_factor)
D_fp16, I_fp16 = index_fp16.search(ds.get_queries(), 100, params=params)
D_sq8, I_sq8 = index_sq8.search(ds.get_queries(), 100, params=params)
KIM_fp16 = knn_intersection_measure(I_fp16, ds.get_groundtruth())
KIM_sq8 = knn_intersection_measure(I_sq8, ds.get_groundtruth())
assert (KIM_fp16 > KIM_sq8)
print(I_sq8[:5])
print(I_fp16[:5])