faiss 0.2.0 → 0.2.1

Sign up to get free protection for your applications and to get access to all the features.
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