pub struct RoaringBitmap { /* private fields */ }Expand description
A compressed bitmap using the Roaring bitmap compression scheme.
§Examples
use roaring::RoaringBitmap;
let mut rb = RoaringBitmap::new();
// insert all primes less than 10
rb.insert(2);
rb.insert(3);
rb.insert(5);
rb.insert(7);
println!("total bits set to true: {}", rb.len());Implementations§
Source§impl RoaringBitmap
 
impl RoaringBitmap
Sourcepub fn statistics(&self) -> Statistics
 
pub fn statistics(&self) -> Statistics
Returns statistics about the composition of a roaring bitmap.
use roaring::RoaringBitmap;
let mut bitmap: RoaringBitmap = (1..100).collect();
let statistics = bitmap.statistics();
assert_eq!(statistics.n_containers, 1);
assert_eq!(statistics.n_array_containers, 1);
assert_eq!(statistics.n_run_containers, 0);
assert_eq!(statistics.n_bitset_containers, 0);
assert_eq!(statistics.n_values_array_containers, 99);
assert_eq!(statistics.n_values_run_containers, 0);
assert_eq!(statistics.n_values_bitset_containers, 0);
assert_eq!(statistics.n_bytes_array_containers, 512);
assert_eq!(statistics.n_bytes_run_containers, 0);
assert_eq!(statistics.n_bytes_bitset_containers, 0);
assert_eq!(statistics.max_value, Some(99));
assert_eq!(statistics.min_value, Some(1));
assert_eq!(statistics.cardinality, 99);Source§impl RoaringBitmap
 
impl RoaringBitmap
Sourcepub fn is_disjoint(&self, other: &Self) -> bool
 
pub fn is_disjoint(&self, other: &Self) -> bool
Returns true if the set has no elements in common with other. This is equivalent to checking for an empty intersection.
§Examples
use roaring::RoaringBitmap;
let mut rb1 = RoaringBitmap::new();
let mut rb2 = RoaringBitmap::new();
rb1.insert(1);
assert_eq!(rb1.is_disjoint(&rb2), true);
rb2.insert(1);
assert_eq!(rb1.is_disjoint(&rb2), false);
Sourcepub fn is_subset(&self, other: &Self) -> bool
 
pub fn is_subset(&self, other: &Self) -> bool
Returns true if this set is a subset of other.
§Examples
use roaring::RoaringBitmap;
let mut rb1 = RoaringBitmap::new();
let mut rb2 = RoaringBitmap::new();
rb1.insert(1);
assert_eq!(rb1.is_subset(&rb2), false);
rb2.insert(1);
assert_eq!(rb1.is_subset(&rb2), true);
rb1.insert(2);
assert_eq!(rb1.is_subset(&rb2), false);Sourcepub fn is_superset(&self, other: &Self) -> bool
 
pub fn is_superset(&self, other: &Self) -> bool
Returns true if this set is a superset of other.
§Examples
use roaring::RoaringBitmap;
let mut rb1 = RoaringBitmap::new();
let mut rb2 = RoaringBitmap::new();
rb1.insert(1);
assert_eq!(rb2.is_superset(&rb1), false);
rb2.insert(1);
assert_eq!(rb2.is_superset(&rb1), true);
rb1.insert(2);
assert_eq!(rb2.is_superset(&rb1), false);Source§impl RoaringBitmap
 
impl RoaringBitmap
Sourcepub fn new() -> RoaringBitmap
 
pub fn new() -> RoaringBitmap
Creates an empty RoaringBitmap.
§Examples
use roaring::RoaringBitmap;
let rb = RoaringBitmap::new();Sourcepub fn full() -> RoaringBitmap
 
pub fn full() -> RoaringBitmap
Sourcepub fn from_lsb0_bytes(offset: u32, bytes: &[u8]) -> RoaringBitmap
 
pub fn from_lsb0_bytes(offset: u32, bytes: &[u8]) -> RoaringBitmap
Creates a RoaringBitmap from a byte slice, interpreting the bytes as a bitmap with a specified offset.
§Arguments
- offset: u32- The starting position in the bitmap where the byte slice will be applied, specified in bits. This means that if- offsetis- n, the first byte in the slice will correspond to the- nth bit(0-indexed) in the bitmap.
- bytes: &[u8]- The byte slice containing the bitmap data. The bytes are interpreted in “Least-Significant-First” bit order.
§Interpretation of bytes
The bytes slice is interpreted in “Least-Significant-First” bit order. Each byte is read from least significant bit (LSB) to most significant bit (MSB).
For example, the byte 0b00000101 represents the bits 1, 0, 1, 0, 0, 0, 0, 0 in that order (see Examples section).
§Panics
This function will panic if bytes.len() + offset is greater than 2^32.
§Examples
use roaring::RoaringBitmap;
let bytes = [0b00000101, 0b00000010, 0b00000000, 0b10000000];
//             ^^^^^^^^    ^^^^^^^^    ^^^^^^^^    ^^^^^^^^
//             76543210          98
let rb = RoaringBitmap::from_lsb0_bytes(0, &bytes);
assert!(rb.contains(0));
assert!(!rb.contains(1));
assert!(rb.contains(2));
assert!(rb.contains(9));
assert!(rb.contains(31));
let rb = RoaringBitmap::from_lsb0_bytes(8, &bytes);
assert!(rb.contains(8));
assert!(!rb.contains(9));
assert!(rb.contains(10));
assert!(rb.contains(17));
assert!(rb.contains(39));
let rb = RoaringBitmap::from_lsb0_bytes(3, &bytes);
assert!(rb.contains(3));
assert!(!rb.contains(4));
assert!(rb.contains(5));
assert!(rb.contains(12));
assert!(rb.contains(34));Sourcepub fn insert(&mut self, value: u32) -> bool
 
pub fn insert(&mut self, value: u32) -> bool
Adds a value to the set.
Returns whether the value was absent from the set.
§Examples
use roaring::RoaringBitmap;
let mut rb = RoaringBitmap::new();
assert_eq!(rb.insert(3), true);
assert_eq!(rb.insert(3), false);
assert_eq!(rb.contains(3), true);Sourcepub fn insert_range<R>(&mut self, range: R) -> u64where
    R: RangeBounds<u32>,
 
pub fn insert_range<R>(&mut self, range: R) -> u64where
    R: RangeBounds<u32>,
Inserts a range of values. Returns the number of inserted values.
§Examples
use roaring::RoaringBitmap;
let mut rb = RoaringBitmap::new();
rb.insert_range(2..4);
assert!(rb.contains(2));
assert!(rb.contains(3));
assert!(!rb.contains(4));Sourcepub fn push(&mut self, value: u32) -> bool
 👎Deprecated since 0.11.0: use try_push instead
pub fn push(&mut self, value: u32) -> bool
try_push insteadPushes value in the bitmap only if it is greater than the current maximum value.
Returns whether the value was inserted.
§Examples
use roaring::RoaringBitmap;
let mut rb = RoaringBitmap::new();
assert!(rb.push(1));
assert!(rb.push(3));
assert_eq!(rb.push(3), false);
assert!(rb.push(5));
assert_eq!(rb.iter().collect::<Vec<u32>>(), vec![1, 3, 5]);Sourcepub fn try_push(&mut self, value: u32) -> Result<(), IntegerTooSmall>
 
pub fn try_push(&mut self, value: u32) -> Result<(), IntegerTooSmall>
Pushes value in the bitmap only if it is greater than the current maximum value.
Returns an error if the value is not greater than the current maximum value.
§Examples
use roaring::{RoaringBitmap, IntegerTooSmall};
let mut rb = RoaringBitmap::new();
assert!(rb.try_push(1).is_ok());
assert!(rb.try_push(3).is_ok());
assert_eq!(rb.try_push(3), Err(IntegerTooSmall));
assert!(rb.try_push(5).is_ok());
assert_eq!(rb.iter().collect::<Vec<u32>>(), vec![1, 3, 5]);Sourcepub fn remove(&mut self, value: u32) -> bool
 
pub fn remove(&mut self, value: u32) -> bool
Removes a value from the set. Returns true if the value was present in the set.
§Examples
use roaring::RoaringBitmap;
let mut rb = RoaringBitmap::new();
rb.insert(3);
assert_eq!(rb.remove(3), true);
assert_eq!(rb.remove(3), false);
assert_eq!(rb.contains(3), false);Sourcepub fn remove_range<R>(&mut self, range: R) -> u64where
    R: RangeBounds<u32>,
 
pub fn remove_range<R>(&mut self, range: R) -> u64where
    R: RangeBounds<u32>,
Removes a range of values. Returns the number of removed values.
§Examples
use roaring::RoaringBitmap;
let mut rb = RoaringBitmap::new();
rb.insert(2);
rb.insert(3);
assert_eq!(rb.remove_range(2..4), 2);Sourcepub fn contains(&self, value: u32) -> bool
 
pub fn contains(&self, value: u32) -> bool
Returns true if this set contains the specified integer.
§Examples
use roaring::RoaringBitmap;
let mut rb = RoaringBitmap::new();
rb.insert(1);
assert_eq!(rb.contains(0), false);
assert_eq!(rb.contains(1), true);
assert_eq!(rb.contains(100), false);Sourcepub fn contains_range<R>(&self, range: R) -> boolwhere
    R: RangeBounds<u32>,
 
pub fn contains_range<R>(&self, range: R) -> boolwhere
    R: RangeBounds<u32>,
Returns true if all values in the range are present in this set.
§Examples
use roaring::RoaringBitmap;
let mut rb = RoaringBitmap::new();
// An empty range is always contained
assert!(rb.contains_range(7..7));
rb.insert_range(1..0xFFF);
assert!(rb.contains_range(1..0xFFF));
assert!(rb.contains_range(2..0xFFF));
// 0 is not contained
assert!(!rb.contains_range(0..2));
// 0xFFF is not contained
assert!(!rb.contains_range(1..=0xFFF));Sourcepub fn range_cardinality<R>(&self, range: R) -> u64where
    R: RangeBounds<u32>,
 
pub fn range_cardinality<R>(&self, range: R) -> u64where
    R: RangeBounds<u32>,
