use of io.druid.extendedset.intset.ConciseSet in project druid by druid-io.
the class RangeBitmapBenchmarkTest method prepareRandomRanges.
@BeforeClass
public static void prepareRandomRanges() throws Exception {
System.setProperty("jub.customkey", String.format("%06.5f", DENSITY));
reset();
final BitSet expectedUnion = new BitSet();
for (int i = 0; i < SIZE; ++i) {
ConciseSet c = new ConciseSet();
MutableRoaringBitmap r = new MutableRoaringBitmap();
{
int k = 0;
boolean fill = true;
while (k < LENGTH) {
int runLength = (int) (LENGTH * DENSITY) + rand.nextInt((int) (LENGTH * DENSITY));
for (int j = k; fill && j < LENGTH && j < k + runLength; ++j) {
c.add(j);
r.add(j);
expectedUnion.set(j);
}
k += runLength;
fill = !fill;
}
}
minIntersection = MIN_INTERSECT;
for (int k = LENGTH / 2; k < LENGTH / 2 + minIntersection; ++k) {
c.add(k);
r.add(k);
expectedUnion.set(k);
}
concise[i] = ImmutableConciseSet.newImmutableFromMutable(c);
offheapConcise[i] = makeOffheapConcise(concise[i]);
roaring[i] = r;
immutableRoaring[i] = makeImmutableRoaring(r);
offheapRoaring[i] = makeOffheapRoaring(r);
genericConcise[i] = new WrappedImmutableConciseBitmap(offheapConcise[i]);
genericRoaring[i] = new WrappedImmutableRoaringBitmap(offheapRoaring[i]);
}
unionCount = expectedUnion.cardinality();
printSizeStats(DENSITY, "Random Alternating Bitmap");
}
use of io.druid.extendedset.intset.ConciseSet in project druid by druid-io.
the class UniformBitmapBenchmarkTest method prepareMostlyUniform.
@BeforeClass
public static void prepareMostlyUniform() throws Exception {
System.setProperty("jub.customkey", String.format("%05.4f", DENSITY));
reset();
final BitSet expectedUnion = new BitSet();
final int[] knownTrue = new int[MIN_INTERSECT];
for (int i = 0; i < knownTrue.length; ++i) {
knownTrue[i] = rand.nextInt(LENGTH);
}
for (int i = 0; i < SIZE; ++i) {
ConciseSet c = new ConciseSet();
MutableRoaringBitmap r = new MutableRoaringBitmap();
for (int k = 0; k < LENGTH; ++k) {
if (rand.nextDouble() < DENSITY) {
c.add(k);
r.add(k);
expectedUnion.set(k);
}
}
for (int k : knownTrue) {
c.add(k);
r.add(k);
expectedUnion.set(k);
}
concise[i] = ImmutableConciseSet.newImmutableFromMutable(c);
offheapConcise[i] = makeOffheapConcise(concise[i]);
roaring[i] = r;
immutableRoaring[i] = makeImmutableRoaring(r);
offheapRoaring[i] = makeOffheapRoaring(r);
genericConcise[i] = new WrappedImmutableConciseBitmap(offheapConcise[i]);
genericRoaring[i] = new WrappedImmutableRoaringBitmap(offheapRoaring[i]);
}
unionCount = expectedUnion.cardinality();
minIntersection = knownTrue.length;
printSizeStats(DENSITY, "Uniform Bitmap");
}
use of io.druid.extendedset.intset.ConciseSet in project druid by druid-io.
the class WrappedConciseBitmap method andNot.
@Override
public void andNot(MutableBitmap mutableBitmap) {
WrappedConciseBitmap other = (WrappedConciseBitmap) mutableBitmap;
ConciseSet unwrappedOtherBitmap = other.bitmap;
bitmap = bitmap.difference(unwrappedOtherBitmap);
}
use of io.druid.extendedset.intset.ConciseSet in project druid by druid-io.
the class WrappedConciseBitmap method union.
@Override
public ImmutableBitmap union(ImmutableBitmap otherBitmap) {
WrappedConciseBitmap other = (WrappedConciseBitmap) otherBitmap;
ConciseSet unwrappedOtherBitmap = other.bitmap;
return new WrappedConciseBitmap(bitmap.clone().union(unwrappedOtherBitmap));
}
use of io.druid.extendedset.intset.ConciseSet in project druid by druid-io.
the class WrappedConciseBitmap method intersection.
@Override
public ImmutableBitmap intersection(ImmutableBitmap otherBitmap) {
WrappedConciseBitmap other = (WrappedConciseBitmap) otherBitmap;
ConciseSet unwrappedOtherBitmap = other.bitmap;
return new WrappedConciseBitmap(bitmap.clone().intersection(unwrappedOtherBitmap));
}
Aggregations