-
Notifications
You must be signed in to change notification settings - Fork 25
/
Copy pathindexing.h
45 lines (38 loc) · 2.77 KB
/
indexing.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
#include "LSHReservoirSampler_config.h"
#ifndef INDEXING_H
#define INDEXING_H
#define TABLENULL -1
#define HASH(x,M,a,b) (unsigned)((unsigned) (a * x + b) >> (32 - M))
#define BINHASH(x,a,b) (unsigned)((unsigned) (a * x + b) >> 31)
/* Datastructure Indexing. */
// _tableCountersLock:
#define tableCountersLockIdx(tb, allocIdx, aggNumReservoirs) (unsigned long long)(tb * aggNumReservoirs + allocIdx)
// _tableMem: Start of the data section of a reservoir.
#define tableMemResIdx(tb, allocIdx, aggNumReservoirs) (unsigned long long)(tb * aggNumReservoirs * (_reservoirSize + 1) + allocIdx * (_reservoirSize + 1) + 1)
// _tableMem: The counter section of a reservoir.
#define tableMemCtIdx(tb, allocIdx, aggNumReservoirs) (unsigned long long)(tb * aggNumReservoirs * (_reservoirSize + 1) + allocIdx * (_reservoirSize + 1))
// _tablePointers & _tablePointersLock: location of a pointer.
#if defined SECONDARY_HASHING
#define tablePointersIdx(numReservoirsHashed, hashIdx, tb, a, b) (unsigned long long)(tb * numReservoirsHashed + HASH(hashIdx, _numSecHash, a, b))
#else
#define tablePointersIdx(numReservoirsHashed, hashIdx, tb, a, b) (unsigned long long)(tb * numReservoirsHashed + hashIdx)
#endif // SECONDARY_HASHING.
// _tableMemAllocator: counter for allocating _tableMem, one per table.
#define tableMemAllocatorIdx(tb) (unsigned)(tb)
// queue: a particular element in the aggregated queue.
#define queueElemIdx(segmentSizePow2, tb, queryIdx, probeIdx, elemIdx) (unsigned)(queryIdx * segmentSizePow2 + tb * _reservoirSize * _queryProbes + probeIdx * _reservoirSize + elemIdx) // The start position of the segment for a particular query giventhe entire segment.
// topk queue: the start location of that of a query.
#define topkIdx(topk, queryIdx) (unsigned)(queryIdx * topk) // Indexing in the topk queue.
// allprobsHash: the hashIdx of an input-probe, i is its index in numProbePerTb.
#define allprobsHashSimpleIdx(numProbePerTb, tb, i) (unsigned)(numProbePerTb * tb + i)
// allprobsHash: the hashIdx of an input-probe.
#define allprobsHashIdx(numProbes, numInputEntries, tb, inputIdx, probsIdx) (unsigned)(numInputEntries * numProbes * tb + inputIdx * numProbes + probsIdx)
// storelog: the id of an input.
#define storelogIdIdx(numProbsPerTb, probeIdx, tb) (unsigned)(numProbsPerTb * tb * 4 + 4 * probeIdx)
// storelog: the assigned counter of an input.
#define storelogCounterIdx(numProbsPerTb, probeIdx, tb) (unsigned)(numProbsPerTb * tb * 4 + 4 * probeIdx + 1)
// storelog: the location of storage (in-reservoir) of an input.
#define storelogLocationIdx(numProbsPerTb, probeIdx, tb) (unsigned)(numProbsPerTb * tb * 4 + 4 * probeIdx + 2)
// storelog: the hashIdx of an input.
#define storelogHashIdxIdx(numProbsPerTb, probeIdx, tb) (unsigned)(numProbsPerTb * tb * 4 + 4 * probeIdx + 3)
#endif /* INDEXING_H */