Returns the number of elements in this set which are in the passed range.
§Examples
use roaring::RoaringBitmap;
let mut rb = RoaringBitmap::new();
rb.insert_range(0x10000..0x40000);
rb.insert(0x50001);
rb.insert(0x50005);
rb.insert(u32::MAX);
assert_eq!(rb.range_cardinality(0..0x10000), 0);
assert_eq!(rb.range_cardinality(0x10000..0x40000), 0x30000);
assert_eq!(rb.range_cardinality(0x50000..0x60000), 2);
assert_eq!(rb.range_cardinality(0x10000..0x10000), 0);
assert_eq!(rb.range_cardinality(0x50000..=u32::MAX), 3);Sourcepub fn clear(&mut self)
 
pub fn clear(&mut self)
Clears all integers in this set.
§Examples
use roaring::RoaringBitmap;
let mut rb = RoaringBitmap::new();
rb.insert(1);
assert_eq!(rb.contains(1), true);
rb.clear();
assert_eq!(rb.contains(1), false);Sourcepub fn is_empty(&self) -> bool
 
pub fn is_empty(&self) -> bool
Returns true if there are no integers in this set.
§Examples
use roaring::RoaringBitmap;
let mut rb = RoaringBitmap::new();
assert_eq!(rb.is_empty(), true);
rb.insert(3);
assert_eq!(rb.is_empty(), false);Sourcepub fn is_full(&self) -> bool
 
pub fn is_full(&self) -> bool
Returns true if there are every possible integers in this set.
§Examples
use roaring::RoaringBitmap;
let mut rb = RoaringBitmap::full();
assert!(!rb.is_empty());
assert!(rb.is_full());Sourcepub fn len(&self) -> u64
 
pub fn len(&self) -> u64
Returns the number of distinct integers added to the set.
§Examples
use roaring::RoaringBitmap;
let mut rb = RoaringBitmap::new();
assert_eq!(rb.len(), 0);
rb.insert(3);
assert_eq!(rb.len(), 1);
rb.insert(3);
rb.insert(4);
assert_eq!(rb.len(), 2);Sourcepub fn min(&self) -> Option<u32>
 
pub fn min(&self) -> Option<u32>
Returns the minimum value in the set (if the set is non-empty).
§Examples
use roaring::RoaringBitmap;
let mut rb = RoaringBitmap::new();
assert_eq!(rb.min(), None);
rb.insert(3);
rb.insert(4);
assert_eq!(rb.min(), Some(3));Sourcepub fn max(&self) -> Option<u32>
 
pub fn max(&self) -> Option<u32>
Returns the maximum value in the set (if the set is non-empty).
§Examples
use roaring::RoaringBitmap;
let mut rb = RoaringBitmap::new();
assert_eq!(rb.max(), None);
rb.insert(3);
rb.insert(4);
assert_eq!(rb.max(), Some(4));Sourcepub fn rank(&self, value: u32) -> u64
 
pub fn rank(&self, value: u32) -> u64
Returns the number of integers that are <= value. rank(u32::MAX) == len()
§Examples
use roaring::RoaringBitmap;
let mut rb = RoaringBitmap::new();
assert_eq!(rb.rank(0), 0);
rb.insert(3);
rb.insert(4);
assert_eq!(rb.rank(3), 1);
assert_eq!(rb.rank(10), 2)Sourcepub fn select(&self, n: u32) -> Option<u32>
 
pub fn select(&self, n: u32) -> Option<u32>
Returns the nth integer in the set or None if n >= len()
§Examples
use roaring::RoaringBitmap;
let mut rb = RoaringBitmap::new();
assert_eq!(rb.select(0), None);
rb.append(vec![0, 10, 100]);
assert_eq!(rb.select(0), Some(0));
assert_eq!(rb.select(1), Some(10));
assert_eq!(rb.select(2), Some(100));
assert_eq!(rb.select(3), None);Sourcepub fn remove_smallest(&mut self, n: u64)
 
pub fn remove_smallest(&mut self, n: u64)
Removes the n smallests values from this bitmap.
§Examples
use roaring::RoaringBitmap;
let mut rb = RoaringBitmap::from_iter([1, 5, 7, 9]);
rb.remove_smallest(2);
assert_eq!(rb, RoaringBitmap::from_iter([7, 9]));
let mut rb = RoaringBitmap::from_iter([1, 3, 7, 9]);
rb.remove_smallest(2);
assert_eq!(rb, RoaringBitmap::from_iter([7, 9]));Sourcepub fn remove_biggest(&mut self, n: u64)
 
pub fn remove_biggest(&mut self, n: u64)
Removes the n biggests values from this bitmap.
§Examples
use roaring::RoaringBitmap;
let mut rb = RoaringBitmap::from_iter([1, 5, 7, 9]);
rb.remove_biggest(2);
assert_eq!(rb, RoaringBitmap::from_iter([1, 5]));
rb.remove_biggest(1);
assert_eq!(rb, RoaringBitmap::from_iter([1]));Sourcepub fn optimize(&mut self) -> bool
 
pub fn optimize(&mut self) -> bool
Optimizes the container storage for this bitmap. Returns true if the container storage was modified, false if not.
§Examples
use roaring::RoaringBitmap;
let mut rb = RoaringBitmap::from_iter(1000..100000);
rb.optimize();Sourcepub fn remove_run_compression(&mut self) -> bool
 
