10 #include "RemapIndices.h"
11 #include "../../FaissAssert.h"
13 namespace faiss {
namespace gpu {
17 void ivfOffsetToUserIndex(
22 const std::vector<std::vector<long>>& listOffsetToUserIndex) {
23 FAISS_ASSERT(numLists == listOffsetToUserIndex.size());
25 #pragma omp parallel for
26 for (
int q = 0; q < queries; ++q) {
27 for (
int r = 0; r < k; ++r) {
28 long offsetIndex = indices[q * k + r];
30 if (offsetIndex < 0)
continue;
32 int listId = (int) (offsetIndex >> 32);
33 int listOffset = (int) (offsetIndex & 0xffffffff);
35 FAISS_ASSERT(listId < numLists);
36 auto& listIndices = listOffsetToUserIndex[listId];
38 FAISS_ASSERT(listOffset < listIndices.size());
39 indices[q * k + r] = listIndices[listOffset];