mirror of
https://github.com/meilisearch/MeiliSearch
synced 2025-01-12 14:27:28 +01:00
Sort the word docids to make intersections much faster
This commit is contained in:
parent
ad11c5fb3f
commit
072382fa61
@ -122,6 +122,10 @@ impl<'a> Search<'a> {
|
|||||||
derived_words: &[(HashMap<String, (u8, RoaringBitmap)>, RoaringBitmap)],
|
derived_words: &[(HashMap<String, (u8, RoaringBitmap)>, RoaringBitmap)],
|
||||||
) -> RoaringBitmap
|
) -> RoaringBitmap
|
||||||
{
|
{
|
||||||
|
// We sort the derived words by inverse popularity, this way intersections are faster.
|
||||||
|
let mut derived_words: Vec<_> = derived_words.iter().collect();
|
||||||
|
derived_words.sort_unstable_by_key(|(_, docids)| docids.len());
|
||||||
|
|
||||||
// we do a union between all the docids of each of the derived words,
|
// we do a union between all the docids of each of the derived words,
|
||||||
// we got N unions (the number of original query words), we then intersect them.
|
// we got N unions (the number of original query words), we then intersect them.
|
||||||
let mut candidates = RoaringBitmap::new();
|
let mut candidates = RoaringBitmap::new();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user