mirror of
https://github.com/meilisearch/MeiliSearch
synced 2025-07-04 20:37:15 +02:00
Optimize cbo roaring bitmaps merge
This commit is contained in:
parent
8f702828ca
commit
9452fabfb2
3 changed files with 93 additions and 51 deletions
|
@ -120,52 +120,11 @@ pub fn merge_cbo_roaring_bitmaps<'a>(
|
|||
_key: &[u8],
|
||||
values: &[Cow<'a, [u8]>],
|
||||
) -> Result<Cow<'a, [u8]>> {
|
||||
match values.split_first().unwrap() {
|
||||
(head, []) => Ok(head.clone()),
|
||||
(head, tail) => {
|
||||
let mut head = CboRoaringBitmapCodec::deserialize_from(&head[..])?;
|
||||
|
||||
for value in tail {
|
||||
head |= CboRoaringBitmapCodec::deserialize_from(&value[..])?;
|
||||
}
|
||||
|
||||
let mut vec = Vec::new();
|
||||
CboRoaringBitmapCodec::serialize_into(&head, &mut vec);
|
||||
Ok(Cow::from(vec))
|
||||
}
|
||||
if values.len() == 1 {
|
||||
Ok(values[0].clone())
|
||||
} else {
|
||||
let mut vec = Vec::new();
|
||||
CboRoaringBitmapCodec::merge_into(values, &mut vec)?;
|
||||
Ok(Cow::from(vec))
|
||||
}
|
||||
}
|
||||
|
||||
// /// Uses the FacetStringLevelZeroValueCodec to merge the values.
|
||||
// pub fn tuple_string_cbo_roaring_bitmap_merge<'a>(
|
||||
// _key: &[u8],
|
||||
// values: &[Cow<[u8]>],
|
||||
// ) -> Result<Cow<'a, [u8]>> {
|
||||
// let (head, tail) = values.split_first().unwrap();
|
||||
// let (head_string, mut head_rb) = FacetStringLevelZeroValueCodec::bytes_decode(&head[..])
|
||||
// .ok_or(SerializationError::Decoding { db_name: None })?;
|
||||
|
||||
// for value in tail {
|
||||
// let (_string, rb) = FacetStringLevelZeroValueCodec::bytes_decode(&value[..])
|
||||
// .ok_or(SerializationError::Decoding { db_name: None })?;
|
||||
// head_rb |= rb;
|
||||
// }
|
||||
|
||||
// FacetStringLevelZeroValueCodec::bytes_encode(&(head_string, head_rb))
|
||||
// .map(|cow| cow.into_owned())
|
||||
// .ok_or(SerializationError::Encoding { db_name: None })
|
||||
// .map_err(Into::into)
|
||||
// }
|
||||
|
||||
// pub fn cbo_roaring_bitmap_merge<'a>(_key: &[u8], values: &[Cow<[u8]>]) -> Result<Cow<'a, [u8]>> {
|
||||
// let (head, tail) = values.split_first().unwrap();
|
||||
// let mut head = CboRoaringBitmapCodec::deserialize_from(&head[..])?;
|
||||
|
||||
// for value in tail {
|
||||
// head |= CboRoaringBitmapCodec::deserialize_from(&value[..])?;
|
||||
// }
|
||||
|
||||
// let mut vec = Vec::new();
|
||||
// CboRoaringBitmapCodec::serialize_into(&head, &mut vec);
|
||||
// Ok(vec)
|
||||
// }
|
||||
|
|
|
@ -188,15 +188,22 @@ fn merge_roaring_bitmaps(new_value: &[u8], db_value: &[u8], buffer: &mut Vec<u8>
|
|||
Ok(serialize_roaring_bitmap(&value, buffer)?)
|
||||
}
|
||||
|
||||
use std::borrow::Cow;
|
||||
|
||||
fn merge_cbo_roaring_bitmaps(
|
||||
new_value: &[u8],
|
||||
db_value: &[u8],
|
||||
buffer: &mut Vec<u8>,
|
||||
) -> Result<()> {
|
||||
let new_value = CboRoaringBitmapCodec::deserialize_from(new_value)?;
|
||||
let db_value = CboRoaringBitmapCodec::deserialize_from(db_value)?;
|
||||
let value = new_value | db_value;
|
||||
Ok(CboRoaringBitmapCodec::serialize_into(&value, buffer))
|
||||
Ok(CboRoaringBitmapCodec::merge_into(
|
||||
&[Cow::Borrowed(db_value), Cow::Borrowed(new_value)],
|
||||
buffer,
|
||||
)?)
|
||||
|
||||
// let new_value = CboRoaringBitmapCodec::deserialize_from(new_value)?;
|
||||
// let db_value = CboRoaringBitmapCodec::deserialize_from(db_value)?;
|
||||
// let value = new_value | db_value;
|
||||
// Ok(CboRoaringBitmapCodec::serialize_into(&value, buffer))
|
||||
}
|
||||
|
||||
/// Write provided entries in database using serialize_value function.
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue