mirror of
https://github.com/meilisearch/MeiliSearch
synced 2024-11-05 04:28:55 +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)],
|
||||
) -> 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 got N unions (the number of original query words), we then intersect them.
|
||||
let mut candidates = RoaringBitmap::new();
|
||||
|
Loading…
Reference in New Issue
Block a user