12 #include "RemapIndices.h"
13 #include "../../FaissAssert.h"
15 namespace faiss {
namespace gpu {
19 void ivfOffsetToUserIndex(
24 const std::vector<std::vector<long>>& listOffsetToUserIndex) {
25 FAISS_ASSERT(numLists == listOffsetToUserIndex.size());
27 #pragma omp parallel for
28 for (
int q = 0; q < queries; ++q) {
29 for (
int r = 0; r < k; ++r) {
30 long offsetIndex = indices[q * k + r];
32 if (offsetIndex < 0)
continue;
34 int listId = (int) (offsetIndex >> 32);
35 int listOffset = (int) (offsetIndex & 0xffffffff);
37 FAISS_ASSERT(listId < numLists);
38 auto& listIndices = listOffsetToUserIndex[listId];
40 FAISS_ASSERT(listOffset < listIndices.size());
41 indices[q * k + r] = listIndices[listOffset];