pub fn remove_run_compression(&mut self) -> bool
Removes run-length encoding even when it is more space efficient.
Returns true if the container storage was modified, false if not.
§Examples
use roaring::RoaringBitmap;
let mut rb = RoaringBitmap::from_iter(0..=10000);
rb.optimize();
assert!(rb.remove_run_compression());Source§impl RoaringBitmap
 
impl RoaringBitmap
Sourcepub fn iter(&self) -> Iter<'_> ⓘ
 
pub fn iter(&self) -> Iter<'_> ⓘ
Iterator over each value stored in the RoaringBitmap, guarantees values are ordered by value.
§Examples
use roaring::RoaringBitmap;
use core::iter::FromIterator;
let bitmap = (1..3).collect::<RoaringBitmap>();
let mut iter = bitmap.iter();
assert_eq!(iter.next(), Some(1));
assert_eq!(iter.next(), Some(2));
assert_eq!(iter.next(), None);Sourcepub fn range<R>(&self, range: R) -> Iter<'_> ⓘwhere
    R: RangeBounds<u32>,
 
pub fn range<R>(&self, range: R) -> Iter<'_> ⓘwhere
    R: RangeBounds<u32>,
Iterator over values within a range stored in the RoaringBitmap.
§Examples
use core::ops::Bound;
use roaring::RoaringBitmap;
let bitmap = RoaringBitmap::from([0, 1, 2, 3, 4, 5, 10, 11, 12, 20, 21, u32::MAX]);
let mut iter = bitmap.range(10..20);
assert_eq!(iter.next(), Some(10));
assert_eq!(iter.next(), Some(11));
assert_eq!(iter.next(), Some(12));
assert_eq!(iter.next(), None);
let mut iter = bitmap.range(100..);
assert_eq!(iter.next(), Some(u32::MAX));
assert_eq!(iter.next(), None);
let mut iter = bitmap.range((Bound::Excluded(0), Bound::Included(10)));
assert_eq!(iter.next(), Some(1));
assert_eq!(iter.next(), Some(2));
assert_eq!(iter.next(), Some(3));
assert_eq!(iter.next(), Some(4));
assert_eq!(iter.next(), Some(5));
assert_eq!(iter.next(), Some(10));
assert_eq!(iter.next(), None);Sourcepub fn into_range<R>(self, range: R) -> IntoIter ⓘwhere
    R: RangeBounds<u32>,
 
pub fn into_range<R>(self, range: R) -> IntoIter ⓘwhere
    R: RangeBounds<u32>,
Iterator over values within a range stored in the RoaringBitmap.
§Examples
use core::ops::Bound;
use roaring::RoaringBitmap;
fn bitmap() -> RoaringBitmap {
    RoaringBitmap::from([0, 1, 2, 3, 4, 5, 10, 11, 12, 20, 21, u32::MAX])
}
let mut iter = bitmap().into_range(10..20);
assert_eq!(iter.next(), Some(10));
assert_eq!(iter.next(), Some(11));
assert_eq!(iter.next(), Some(12));
assert_eq!(iter.next(), None);
let mut iter = bitmap().into_range(100..);
assert_eq!(iter.next(), Some(u32::MAX));
assert_eq!(iter.next(), None);
let mut iter = bitmap().into_range((Bound::Excluded(0), Bound::Included(10)));
assert_eq!(iter.next(), Some(1));
assert_eq!(iter.next(), Some(2));
assert_eq!(iter.next(), Some(3));
assert_eq!(iter.next(), Some(4));
assert_eq!(iter.next(), Some(5));
assert_eq!(iter.next(), Some(10));
assert_eq!(iter.next(), None);Source§impl RoaringBitmap
 
impl RoaringBitmap
Sourcepub fn from_sorted_iter<I: IntoIterator<Item = u32>>(
    iterator: I,
) -> Result<RoaringBitmap, NonSortedIntegers>
 
pub fn from_sorted_iter<I: IntoIterator<Item = u32>>( iterator: I, ) -> Result<RoaringBitmap, NonSortedIntegers>
Create the set from a sorted iterator. Values must be sorted and deduplicated.
The values of the iterator must be ordered and strictly greater than the greatest value in the set. If a value in the iterator doesn’t satisfy this requirement, it is not added and the append operation is stopped.
Returns Ok with the requested RoaringBitmap, Err with the number of elements
that were correctly appended before failure.
§Example: Create a set from an ordered list of integers.
use roaring::RoaringBitmap;
let mut rb = RoaringBitmap::from_sorted_iter(0..10).unwrap();
assert!(rb.iter().eq(0..10));§Example: Try to create a set from a non-ordered list of integers.
use roaring::RoaringBitmap;
let integers = 0..10u32;
let error = RoaringBitmap::from_sorted_iter(integers.rev()).unwrap_err();
assert_eq!(error.valid_until(), 1);Sourcepub fn append<I: IntoIterator<Item = u32>>(
    &mut self,
    iterator: I,
) -> Result<u64, NonSortedIntegers>
 
