faiss 0.2.0 → 0.2.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (202) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +4 -0
  3. data/lib/faiss/version.rb +1 -1
  4. data/vendor/faiss/faiss/AutoTune.cpp +292 -291
  5. data/vendor/faiss/faiss/AutoTune.h +55 -56
  6. data/vendor/faiss/faiss/Clustering.cpp +334 -195
  7. data/vendor/faiss/faiss/Clustering.h +88 -35
  8. data/vendor/faiss/faiss/IVFlib.cpp +171 -195
  9. data/vendor/faiss/faiss/IVFlib.h +48 -51
  10. data/vendor/faiss/faiss/Index.cpp +85 -103
  11. data/vendor/faiss/faiss/Index.h +54 -48
  12. data/vendor/faiss/faiss/Index2Layer.cpp +139 -164
  13. data/vendor/faiss/faiss/Index2Layer.h +22 -22
  14. data/vendor/faiss/faiss/IndexBinary.cpp +45 -37
  15. data/vendor/faiss/faiss/IndexBinary.h +140 -132
  16. data/vendor/faiss/faiss/IndexBinaryFlat.cpp +73 -53
  17. data/vendor/faiss/faiss/IndexBinaryFlat.h +29 -24
  18. data/vendor/faiss/faiss/IndexBinaryFromFloat.cpp +46 -43
  19. data/vendor/faiss/faiss/IndexBinaryFromFloat.h +16 -15
  20. data/vendor/faiss/faiss/IndexBinaryHNSW.cpp +215 -232
  21. data/vendor/faiss/faiss/IndexBinaryHNSW.h +25 -24
  22. data/vendor/faiss/faiss/IndexBinaryHash.cpp +182 -177
  23. data/vendor/faiss/faiss/IndexBinaryHash.h +41 -34
  24. data/vendor/faiss/faiss/IndexBinaryIVF.cpp +489 -461
  25. data/vendor/faiss/faiss/IndexBinaryIVF.h +97 -68
  26. data/vendor/faiss/faiss/IndexFlat.cpp +116 -147
  27. data/vendor/faiss/faiss/IndexFlat.h +35 -46
  28. data/vendor/faiss/faiss/IndexHNSW.cpp +372 -348
  29. data/vendor/faiss/faiss/IndexHNSW.h +57 -41
  30. data/vendor/faiss/faiss/IndexIVF.cpp +474 -454
  31. data/vendor/faiss/faiss/IndexIVF.h +146 -113
  32. data/vendor/faiss/faiss/IndexIVFFlat.cpp +248 -250
  33. data/vendor/faiss/faiss/IndexIVFFlat.h +48 -51
  34. data/vendor/faiss/faiss/IndexIVFPQ.cpp +457 -516
  35. data/vendor/faiss/faiss/IndexIVFPQ.h +74 -66
  36. data/vendor/faiss/faiss/IndexIVFPQFastScan.cpp +406 -372
  37. data/vendor/faiss/faiss/IndexIVFPQFastScan.h +82 -57
  38. data/vendor/faiss/faiss/IndexIVFPQR.cpp +104 -102
  39. data/vendor/faiss/faiss/IndexIVFPQR.h +33 -28
  40. data/vendor/faiss/faiss/IndexIVFSpectralHash.cpp +125 -133
  41. data/vendor/faiss/faiss/IndexIVFSpectralHash.h +19 -21
  42. data/vendor/faiss/faiss/IndexLSH.cpp +75 -96
  43. data/vendor/faiss/faiss/IndexLSH.h +21 -26
  44. data/vendor/faiss/faiss/IndexLattice.cpp +42 -56
  45. data/vendor/faiss/faiss/IndexLattice.h +11 -16
  46. data/vendor/faiss/faiss/IndexNNDescent.cpp +231 -0
  47. data/vendor/faiss/faiss/IndexNNDescent.h +72 -0
  48. data/vendor/faiss/faiss/IndexNSG.cpp +303 -0
  49. data/vendor/faiss/faiss/IndexNSG.h +85 -0
  50. data/vendor/faiss/faiss/IndexPQ.cpp +405 -464
  51. data/vendor/faiss/faiss/IndexPQ.h +64 -67
  52. data/vendor/faiss/faiss/IndexPQFastScan.cpp +143 -170
  53. data/vendor/faiss/faiss/IndexPQFastScan.h +46 -32
  54. data/vendor/faiss/faiss/IndexPreTransform.cpp +120 -150
  55. data/vendor/faiss/faiss/IndexPreTransform.h +33 -36
  56. data/vendor/faiss/faiss/IndexRefine.cpp +115 -131
  57. data/vendor/faiss/faiss/IndexRefine.h +22 -23
  58. data/vendor/faiss/faiss/IndexReplicas.cpp +147 -153
  59. data/vendor/faiss/faiss/IndexReplicas.h +62 -56
  60. data/vendor/faiss/faiss/IndexResidual.cpp +291 -0
  61. data/vendor/faiss/faiss/IndexResidual.h +152 -0
  62. data/vendor/faiss/faiss/IndexScalarQuantizer.cpp +120 -155
  63. data/vendor/faiss/faiss/IndexScalarQuantizer.h +41 -45
  64. data/vendor/faiss/faiss/IndexShards.cpp +256 -240
  65. data/vendor/faiss/faiss/IndexShards.h +85 -73
  66. data/vendor/faiss/faiss/MatrixStats.cpp +112 -97
  67. data/vendor/faiss/faiss/MatrixStats.h +7 -10
  68. data/vendor/faiss/faiss/MetaIndexes.cpp +135 -157
  69. data/vendor/faiss/faiss/MetaIndexes.h +40 -34
  70. data/vendor/faiss/faiss/MetricType.h +7 -7
  71. data/vendor/faiss/faiss/VectorTransform.cpp +652 -474
  72. data/vendor/faiss/faiss/VectorTransform.h +61 -89
  73. data/vendor/faiss/faiss/clone_index.cpp +77 -73
  74. data/vendor/faiss/faiss/clone_index.h +4 -9
  75. data/vendor/faiss/faiss/gpu/GpuAutoTune.cpp +33 -38
  76. data/vendor/faiss/faiss/gpu/GpuAutoTune.h +11 -9
  77. data/vendor/faiss/faiss/gpu/GpuCloner.cpp +197 -170
  78. data/vendor/faiss/faiss/gpu/GpuCloner.h +53 -35
  79. data/vendor/faiss/faiss/gpu/GpuClonerOptions.cpp +12 -14
  80. data/vendor/faiss/faiss/gpu/GpuClonerOptions.h +27 -25
  81. data/vendor/faiss/faiss/gpu/GpuDistance.h +116 -112
  82. data/vendor/faiss/faiss/gpu/GpuFaissAssert.h +1 -2
  83. data/vendor/faiss/faiss/gpu/GpuIndex.h +134 -137
  84. data/vendor/faiss/faiss/gpu/GpuIndexBinaryFlat.h +76 -73
  85. data/vendor/faiss/faiss/gpu/GpuIndexFlat.h +173 -162
  86. data/vendor/faiss/faiss/gpu/GpuIndexIVF.h +67 -64
  87. data/vendor/faiss/faiss/gpu/GpuIndexIVFFlat.h +89 -86
  88. data/vendor/faiss/faiss/gpu/GpuIndexIVFPQ.h +150 -141
  89. data/vendor/faiss/faiss/gpu/GpuIndexIVFScalarQuantizer.h +101 -103
  90. data/vendor/faiss/faiss/gpu/GpuIndicesOptions.h +17 -16
  91. data/vendor/faiss/faiss/gpu/GpuResources.cpp +116 -128
  92. data/vendor/faiss/faiss/gpu/GpuResources.h +182 -186
  93. data/vendor/faiss/faiss/gpu/StandardGpuResources.cpp +433 -422
  94. data/vendor/faiss/faiss/gpu/StandardGpuResources.h +131 -130
  95. data/vendor/faiss/faiss/gpu/impl/InterleavedCodes.cpp +468 -456
  96. data/vendor/faiss/faiss/gpu/impl/InterleavedCodes.h +25 -19
  97. data/vendor/faiss/faiss/gpu/impl/RemapIndices.cpp +22 -20
  98. data/vendor/faiss/faiss/gpu/impl/RemapIndices.h +9 -8
  99. data/vendor/faiss/faiss/gpu/perf/IndexWrapper-inl.h +39 -44
  100. data/vendor/faiss/faiss/gpu/perf/IndexWrapper.h +16 -14
  101. data/vendor/faiss/faiss/gpu/perf/PerfClustering.cpp +77 -71
  102. data/vendor/faiss/faiss/gpu/perf/PerfIVFPQAdd.cpp +109 -88
  103. data/vendor/faiss/faiss/gpu/perf/WriteIndex.cpp +75 -64
  104. data/vendor/faiss/faiss/gpu/test/TestCodePacking.cpp +230 -215
  105. data/vendor/faiss/faiss/gpu/test/TestGpuIndexBinaryFlat.cpp +80 -86
  106. data/vendor/faiss/faiss/gpu/test/TestGpuIndexFlat.cpp +284 -277
  107. data/vendor/faiss/faiss/gpu/test/TestGpuIndexIVFFlat.cpp +416 -416
  108. data/vendor/faiss/faiss/gpu/test/TestGpuIndexIVFPQ.cpp +611 -517
  109. data/vendor/faiss/faiss/gpu/test/TestGpuIndexIVFScalarQuantizer.cpp +166 -164
  110. data/vendor/faiss/faiss/gpu/test/TestGpuMemoryException.cpp +61 -53
  111. data/vendor/faiss/faiss/gpu/test/TestUtils.cpp +274 -238
  112. data/vendor/faiss/faiss/gpu/test/TestUtils.h +73 -57
  113. data/vendor/faiss/faiss/gpu/test/demo_ivfpq_indexing_gpu.cpp +47 -50
  114. data/vendor/faiss/faiss/gpu/utils/DeviceUtils.h +79 -72
  115. data/vendor/faiss/faiss/gpu/utils/StackDeviceMemory.cpp +140 -146
  116. data/vendor/faiss/faiss/gpu/utils/StackDeviceMemory.h +69 -71
  117. data/vendor/faiss/faiss/gpu/utils/StaticUtils.h +21 -16
  118. data/vendor/faiss/faiss/gpu/utils/Timer.cpp +25 -29
  119. data/vendor/faiss/faiss/gpu/utils/Timer.h +30 -29
  120. data/vendor/faiss/faiss/impl/AdditiveQuantizer.cpp +270 -0
  121. data/vendor/faiss/faiss/impl/AdditiveQuantizer.h +115 -0
  122. data/vendor/faiss/faiss/impl/AuxIndexStructures.cpp +90 -120
  123. data/vendor/faiss/faiss/impl/AuxIndexStructures.h +81 -65
  124. data/vendor/faiss/faiss/impl/FaissAssert.h +73 -58
  125. data/vendor/faiss/faiss/impl/FaissException.cpp +56 -48
  126. data/vendor/faiss/faiss/impl/FaissException.h +41 -29
  127. data/vendor/faiss/faiss/impl/HNSW.cpp +595 -611
  128. data/vendor/faiss/faiss/impl/HNSW.h +179 -200
  129. data/vendor/faiss/faiss/impl/LocalSearchQuantizer.cpp +672 -0
  130. data/vendor/faiss/faiss/impl/LocalSearchQuantizer.h +172 -0
  131. data/vendor/faiss/faiss/impl/NNDescent.cpp +487 -0
  132. data/vendor/faiss/faiss/impl/NNDescent.h +154 -0
  133. data/vendor/faiss/faiss/impl/NSG.cpp +682 -0
  134. data/vendor/faiss/faiss/impl/NSG.h +199 -0
  135. data/vendor/faiss/faiss/impl/PolysemousTraining.cpp +484 -454
  136. data/vendor/faiss/faiss/impl/PolysemousTraining.h +52 -55
  137. data/vendor/faiss/faiss/impl/ProductQuantizer-inl.h +26 -47
  138. data/vendor/faiss/faiss/impl/ProductQuantizer.cpp +469 -459
  139. data/vendor/faiss/faiss/impl/ProductQuantizer.h +76 -87
  140. data/vendor/faiss/faiss/impl/ResidualQuantizer.cpp +448 -0
  141. data/vendor/faiss/faiss/impl/ResidualQuantizer.h +130 -0
  142. data/vendor/faiss/faiss/impl/ResultHandler.h +96 -132
  143. data/vendor/faiss/faiss/impl/ScalarQuantizer.cpp +648 -701
  144. data/vendor/faiss/faiss/impl/ScalarQuantizer.h +48 -46
  145. data/vendor/faiss/faiss/impl/ThreadedIndex-inl.h +129 -131
  146. data/vendor/faiss/faiss/impl/ThreadedIndex.h +61 -55
  147. data/vendor/faiss/faiss/impl/index_read.cpp +547 -479
  148. data/vendor/faiss/faiss/impl/index_write.cpp +497 -407
  149. data/vendor/faiss/faiss/impl/io.cpp +75 -94
  150. data/vendor/faiss/faiss/impl/io.h +31 -41
  151. data/vendor/faiss/faiss/impl/io_macros.h +40 -29
  152. data/vendor/faiss/faiss/impl/lattice_Zn.cpp +137 -186
  153. data/vendor/faiss/faiss/impl/lattice_Zn.h +40 -51
  154. data/vendor/faiss/faiss/impl/platform_macros.h +29 -8
  155. data/vendor/faiss/faiss/impl/pq4_fast_scan.cpp +77 -124
  156. data/vendor/faiss/faiss/impl/pq4_fast_scan.h +39 -48
  157. data/vendor/faiss/faiss/impl/pq4_fast_scan_search_1.cpp +41 -52
  158. data/vendor/faiss/faiss/impl/pq4_fast_scan_search_qbs.cpp +80 -117
  159. data/vendor/faiss/faiss/impl/simd_result_handlers.h +109 -137
  160. data/vendor/faiss/faiss/index_factory.cpp +269 -218
  161. data/vendor/faiss/faiss/index_factory.h +6 -7
  162. data/vendor/faiss/faiss/index_io.h +23 -26
  163. data/vendor/faiss/faiss/invlists/BlockInvertedLists.cpp +67 -75
  164. data/vendor/faiss/faiss/invlists/BlockInvertedLists.h +22 -24
  165. data/vendor/faiss/faiss/invlists/DirectMap.cpp +96 -112
  166. data/vendor/faiss/faiss/invlists/DirectMap.h +29 -33
  167. data/vendor/faiss/faiss/invlists/InvertedLists.cpp +307 -364
  168. data/vendor/faiss/faiss/invlists/InvertedLists.h +151 -151
  169. data/vendor/faiss/faiss/invlists/InvertedListsIOHook.cpp +29 -34
  170. data/vendor/faiss/faiss/invlists/InvertedListsIOHook.h +17 -18
  171. data/vendor/faiss/faiss/invlists/OnDiskInvertedLists.cpp +257 -293
  172. data/vendor/faiss/faiss/invlists/OnDiskInvertedLists.h +50 -45
  173. data/vendor/faiss/faiss/python/python_callbacks.cpp +23 -26
  174. data/vendor/faiss/faiss/python/python_callbacks.h +9 -16
  175. data/vendor/faiss/faiss/utils/AlignedTable.h +79 -44
  176. data/vendor/faiss/faiss/utils/Heap.cpp +40 -48
  177. data/vendor/faiss/faiss/utils/Heap.h +186 -209
  178. data/vendor/faiss/faiss/utils/WorkerThread.cpp +67 -76
  179. data/vendor/faiss/faiss/utils/WorkerThread.h +32 -33
  180. data/vendor/faiss/faiss/utils/distances.cpp +301 -310
  181. data/vendor/faiss/faiss/utils/distances.h +133 -118
  182. data/vendor/faiss/faiss/utils/distances_simd.cpp +456 -516
  183. data/vendor/faiss/faiss/utils/extra_distances-inl.h +117 -0
  184. data/vendor/faiss/faiss/utils/extra_distances.cpp +113 -232
  185. data/vendor/faiss/faiss/utils/extra_distances.h +30 -29
  186. data/vendor/faiss/faiss/utils/hamming-inl.h +260 -209
  187. data/vendor/faiss/faiss/utils/hamming.cpp +375 -469
  188. data/vendor/faiss/faiss/utils/hamming.h +62 -85
  189. data/vendor/faiss/faiss/utils/ordered_key_value.h +16 -18
  190. data/vendor/faiss/faiss/utils/partitioning.cpp +393 -318
  191. data/vendor/faiss/faiss/utils/partitioning.h +26 -21
  192. data/vendor/faiss/faiss/utils/quantize_lut.cpp +78 -66
  193. data/vendor/faiss/faiss/utils/quantize_lut.h +22 -20
  194. data/vendor/faiss/faiss/utils/random.cpp +39 -63
  195. data/vendor/faiss/faiss/utils/random.h +13 -16
  196. data/vendor/faiss/faiss/utils/simdlib.h +4 -2
  197. data/vendor/faiss/faiss/utils/simdlib_avx2.h +88 -85
  198. data/vendor/faiss/faiss/utils/simdlib_emulated.h +226 -165
  199. data/vendor/faiss/faiss/utils/simdlib_neon.h +832 -0
  200. data/vendor/faiss/faiss/utils/utils.cpp +304 -287
  201. data/vendor/faiss/faiss/utils/utils.h +53 -48
  202. metadata +20 -2
