-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathcompress_variable_byte.h
98 lines (90 loc) · 2.32 KB
/
compress_variable_byte.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
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
/*
COMPRESS_VARIABLE_BYTE.H
------------------------
*/
#ifndef COMPRESS_VARIABLE_BYTE_H_
#define COMPRESS_VARIABLE_BYTE_H_
#include "compress.h"
/*
class ANT_COMPRESS_VARIABLE_BYTE
--------------------------------
*/
class ANT_compress_variable_byte : public ANT_compress
{
public:
ANT_compress_variable_byte() {}
virtual ~ANT_compress_variable_byte() {}
virtual long long compress(unsigned char *destination, long long destination_length, uint32_t *source, long long source_integers);
virtual void decompress(uint32_t *destination, unsigned char *source, long long destination_integers);
static inline long compress_bytes_needed(long long docno);
static inline void compress_into(unsigned char *dest, long long docno);
} ;
/*
ANT_COMPRESS_VARIABLE_BYTE::COMPRESS_BYTES_NEEDED()
---------------------------------------------------
*/
inline long ANT_compress_variable_byte::compress_bytes_needed(long long docno)
{
if (docno < ((long long)1 << 7))
return 1;
else if (docno < ((long long)1 << 14))
return 2;
else if (docno < ((long long)1 << 21))
return 3;
else if (docno < ((long long)1 << 28))
return 4;
else if (docno < ((long long)1 << 35))
return 5;
else if (docno < ((long long)1 << 42))
return 6;
else if (docno < ((long long)1 << 49))
return 7;
else if (docno < ((long long)1 << 56))
return 8;
else
return 9;
}
/*
ANT_COMPRESS_VARIABLE_BYTE::COMPRESS_INTO()
-------------------------------------------
*/
inline void ANT_compress_variable_byte::compress_into(unsigned char *dest, long long docno)
{
if (docno < ((long long)1 << 7))
goto one;
else if (docno < ((long long)1 << 14))
goto two;
else if (docno < ((long long)1 << 21))
goto three;
else if (docno < ((long long)1 << 28))
goto four;
else if (docno < ((long long)1 << 35))
goto five;
else if (docno < ((long long)1 << 42))
goto six;
else if (docno < ((long long)1 << 49))
goto seven;
else if (docno < ((long long)1 << 56))
goto eight;
/*
Else we are a nine byte compressed integer
*/
*dest++ = (docno >> 56) & 0x7F;
eight:
*dest++ = (docno >> 49) & 0x7F;
seven:
*dest++ = (docno >> 42) & 0x7F;
six:
*dest++ = (docno >> 35) & 0x7F;
five:
*dest++ = (docno >> 28) & 0x7F;
four:
*dest++ = (docno >> 21) & 0x7F;
three:
*dest++ = (docno >> 14) & 0x7F;
two:
*dest++ = (docno >> 7) & 0x7F;
one:
*dest++ = (docno & 0x7F) | 0x80;
}
#endif /* COMPRESS_VARIABLE_BYTE_H_ */