pub fn append<I: IntoIterator<Item = u32>>( &mut self, iterator: I, ) -> Result<u64, NonSortedIntegers>
Extend the set with a sorted iterator.
The values of the iterator must be ordered and strictly greater than the greatest value in the set. If a value in the iterator doesn’t satisfy this requirement, it is not added and the append operation is stopped.
Returns Ok with the number of elements appended to the set, Err with
the number of elements we effectively appended before an error occurred.
§Examples
use roaring::RoaringBitmap;
let mut rb = RoaringBitmap::new();
assert_eq!(rb.append(0..10), Ok(10));
assert!(rb.iter().eq(0..10));Source§impl RoaringBitmap
 
impl RoaringBitmap
Sourcepub fn intersection_len(&self, other: &RoaringBitmap) -> u64
 
pub fn intersection_len(&self, other: &RoaringBitmap) -> u64
Computes the len of the intersection with the specified other bitmap without creating a new bitmap.
This is faster and more space efficient when you’re only interested in the cardinality of the intersection.
§Examples
use roaring::RoaringBitmap;
let rb1: RoaringBitmap = (1..4).collect();
let rb2: RoaringBitmap = (3..5).collect();
assert_eq!(rb1.intersection_len(&rb2), (rb1 & rb2).len());Sourcepub fn union_len(&self, other: &RoaringBitmap) -> u64
 
pub fn union_len(&self, other: &RoaringBitmap) -> u64
Computes the len of the union with the specified other bitmap without creating a new bitmap.
This is faster and more space efficient when you’re only interested in the cardinality of the union.
§Examples
use roaring::RoaringBitmap;
let rb1: RoaringBitmap = (1..4).collect();
let rb2: RoaringBitmap = (3..5).collect();
assert_eq!(rb1.union_len(&rb2), (rb1 | rb2).len());Sourcepub fn difference_len(&self, other: &RoaringBitmap) -> u64
 
pub fn difference_len(&self, other: &RoaringBitmap) -> u64
Computes the len of the difference with the specified other bitmap without creating a new bitmap.
This is faster and more space efficient when you’re only interested in the cardinality of the difference.
§Examples
use roaring::RoaringBitmap;
let rb1: RoaringBitmap = (1..4).collect();
let rb2: RoaringBitmap = (3..5).collect();
assert_eq!(rb1.difference_len(&rb2), (rb1 - rb2).len());Sourcepub fn symmetric_difference_len(&self, other: &RoaringBitmap) -> u64
 
pub fn symmetric_difference_len(&self, other: &RoaringBitmap) -> u64
Computes the len of the symmetric difference with the specified other bitmap without creating a new bitmap.
This is faster and more space efficient when you’re only interested in the cardinality of the symmetric difference.
§Examples
use roaring::RoaringBitmap;
let rb1: RoaringBitmap = (1..4).collect();
let rb2: RoaringBitmap = (3..5).collect();
assert_eq!(rb1.symmetric_difference_len(&rb2), (rb1 ^ rb2).len());Source§impl RoaringBitmap
 
impl RoaringBitmap
Sourcepub fn intersection_with_serialized_unchecked<R>(
    &self,
    other: R,
) -> Result<RoaringBitmap>
 
pub fn intersection_with_serialized_unchecked<R>( &self, other: R, ) -> Result<RoaringBitmap>
Computes the intersection between a materialized RoaringBitmap and a serialized one.
This is faster and more space efficient when you only need the intersection result. It reduces the number of deserialized internal container and therefore the number of allocations and copies of bytes.
§Examples
use roaring::RoaringBitmap;
use std::io::Cursor;
let rb1: RoaringBitmap = (1..4).collect();
let rb2: RoaringBitmap = (3..5).collect();
// Let's say the rb2 bitmap is serialized
let mut bytes = Vec::new();
rb2.serialize_into(&mut bytes).unwrap();
let rb2_bytes = Cursor::new(bytes);
assert_eq!(
    rb1.intersection_with_serialized_unchecked(rb2_bytes).unwrap(),
    rb1 & rb2,
);Source§impl RoaringBitmap
 
impl RoaringBitmap
Sourcepub fn serialized_size(&self) -> usize
 
pub fn serialized_size(&self) -> usize
Return the size in bytes of the serialized output. This is compatible with the official C/C++, Java and Go implementations.
§Examples
use roaring::RoaringBitmap;
let rb1: RoaringBitmap = (1..4).collect();
let mut bytes = Vec::with_capacity(rb1.serialized_size());
rb1.serialize_into(&mut bytes).unwrap();
let rb2 = RoaringBitmap::deserialize_from(&bytes[..]).unwrap();
assert_eq!(rb1, rb2);Sourcepub fn serialize_into<W: Write>(&self, writer: W) -> Result<()>
 
pub fn serialize_into<W: Write>(&self, writer: W) -> Result<()>
Serialize this bitmap into the standard Roaring on-disk format. This is compatible with the official C/C++, Java and Go implementations.
§Examples
use roaring::RoaringBitmap;
let rb1: RoaringBitmap = (1..4).collect();
let mut bytes = vec![];
rb1.serialize_into(&mut bytes).unwrap();
let rb2 = RoaringBitmap::deserialize_from(&bytes[..]).unwrap();
assert_eq!(rb1, rb2);Sourcepub fn deserialize_from<R: Read>(reader: R) -> Result<RoaringBitmap>
 
