-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathREADME
72 lines (60 loc) · 1.6 KB
/
README
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
jbloom - jni-powered bloom filters for java
written by John Muellerleile (@jrecursive)
* jbloom is a java native interface wrapper around a modified version of open bloom
* serialize / deserialize compatible with ebloom (erlang NIF) http://bitbucket.org/basho/ebloom/
* see src/jbloom/TestJBloom.java for an introduction to all the functions.
* i'll update the build process to something sane soon, until then -- sorry, see build_osx.sh or build_linux.sh, depending.
* the build process currently creates 64 bit binaries
* build should output something like this if successful:
cleaning...
javac...
javah...
build native lib...
run jbloom.test
b1.contains('JBloom') = true
b1.contains('giraffes') = false
JBloom.effectiveFPP() = 1.4086502789328668E-27
JBloom.intersect(b1, b2)
b1.contains('JBloom') = false
b1.contains('lucky') = true
b1.contains('lobster') = false
JBloom.union(b1, b3)
b1.contains('lucky') = true
b1.contains('lobster') = true
b1.contains('JBloom') = true
JBloom.difference(b1, b3);
b1.contains('giraffes') = false
b1.contains('trees') = true
b1.contains('sharks') = true
b1.contains('lucky') = false
b1.serialize();
bytes.length = 12068
b4.contains('giraffes') = false
b4.contains('trees') = true
b4.contains('sharks') = true
b4.contains('lucky') = false
performing 1m inserts...
1m inserts took 1371ms
10% fpp, serialized size is 601101 bytes and took 17ms
sanity check
0: true
1: true
2: true
3: true
4: true
5: true
6: true
7: true
8: true
9: true
2000000: false
2000001: false
2000002: false
2000003: false
2000004: true
2000005: false
2000006: false
2000007: false
2000008: false
2000009: false
* enjoy!