11 #include "RemapIndices.h"
12 #include "../../FaissAssert.h"
14 namespace faiss {
namespace gpu {
18 void ivfOffsetToUserIndex(
23 const std::vector<std::vector<long>>& listOffsetToUserIndex) {
24 FAISS_ASSERT(numLists == listOffsetToUserIndex.size());
26 #pragma omp parallel for
27 for (
int q = 0; q < queries; ++q) {
28 for (
int r = 0; r < k; ++r) {
29 long offsetIndex = indices[q * k + r];
31 if (offsetIndex < 0)
continue;
33 int listId = (int) (offsetIndex >> 32);
34 int listOffset = (int) (offsetIndex & 0xffffffff);
36 FAISS_ASSERT(listId < numLists);
37 auto& listIndices = listOffsetToUserIndex[listId];
39 FAISS_ASSERT(listOffset < listIndices.size());
40 indices[q * k + r] = listIndices[listOffset];