pub fn deserialize_from<R: Read>(reader: R) -> Result<RoaringBitmap>
Deserialize a bitmap into memory from the standard Roaring on-disk format. This is compatible with the official C/C++, Java and Go implementations. This method checks that all of the internal values are valid. If deserializing from a trusted source consider RoaringBitmap::deserialize_unchecked_from
§Examples
use roaring::RoaringBitmap;
let rb1: RoaringBitmap = (1..4).collect();
let mut bytes = vec![];
rb1.serialize_into(&mut bytes).unwrap();
let rb2 = RoaringBitmap::deserialize_from(&bytes[..]).unwrap();
assert_eq!(rb1, rb2);Sourcepub fn deserialize_unchecked_from<R: Read>(reader: R) -> Result<RoaringBitmap>
 
pub fn deserialize_unchecked_from<R: Read>(reader: R) -> Result<RoaringBitmap>
Deserialize a bitmap into memory from the standard Roaring on-disk format. This is compatible with the official C/C++, Java and Go implementations. This method is memory safe but will not check if the data is a valid bitmap.
§Examples
use roaring::RoaringBitmap;
let rb1: RoaringBitmap = (1..4).collect();
let mut bytes = vec![];
rb1.serialize_into(&mut bytes).unwrap();
let rb2 = RoaringBitmap::deserialize_unchecked_from(&bytes[..]).unwrap();
assert_eq!(rb1, rb2);Trait Implementations§
Source§impl BitAnd<&RoaringBitmap> for &RoaringBitmap
 
impl BitAnd<&RoaringBitmap> for &RoaringBitmap
Source§fn bitand(self, rhs: &RoaringBitmap) -> RoaringBitmap
 
fn bitand(self, rhs: &RoaringBitmap) -> RoaringBitmap
An intersection between two sets.
Source§type Output = RoaringBitmap
 
type Output = RoaringBitmap
& operator.Source§impl BitAnd<&RoaringBitmap> for RoaringBitmap
 
impl BitAnd<&RoaringBitmap> for RoaringBitmap
Source§fn bitand(self, rhs: &RoaringBitmap) -> RoaringBitmap
 
fn bitand(self, rhs: &RoaringBitmap) -> RoaringBitmap
An intersection between two sets.
Source§type Output = RoaringBitmap
 
type Output = RoaringBitmap
& operator.Source§impl BitAnd<RoaringBitmap> for &RoaringBitmap
 
impl BitAnd<RoaringBitmap> for &RoaringBitmap
Source§fn bitand(self, rhs: RoaringBitmap) -> RoaringBitmap
 
fn bitand(self, rhs: RoaringBitmap) -> RoaringBitmap
An intersection between two sets.
Source§type Output = RoaringBitmap
 
type Output = RoaringBitmap
& operator.Source§impl BitAnd for RoaringBitmap
 
impl BitAnd for RoaringBitmap
Source§fn bitand(self, rhs: RoaringBitmap) -> RoaringBitmap
 
fn bitand(self, rhs: RoaringBitmap) -> RoaringBitmap
An intersection between two sets.
Source§type Output = RoaringBitmap
 
type Output = RoaringBitmap
& operator.Source§impl BitAndAssign<&RoaringBitmap> for RoaringBitmap
 
impl BitAndAssign<&RoaringBitmap> for RoaringBitmap
Source§fn bitand_assign(&mut self, rhs: &RoaringBitmap)
 
fn bitand_assign(&mut self, rhs: &RoaringBitmap)
An intersection between two sets.
Source§impl BitAndAssign for RoaringBitmap
 
impl BitAndAssign for RoaringBitmap
Source§fn bitand_assign(&mut self, rhs: RoaringBitmap)
 
fn bitand_assign(&mut self, rhs: RoaringBitmap)
An intersection between two sets.
Source§impl BitOr<&RoaringBitmap> for &RoaringBitmap
 
impl BitOr<&RoaringBitmap> for &RoaringBitmap
Source§fn bitor(self, rhs: &RoaringBitmap) -> RoaringBitmap
 
fn bitor(self, rhs: &RoaringBitmap) -> RoaringBitmap
An union between two sets.
Source§type Output = RoaringBitmap
 
type Output = RoaringBitmap
| operator.Source§impl BitOr<&RoaringBitmap> for RoaringBitmap
 
impl BitOr<&RoaringBitmap> for RoaringBitmap
Source§fn bitor(self, rhs: &RoaringBitmap) -> RoaringBitmap
 
fn bitor(self, rhs: &RoaringBitmap) -> RoaringBitmap
An union between two sets.
Source§type Output = RoaringBitmap
 
type Output = RoaringBitmap
| operator.Source§impl BitOr<RoaringBitmap> for &RoaringBitmap
 
impl BitOr<RoaringBitmap> for &RoaringBitmap
Source§fn bitor(self, rhs: RoaringBitmap) -> RoaringBitmap
 
fn bitor(self, rhs: RoaringBitmap) -> RoaringBitmap
An union between two sets.
Source§type Output = RoaringBitmap
 
type Output = RoaringBitmap
| operator.Source§impl BitOr for RoaringBitmap
 
impl BitOr for RoaringBitmap
Source§fn bitor(self, rhs: RoaringBitmap) -> RoaringBitmap
 