@@ -0,0 +1,115 @@
1
+ /**
2
+ * Copyright (c) Facebook, Inc. and its affiliates.
3
+ *
4
+ * This source code is licensed under the MIT license found in the
5
+ * LICENSE file in the root directory of this source tree.
6
+ */
7
+
8
+ #pragma once
9
+
10
+ #include <cstdint>
11
+ #include <vector>
12
+
13
+ #include <faiss/Index.h>
14
+
15
+ namespace faiss {
16
+
17
+ /** Abstract structure for additive quantizers
18
+ *
19
+ * Different from the product quantizer in which the decoded vector is the
20
+ * concatenation of M sub-vectors, additive quantizers sum M sub-vectors
21
+ * to get the decoded vector.
22
+ */
23
+ struct AdditiveQuantizer {
24
+ size_t d; ///< size of the input vectors
25
+ size_t M; ///< number of codebooks
26
+ std::vector<size_t> nbits; ///< bits for each step
27
+ std::vector<float> codebooks; ///< codebooks
28
+
29
+ // derived values
30
+ std::vector<size_t> codebook_offsets;
31
+ size_t code_size; ///< code size in bytes
32
+ size_t tot_bits; ///< total number of bits
33
+ size_t total_codebook_size; ///< size of the codebook in vectors
34
+ bool is_byte_aligned;
35
+
36
+ bool verbose; ///< verbose during training?
37
+ bool is_trained; ///< is trained or not
38
+
39
+ ///< compute derived values when d, M and nbits have been set
40
+ void set_derived_values();
41
+
42
+ ///< Train the additive quantizer
43
+ virtual void train(size_t n, const float* x) = 0;
44
+
45
+ /** Encode a set of vectors
46
+ *
47
+ * @param x vectors to encode, size n * d
48
+ * @param codes output codes, size n * code_size
49
+ */
50
+ virtual void compute_codes(const float* x, uint8_t* codes, size_t n)
51
+ const = 0;
52
+
53
+ /** pack a series of code to bit-compact format
54
+ *
55
+ * @param codes codes to be packed, size n * code_size
56
+ * @param packed_codes output bit-compact codes
57
+ * @param ld_codes leading dimension of codes
58
+ */
59
+ void pack_codes(
60
+ size_t n,
61
+ const int32_t* codes,
62
+ uint8_t* packed_codes,
63
+ int64_t ld_codes = -1) const;
64
+
65
+ /** Decode a set of vectors
66
+ *
67
+ * @param codes codes to decode, size n * code_size
68
+ * @param x output vectors, size n * d
69
+ */
70
+ void decode(const uint8_t* codes, float* x, size_t n) const;
71
+
72
+ /****************************************************************************
73
+ * Support for exhaustive distance computations with the centroids.
74
+ * Hence, the number of elements that can be enumerated is not too large.
75
+ ****************************************************************************/
76
+ using idx_t = Index::idx_t;
77
+
78
+ /// decoding function for a code in a 64-bit word
79
+ void decode_64bit(idx_t n, float* x) const;
80
+
81
+ /** Compute inner-product look-up tables. Used in the centroid search
82
+ * functions.
83
+ *
84
+ * @param xq query vector, size (n, d)
85
+ * @param LUT look-up table, size (n, total_codebook_size)
86
+ */
87
+ void compute_LUT(size_t n, const float* xq, float* LUT) const;
88
+
89
+ /// exact IP search
90
+ void knn_exact_inner_product(
91
+ idx_t n,
92
+ const float* xq,
93
+ idx_t k,
94
+ float* distances,
95
+ idx_t* labels) const;
96
+
97
+ /** For L2 search we need the L2 norms of the centroids
98
+ *
99
+ * @param norms output norms table, size total_codebook_size
100
+ */
101
+ void compute_centroid_norms(float* norms) const;
102
+
103
+ /** Exact L2 search, with precomputed norms */
104
+ void knn_exact_L2(
105
+ idx_t n,
106
+ const float* xq,
107
+ idx_t k,
108
+ float* distances,
109
+ idx_t* labels,
110
+ const float* centroid_norms) const;
111
+
112
+ virtual ~AdditiveQuantizer();
113
+ };
114
+
115
+ }; // namespace faiss
@@ -14,18 +14,16 @@
14
14
 
