forked from efficient/rankselect
-
Notifications
You must be signed in to change notification settings - Fork 3
/
bitmap.h
83 lines (63 loc) · 2.01 KB
/
bitmap.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
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
/**
Copyright 2013 Carnegie Mellon University
Authors: Dong Zhou, David G. Andersen and Michale Kaminsky
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
/* -*- Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -* -*/
#ifndef _BITMAP_H_
#define _BITMAP_H_
#include <assert.h>
#include <stdio.h>
#include <stdlib.h>
#include <sys/types.h>
#include <stdint.h>
#include <string.h>
#define __STDC_FORMAT_MACROS
#include <inttypes.h>
#include "shared.h"
const int kWordSize = 64;
const int kBasicBlockSize = 512;
const int kBasicBlockBits = 9;
const int kBasicBlockMask = kBasicBlockSize - 1;
const int kWordCountPerBasicBlock = kBasicBlockSize / kWordSize;
class Bitmap {
public:
Bitmap() { pCount_ = 0; }
virtual uint64 rank(uint64 pos) = 0;
virtual uint64 select(uint64 rank) = 0;
virtual uint64 selectWord(uint64 idx, uint64 rank) = 0;
uint64 pCount() { return pCount_; }
protected:
uint64 pCount_;
};
class BitmapPoppy: public Bitmap {
public:
BitmapPoppy(uint64* bits, uint64 nbits);
~BitmapPoppy() {}
uint64 rank(uint64 pos);
uint64 select(uint64 rank);
uint64 selectWord(uint64 idx, uint64 rank);
private:
uint64* bits_;
uint64 nbits_;
uint64* l2Entries_;
uint64 l2EntryCount_;
uint64* l1Entries_;
uint64 l1EntryCount_;
uint64 basicBlockCount_;
uint32* loc_[1ULL << 31];
uint64 locCount_[1ULL << 31];
static const int kLocFreq = 8192;
static const int kLocFreqMask = 8191;
static const int kL2EntryCountPerL1Entry = 1 << 21;
static const int kBasicBlockCountPerL1Entry = 1 << 23;
};
#endif /* _BITMAP_H_ */