fn bitor(self, rhs: RoaringBitmap) -> RoaringBitmap
An union between two sets.
Source§type Output = RoaringBitmap
 
type Output = RoaringBitmap
| operator.Source§impl BitOrAssign<&RoaringBitmap> for RoaringBitmap
 
impl BitOrAssign<&RoaringBitmap> for RoaringBitmap
Source§fn bitor_assign(&mut self, rhs: &RoaringBitmap)
 
fn bitor_assign(&mut self, rhs: &RoaringBitmap)
An union between two sets.
Source§impl BitOrAssign for RoaringBitmap
 
impl BitOrAssign for RoaringBitmap
Source§fn bitor_assign(&mut self, rhs: RoaringBitmap)
 
fn bitor_assign(&mut self, rhs: RoaringBitmap)
An union between two sets.
Source§impl BitXor<&RoaringBitmap> for &RoaringBitmap
 
impl BitXor<&RoaringBitmap> for &RoaringBitmap
Source§fn bitxor(self, rhs: &RoaringBitmap) -> RoaringBitmap
 
fn bitxor(self, rhs: &RoaringBitmap) -> RoaringBitmap
A symmetric difference between two sets.
Source§type Output = RoaringBitmap
 
type Output = RoaringBitmap
^ operator.Source§impl BitXor<&RoaringBitmap> for RoaringBitmap
 
impl BitXor<&RoaringBitmap> for RoaringBitmap
Source§fn bitxor(self, rhs: &RoaringBitmap) -> RoaringBitmap
 
fn bitxor(self, rhs: &RoaringBitmap) -> RoaringBitmap
A symmetric difference between two sets.
Source§type Output = RoaringBitmap
 
type Output = RoaringBitmap
^ operator.Source§impl BitXor<RoaringBitmap> for &RoaringBitmap
 
impl BitXor<RoaringBitmap> for &RoaringBitmap
Source§fn bitxor(self, rhs: RoaringBitmap) -> RoaringBitmap
 
fn bitxor(self, rhs: RoaringBitmap) -> RoaringBitmap
A symmetric difference between two sets.
Source§type Output = RoaringBitmap
 
type Output = RoaringBitmap
^ operator.Source§impl BitXor for RoaringBitmap
 
impl BitXor for RoaringBitmap
Source§fn bitxor(self, rhs: RoaringBitmap) -> RoaringBitmap
 
fn bitxor(self, rhs: RoaringBitmap) -> RoaringBitmap
A symmetric difference between two sets.
Source§type Output = RoaringBitmap
 
type Output = RoaringBitmap
^ operator.Source§impl BitXorAssign<&RoaringBitmap> for RoaringBitmap
 
impl BitXorAssign<&RoaringBitmap> for RoaringBitmap
Source§fn bitxor_assign(&mut self, rhs: &RoaringBitmap)
 
fn bitxor_assign(&mut self, rhs: &RoaringBitmap)
A symmetric difference between two sets.
Source§impl BitXorAssign for RoaringBitmap
 
impl BitXorAssign for RoaringBitmap
Source§fn bitxor_assign(&mut self, rhs: RoaringBitmap)
 
fn bitxor_assign(&mut self, rhs: RoaringBitmap)
A symmetric difference between two sets.
Source§impl Clone for RoaringBitmap
 
impl Clone for RoaringBitmap
Source§impl Debug for RoaringBitmap
 
impl Debug for RoaringBitmap
Source§impl Default for RoaringBitmap
 
impl Default for RoaringBitmap
Source§fn default() -> RoaringBitmap
 
fn default() -> RoaringBitmap
Source§impl<'a> Extend<&'a u32> for RoaringBitmap
 
impl<'a> Extend<&'a u32> for RoaringBitmap
Source§fn extend<I: IntoIterator<Item = &'a u32>>(&mut self, values: I)
 
fn extend<I: IntoIterator<Item = &'a u32>>(&mut self, values: I)
Inserts multiple values and returns the count of new additions.
This is expected to be faster than calling RoaringBitmap::insert on each value.
The provided integers values don’t have to be in sorted order, but it may be preferable to sort them from a performance point of view.
§Examples
use roaring::RoaringBitmap;
let mut rb = RoaringBitmap::new();
rb.extend([1, 2, 3, 4, 1500, 1508, 1507, 1509]);
assert!(rb.contains(2));
assert!(rb.contains(1508));
assert!(!rb.contains(5));Source§fn extend_one(&mut self, item: A)
 
fn extend_one(&mut self, item: A)
extend_one)Source§fn extend_reserve(&mut self, additional: usize)
 
fn extend_reserve(&mut self, additional: usize)
extend_one)Source§impl Extend<u32> for RoaringBitmap
 
impl Extend<u32> for RoaringBitmap
Source§fn extend<I: IntoIterator<Item = u32>>(&mut self, values: I)
 
fn extend<I: IntoIterator<Item = u32>>(&mut self, values: I)
Inserts multiple values and returns the count of new additions.
This is expected to be faster than calling RoaringBitmap::insert on each value.
The provided integers values don’t have to be in sorted order, but it may be preferable to sort them from a performance point of view.
§Examples
use roaring::RoaringBitmap;
let mut rb = RoaringBitmap::new();
rb.extend([1, 2, 3, 4, 1500, 1508, 1507, 1509]);
assert!(rb.contains(2));
assert!(rb.contains(1508));
assert!(!rb.contains(5));Source§fn extend_one(&mut self, item: A)
 
