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