mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-26 05:26:27 +00:00 
			
		
		
		
	Depth-first search cache the docids unions
This commit is contained in:
		| @@ -1,4 +1,5 @@ | |||||||
| use std::collections::{HashMap, HashSet}; | use std::collections::{HashMap, HashSet}; | ||||||
|  | use std::collections::hash_map::Entry::{Occupied, Vacant}; | ||||||
|  |  | ||||||
| use fst::{IntoStreamer, Streamer}; | use fst::{IntoStreamer, Streamer}; | ||||||
| use levenshtein_automata::DFA; | use levenshtein_automata::DFA; | ||||||
| @@ -215,22 +216,28 @@ impl<'a> Search<'a> { | |||||||
|             words: &[(HashMap<String, (u8, RoaringBitmap)>, RoaringBitmap)], |             words: &[(HashMap<String, (u8, RoaringBitmap)>, RoaringBitmap)], | ||||||
|             candidates: &RoaringBitmap, |             candidates: &RoaringBitmap, | ||||||
|             parent_docids: Option<&RoaringBitmap>, |             parent_docids: Option<&RoaringBitmap>, | ||||||
|  |             union_cache: &mut HashMap<(usize, u8), RoaringBitmap>, | ||||||
|         ) -> anyhow::Result<Option<RoaringBitmap>> |         ) -> anyhow::Result<Option<RoaringBitmap>> | ||||||
|         { |         { | ||||||
|             let (words1, words2) = (&words[0].0, &words[1].0); |             let (words1, words2) = (&words[0].0, &words[1].0); | ||||||
|             let pairs = words_pair_combinations(words1, words2); |             let pairs = words_pair_combinations(words1, words2); | ||||||
|  |  | ||||||
|             for proximity in 1..=8 { |             for proximity in 1..=8 { | ||||||
|  |                 let mut docids = match union_cache.entry((words.len(), proximity)) { | ||||||
|                 let mut docids = RoaringBitmap::new(); |                     Occupied(entry) => entry.get().clone(), | ||||||
|                 if proximity == 8 { |                     Vacant(entry) => { | ||||||
|                     docids = candidates.clone(); |                         let mut docids = RoaringBitmap::new(); | ||||||
|                 } else { |                         if proximity == 8 { | ||||||
|                     for (w1, w2) in pairs.iter().cloned() { |                             docids = candidates.clone(); | ||||||
|                         let key = (w1, w2, proximity); |                         } else { | ||||||
|                         if let Some(di) = index.word_pair_proximity_docids.get(rtxn, &key)? { |                             for (w1, w2) in pairs.iter().cloned() { | ||||||
|                             docids.union_with(&di); |                                 let key = (w1, w2, proximity); | ||||||
|  |                                 if let Some(di) = index.word_pair_proximity_docids.get(rtxn, &key)? { | ||||||
|  |                                     docids.union_with(&di); | ||||||
|  |                                 } | ||||||
|  |                             } | ||||||
|                         } |                         } | ||||||
|  |                         entry.insert(docids).clone() | ||||||
|                     } |                     } | ||||||
|                 }; |                 }; | ||||||
|  |  | ||||||
| @@ -242,7 +249,7 @@ impl<'a> Search<'a> { | |||||||
|                     let words = &words[1..]; |                     let words = &words[1..]; | ||||||
|                     // We are the last word. |                     // We are the last word. | ||||||
|                     if words.len() < 2 { return Ok(Some(docids)) } |                     if words.len() < 2 { return Ok(Some(docids)) } | ||||||
|                     if let Some(di) = depth_first_search(index, rtxn, words, candidates, Some(&docids))? { |                     if let Some(di) = depth_first_search(index, rtxn, words, candidates, Some(&docids), union_cache)? { | ||||||
|                         return Ok(Some(di)) |                         return Ok(Some(di)) | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
| @@ -251,8 +258,10 @@ impl<'a> Search<'a> { | |||||||
|             Ok(None) |             Ok(None) | ||||||
|         } |         } | ||||||
|  |  | ||||||
|  |         let mut union_cache = HashMap::new(); | ||||||
|  |         let answer = depth_first_search(index, rtxn, &derived_words, &candidates, None, &mut union_cache)?; | ||||||
|  |  | ||||||
|         let mut documents = Vec::new(); |         let mut documents = Vec::new(); | ||||||
|         let answer = depth_first_search(index, rtxn, &derived_words, &candidates, None)?; |  | ||||||
|         if let Some(answer) = answer { |         if let Some(answer) = answer { | ||||||
|             documents.push(answer); |             documents.push(answer); | ||||||
|         } |         } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user