fn extend_one(&mut self, item: A)
extend_one)Source§fn extend_reserve(&mut self, additional: usize)
 
fn extend_reserve(&mut self, additional: usize)
extend_one)Source§impl<'a> FromIterator<&'a u32> for RoaringBitmap
 
impl<'a> FromIterator<&'a u32> for RoaringBitmap
Source§fn from_iter<I: IntoIterator<Item = &'a u32>>(iterator: I) -> RoaringBitmap
 
fn from_iter<I: IntoIterator<Item = &'a u32>>(iterator: I) -> RoaringBitmap
Source§impl FromIterator<u32> for RoaringBitmap
 
impl FromIterator<u32> for RoaringBitmap
Source§fn from_iter<I: IntoIterator<Item = u32>>(iterator: I) -> RoaringBitmap
 
fn from_iter<I: IntoIterator<Item = u32>>(iterator: I) -> RoaringBitmap
Source§impl<'a> IntoIterator for &'a RoaringBitmap
 
impl<'a> IntoIterator for &'a RoaringBitmap
Source§impl IntoIterator for RoaringBitmap
 
impl IntoIterator for RoaringBitmap
Source§impl<'a, I> MultiOps<&'a RoaringBitmap> for Iwhere
    I: IntoIterator<Item = &'a RoaringBitmap>,
 
impl<'a, I> MultiOps<&'a RoaringBitmap> for Iwhere
    I: IntoIterator<Item = &'a RoaringBitmap>,
Source§type Output = RoaringBitmap
 
type Output = RoaringBitmap
Source§fn intersection(self) -> Self::Output
 
fn intersection(self) -> Self::Output
intersection between all elements.Source§fn difference(self) -> Self::Output
 
fn difference(self) -> Self::Output
difference between all elements.Source§fn symmetric_difference(self) -> Self::Output
 
fn symmetric_difference(self) -> Self::Output
symmetric difference between all elements.Source§impl<I> MultiOps<RoaringBitmap> for Iwhere
    I: IntoIterator<Item = RoaringBitmap>,
 
impl<I> MultiOps<RoaringBitmap> for Iwhere
    I: IntoIterator<Item = RoaringBitmap>,
Source§type Output = RoaringBitmap
 
type Output = RoaringBitmap
Source§fn intersection(self) -> Self::Output
 
fn intersection(self) -> Self::Output
intersection between all elements.Source§fn difference(self) -> Self::Output
 
fn difference(self) -> Self::Output
difference between all elements.Source§fn symmetric_difference(self) -> Self::Output
 
fn symmetric_difference(self) -> Self::Output
symmetric difference between all elements.Source§impl PartialEq for RoaringBitmap
 
impl PartialEq for RoaringBitmap
Source§impl Sub<&RoaringBitmap> for &RoaringBitmap
 
impl Sub<&RoaringBitmap> for &RoaringBitmap
Source§fn sub(self, rhs: &RoaringBitmap) -> RoaringBitmap
 
fn sub(self, rhs: &RoaringBitmap) -> RoaringBitmap
A difference between two sets.
Source§type Output = RoaringBitmap
 
type Output = RoaringBitmap
- operator.Source§impl Sub<&RoaringBitmap> for RoaringBitmap
 
impl Sub<&RoaringBitmap> for RoaringBitmap
Source§fn sub(self, rhs: &RoaringBitmap) -> RoaringBitmap
 
fn sub(self, rhs: &RoaringBitmap) -> RoaringBitmap
A difference between two sets.
Source§type Output = RoaringBitmap
 
type Output = RoaringBitmap
- operator.Source§impl Sub<RoaringBitmap> for &RoaringBitmap
 
impl Sub<RoaringBitmap> for &RoaringBitmap
Source§fn sub(self, rhs: RoaringBitmap) -> RoaringBitmap
 
fn sub(self, rhs: RoaringBitmap) -> RoaringBitmap
A difference between two sets.
Source§type Output = RoaringBitmap
 
type Output = RoaringBitmap
- operator.Source§impl Sub for RoaringBitmap
 
impl Sub for RoaringBitmap
Source§fn sub(self, rhs: RoaringBitmap) -> RoaringBitmap
 
fn sub(self, rhs: RoaringBitmap) -> RoaringBitmap
A difference between two sets.
Source§type Output = RoaringBitmap
 
type Output = RoaringBitmap
- operator.Source§impl SubAssign<&RoaringBitmap> for RoaringBitmap
 
impl SubAssign<&RoaringBitmap> for RoaringBitmap
Source§fn sub_assign(&mut self, rhs: &RoaringBitmap)
 
fn sub_assign(&mut self, rhs: &RoaringBitmap)
A difference between two sets.
Source§impl SubAssign for RoaringBitmap
 
impl SubAssign for RoaringBitmap
Source§fn sub_assign(&mut self, rhs: RoaringBitmap)
 
fn sub_assign(&mut self, rhs: RoaringBitmap)
A difference between two sets.