15
15
  #include <faiss/impl/FaissAssert.h>
16
16
 
17
-
18
17
  namespace faiss {
19
18
 
20
-
21
19
  /***********************************************************************
22
20
  * RangeSearchResult
23
21
  ***********************************************************************/
24
22
 
25
- RangeSearchResult::RangeSearchResult (idx_t nq, bool alloc_lims): nq (nq) {
23
+ RangeSearchResult::RangeSearchResult(idx_t nq, bool alloc_lims) : nq(nq) {
26
24
  if (alloc_lims) {
27
- lims = new size_t [nq + 1];
28
- memset (lims, 0, sizeof(*lims) * (nq + 1));
25
+ lims = new size_t[nq + 1];
26
+ memset(lims, 0, sizeof(*lims) * (nq + 1));
29
27
  } else {
30
28
  lims = nullptr;
31
29
  }
@@ -36,145 +34,129 @@ RangeSearchResult::RangeSearchResult (idx_t nq, bool alloc_lims): nq (nq) {
36
34
 
37
35
  /// called when lims contains the nb of elements result entries
38
36
  /// for each query
39
- void RangeSearchResult::do_allocation () {
37
+ void RangeSearchResult::do_allocation() {
38
+ // works only if all the partial results are aggregated
39
+ // simulatenously
40
+ FAISS_THROW_IF_NOT(labels == nullptr && distances == nullptr);
40
41
  size_t ofs = 0;
41
42
  for (int i = 0; i < nq; i++) {
42
43
  size_t n = lims[i];
43
- lims [i] = ofs;
44
+ lims[i] = ofs;
44
45
  ofs += n;
45
46
  }
46
- lims [nq] = ofs;
47
- labels = new idx_t [ofs];
48
- distances = new float [ofs];
47
+ lims[nq] = ofs;
48
+ labels = new idx_t[ofs];
49
+ distances = new float[ofs];
49
50
  }
50
51
 
51
- RangeSearchResult::~RangeSearchResult () {
52
- delete [] labels;
53
- delete [] distances;
54
- delete [] lims;
52
+ RangeSearchResult::~RangeSearchResult() {
53
+ delete[] labels;
54
+ delete[] distances;
55
+ delete[] lims;
55
56
  }
56
57
 
57
-
58
-
59
-
60
-
61
58
  /***********************************************************************
62
59
  * BufferList
63
60
  ***********************************************************************/
64
61
 
65
-
66
- BufferList::BufferList (size_t buffer_size):
67
- buffer_size (buffer_size)
68
- {
62
+ BufferList::BufferList(size_t buffer_size) : buffer_size(buffer_size) {
69
63
  wp = buffer_size;
70
64
  }
71
65
 
72
- BufferList::~BufferList ()
73
- {
66
+ BufferList::~BufferList() {
74
67
  for (int i = 0; i < buffers.size(); i++) {
75
- delete [] buffers[i].ids;
76
- delete [] buffers[i].dis;
68
+ delete[] buffers[i].ids;
69
+ delete[] buffers[i].dis;
77
70
  }
78
71
  }
79
72
 
80
- void BufferList::add (idx_t id, float dis) {
73
+ void BufferList::add(idx_t id, float dis) {
81
74
  if (wp == buffer_size) { // need new buffer
82
75
  append_buffer();
83
76
  }
84
- Buffer & buf = buffers.back();
85
- buf.ids [wp] = id;
86
- buf.dis [wp] = dis;
77
+ Buffer& buf = buffers.back();
78
+ buf.ids[wp] = id;
79
+ buf.dis[wp] = dis;
87
80
  wp++;
88
81
  }
89
82
 
90
-
91
- void BufferList::append_buffer ()
92
- {
93
- Buffer buf = {new idx_t [buffer_size], new float [buffer_size]};
94
- buffers.push_back (buf);
83
+ void BufferList::append_buffer() {
84
+ Buffer buf = {new idx_t[buffer_size], new float[buffer_size]};
85
+ buffers.push_back(buf);
95
86
  wp = 0;
96
87
  }
97
88
 
98
89
  /// copy elemnts ofs:ofs+n-1 seen as linear data in the buffers to
99
90
  /// tables dest_ids, dest_dis
100
- void BufferList::copy_range (size_t ofs, size_t n,
101
- idx_t * dest_ids, float *dest_dis)
102
- {
91
+ void BufferList::copy_range(
92
+ size_t ofs,
93
+ size_t n,
94
+ idx_t* dest_ids,
95
+ float* dest_dis) {
103
96
  size_t bno = ofs / buffer_size;
104
97
  ofs -= bno * buffer_size;
105
98
  while (n > 0) {
106
99
  size_t ncopy = ofs + n < buffer_size ? n : buffer_size - ofs;
107
- Buffer buf = buffers [bno];
108
- memcpy (dest_ids, buf.ids + ofs, ncopy * sizeof(*dest_ids));
109
- memcpy (dest_dis, buf.dis + ofs, ncopy * sizeof(*dest_dis));
100
+ Buffer buf = buffers[bno];
101
+ memcpy(dest_ids, buf.ids + ofs, ncopy * sizeof(*dest_ids));
102
+ memcpy(dest_dis, buf.dis + ofs, ncopy * sizeof(*dest_dis));
110
103
  dest_ids += ncopy;
111
104
  dest_dis += ncopy;
112
105
  ofs = 0;
113
- bno ++;
106
+ bno++;
114
107
  n -= ncopy;
115
108
  }
116
109
  }
117
110
 
118
-
119
111
  /***********************************************************************
120
112
  * RangeSearchPartialResult
121
113
  ***********************************************************************/
122
114
 
123
- void RangeQueryResult::add (float dis, idx_t id) {
115
+ void RangeQueryResult::add(float dis, idx_t id) {
124
116
  nres++;
125
- pres->add (id, dis);
117
+ pres->add(id, dis);
126
118
  }
127
119
 
128
-
129
-
130
- RangeSearchPartialResult::RangeSearchPartialResult (RangeSearchResult * res_in):
131
- BufferList(res_in->buffer_size),
132
- res(res_in)
133
- {}
134
-
120
+ RangeSearchPartialResult::RangeSearchPartialResult(RangeSearchResult* res_in)
121
+ : BufferList(res_in->buffer_size), res(res_in) {}
135
122
 
136
123
  /// begin a new result
137
- RangeQueryResult &
138
- RangeSearchPartialResult::new_result (idx_t qno)
139
- {
124
+ RangeQueryResult& RangeSearchPartialResult::new_result(idx_t qno) {
140
125
  RangeQueryResult qres = {qno, 0, this};
141
- queries.push_back (qres);
126
+ queries.push_back(qres);
142
127
  return queries.back();
143
128
  }
144
129
 
145
-
146
- void RangeSearchPartialResult::finalize ()
147
- {
148
- set_lims ();
130
+ void RangeSearchPartialResult::finalize() {
131
+ set_lims();
149
132
  #pragma omp barrier
150
133
 
151
134
  #pragma omp single
152
- res->do_allocation ();
135
+ res->do_allocation();
153
136
 
154
137
  #pragma omp barrier
155
- copy_result ();
138
+ copy_result();
156
139
  }
157
140
 
158
-
159
141
  /// called by range_search before do_allocation
160
- void RangeSearchPartialResult::set_lims ()
161
- {
142
+ void RangeSearchPartialResult::set_lims() {
162
143
  for (int i = 0; i < queries.size(); i++) {
163
- RangeQueryResult & qres = queries[i];
144
+ RangeQueryResult& qres = queries[i];
164
145
  res->lims[qres.qno] = qres.nres;
165
146
  }
166
147
  }
167
148
 
168
149
  /// called by range_search after do_allocation
169
- void RangeSearchPartialResult::copy_result (bool incremental)
170
- {
150
+ void RangeSearchPartialResult::copy_result(bool incremental) {
171
151
  size_t ofs = 0;
172
152
  for (int i = 0; i < queries.size(); i++) {
173
- RangeQueryResult & qres = queries[i];
153
+ RangeQueryResult& qres = queries[i];
174
154
 
175
- copy_range (ofs, qres.nres,
176
- res->labels + res->lims[qres.qno],
177
- res->distances + res->lims[qres.qno]);
155
+ copy_range(
156
+ ofs,
157
+ qres.nres,
158
+ res->labels + res->lims[qres.qno],
159
+ res->distances + res->lims[qres.qno]);
178
160
  if (incremental) {
179
161
  res->lims[qres.qno] += qres.nres;
180
162
  }
@@ -182,26 +164,28 @@ void RangeSearchPartialResult::copy_result (bool incremental)
182
164
  }
183
165
  }
184
166
 
185
- void RangeSearchPartialResult::merge (std::vector <RangeSearchPartialResult *> &
186
- partial_results, bool do_delete)
187
- {
188
-
167
+ void RangeSearchPartialResult::merge(
168
+ std::vector<RangeSearchPartialResult*>& partial_results,
169
+ bool do_delete) {
189
170
  int npres = partial_results.size();
190
- if (npres == 0) return;
191
- RangeSearchResult *result = partial_results[0]->res;
171
+ if (npres == 0)
172
+ return;
173
+ RangeSearchResult* result = partial_results[0]->res;
192
174
  size_t nx = result->nq;
193
175
 
194
176
  // count
195
- for (const RangeSearchPartialResult * pres : partial_results) {
196
- if (!pres) continue;
197
- for (const RangeQueryResult &qres : pres->queries) {
177
+ for (const RangeSearchPartialResult* pres : partial_results) {
178
+ if (!pres)
179
+ continue;
180
+ for (const RangeQueryResult& qres : pres->queries) {
198
181
  result->lims[qres.qno] += qres.nres;
199
182
  }
200
183
  }
201
- result->do_allocation ();
184
+ result->do_allocation();
202
185
  for (int j = 0; j < npres; j++) {
203
- if (!partial_results[j]) continue;
204
- partial_results[j]->copy_result (true);
186
+ if (!partial_results[j])
187
+ continue;
188
+ partial_results[j]->copy_result(true);
205
189
  if (do_delete) {
206
190
  delete partial_results[j];
207
191
  partial_results[j] = nullptr;
@@ -210,22 +194,19 @@ void RangeSearchPartialResult::merge (std::vector <RangeSearchPartialResult *> &
210
194
 
211
195
  // reset the limits
212
196
  for (size_t i = nx; i > 0; i--) {
213
- result->lims [i] = result->lims [i - 1];
197
+ result->lims[i] = result->lims[i - 1];
214
198
  }
215
- result->lims [0] = 0;
199
+ result->lims[0] = 0;
216
200
  }
217
201
 
218
202
  /***********************************************************************
219
203
  * IDSelectorRange
220
204
  ***********************************************************************/
221
205
 
222
- IDSelectorRange::IDSelectorRange (idx_t imin, idx_t imax):
223
- imin (imin), imax (imax)
224
- {
225
- }
206
+ IDSelectorRange::IDSelectorRange(idx_t imin, idx_t imax)
207
+ : imin(imin), imax(imax) {}
226
208
 
227
- bool IDSelectorRange::is_member (idx_t id) const
228
- {
209
+ bool IDSelectorRange::is_member(idx_t id) const {
229
210
  return id >= imin && id < imax;
230
211
  }
231
212
 
@@ -233,33 +214,29 @@ bool IDSelectorRange::is_member (idx_t id) const
233
214
  * IDSelectorArray
234
215
  ***********************************************************************/
235
216
 
236
- IDSelectorArray::IDSelectorArray (size_t n, const idx_t *ids):
237
- n (n), ids(ids)
238
- {
239
- }
217
+ IDSelectorArray::IDSelectorArray(size_t n, const idx_t* ids) : n(n), ids(ids) {}
240
218
 
241
- bool IDSelectorArray::is_member (idx_t id) const
242
- {
219
+ bool IDSelectorArray::is_member(idx_t id) const {
243
220
  for (idx_t i = 0; i < n; i++) {
244
- if (ids[i] == id) return true;
221
+ if (ids[i] == id)
222
+ return true;
245
223
  }
246
224
  return false;
247
225
  }
248
226
 
249
-
250
227
  /***********************************************************************
251
228
  * IDSelectorBatch
252
229
  ***********************************************************************/
253
230
 
254
- IDSelectorBatch::IDSelectorBatch (size_t n, const idx_t *indices)
255
- {
231
+ IDSelectorBatch::IDSelectorBatch(size_t n, const idx_t* indices) {
256
232
  nbits = 0;
257
- while (n > (1L << nbits)) nbits++;
233
+ while (n > (1L << nbits))
234
+ nbits++;
258
235
  nbits += 5;
259
236
  // for n = 1M, nbits = 25 is optimal, see P56659518
260
237
 
261
238
  mask = (1L << nbits) - 1;
262
- bloom.resize (1UL << (nbits - 3), 0);
239
+ bloom.resize(1UL << (nbits - 3), 0);
263
240
  for (long i = 0; i < n; i++) {
264
241
  Index::idx_t id = indices[i];
265
242
  set.insert(id);
@@ -268,39 +245,36 @@ IDSelectorBatch::IDSelectorBatch (size_t n, const idx_t *indices)
268
245
  }
269
246
  }
270
247
 
271
- bool IDSelectorBatch::is_member (idx_t i) const
272
- {
248
+ bool IDSelectorBatch::is_member(idx_t i) const {
273
249
  long im = i & mask;
274
- if(!(bloom[im>>3] & (1 << (im & 7)))) {
250
+ if (!(bloom[im >> 3] & (1 << (im & 7)))) {
275
251
  return 0;
276
252
  }
277
253
  return set.count(i);
278
254
  }
279
255
 
280
-
281
256
  /***********************************************************
282
257
  * Interrupt callback
283
258
  ***********************************************************/
284
259
 
285
-
286
260
  std::unique_ptr<InterruptCallback> InterruptCallback::instance;
287
261
 
288
262
  std::mutex InterruptCallback::lock;
289
263
 
290
- void InterruptCallback::clear_instance () {
291
- delete instance.release ();
264
+ void InterruptCallback::clear_instance() {
265
+ delete instance.release();
292
266
  }
293
267
 
294
- void InterruptCallback::check () {
268
+ void InterruptCallback::check() {
295
269
  if (!instance.get()) {
296
270
  return;
297
271
  }
298
- if (instance->want_interrupt ()) {
299
- FAISS_THROW_MSG ("computation interrupted");
272
+ if (instance->want_interrupt()) {
273
+ FAISS_THROW_MSG("computation interrupted");
300
274
  }
301
275
  }
302
276
 
303
- bool InterruptCallback::is_interrupted () {
277
+ bool InterruptCallback::is_interrupted() {
304
278
  if (!instance.get()) {
305
279
  return false;
306
280
  }
@@ -308,8 +282,7 @@ bool InterruptCallback::is_interrupted () {
308
282
  return instance->want_interrupt();
309
283
  }
310
284
 
311
-
312
- size_t InterruptCallback::get_period_hint (size_t flops) {
285
+ size_t InterruptCallback::get_period_hint(size_t flops) {
313
286
  if (!instance.get()) {
314
287
  return 1L << 30; // never check
315
288
  }
@@ -317,7 +290,4 @@ size_t InterruptCallback::get_period_hint (size_t flops) {
317
290
  return std::max((size_t)10 * 10 * 1000 * 1000 / (flops + 1), (size_t)1);
318
291
  }
319
292
 
320
-
321
-
322
-
323
293
  } // namespace faiss