mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-25 13:06:27 +00:00 
			
		
		
		
	Sort the word docids to make intersections much faster
This commit is contained in:
		| @@ -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(); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user