mirror of
https://github.com/meilisearch/MeiliSearch
synced 2025-01-12 06:24:29 +01:00
squash-me: It works! we must remove the debug after having added more tests
This commit is contained in:
parent
13977d9338
commit
fecd8ca54a
@ -39,8 +39,37 @@ impl Path {
|
|||||||
Some(Path(vec![*position]))
|
Some(Path(vec![*position]))
|
||||||
}
|
}
|
||||||
|
|
||||||
fn successors(&self, _positions: &[Vec<u32>]) -> Vec<(Path, u32)> {
|
// TODO we must skip the successors that have already been sent
|
||||||
vec![]
|
fn successors(&self, positions: &[Vec<u32>]) -> Vec<(Path, u32)> {
|
||||||
|
let mut successors = Vec::new();
|
||||||
|
|
||||||
|
// If we can grow or shift the path
|
||||||
|
if self.0.len() < positions.len() {
|
||||||
|
let mut grown_path = self.0.clone();
|
||||||
|
grown_path.push(positions[self.0.len()][0]);
|
||||||
|
let path = Path(grown_path);
|
||||||
|
let proximity = path.proximity();
|
||||||
|
successors.push((path, proximity));
|
||||||
|
}
|
||||||
|
|
||||||
|
// We retrieve the tail of the current path and try to find
|
||||||
|
// the successor of this tail.
|
||||||
|
let next_path_tail = dbg!(self.0.last().unwrap() + 1);
|
||||||
|
// To do so we add 1 to the tail and check that something exists.
|
||||||
|
let path_tail_index = dbg!(positions[self.0.len() - 1].binary_search(&next_path_tail).unwrap_or_else(|p| p));
|
||||||
|
// If we found something it means that we can shift the path.
|
||||||
|
if let Some(pos) = positions[self.0.len() - 1].get(path_tail_index) {
|
||||||
|
let mut shifted_path = self.0.clone();
|
||||||
|
*shifted_path.last_mut().unwrap() = *pos;
|
||||||
|
let path = Path(shifted_path);
|
||||||
|
let proximity = path.proximity();
|
||||||
|
successors.push((path, proximity));
|
||||||
|
}
|
||||||
|
|
||||||
|
eprintln!("self: {:?}", self);
|
||||||
|
successors.iter().for_each(|s| eprintln!("successor: {:?}", s));
|
||||||
|
|
||||||
|
successors
|
||||||
}
|
}
|
||||||
|
|
||||||
fn proximity(&self) -> u32 {
|
fn proximity(&self) -> u32 {
|
||||||
@ -73,22 +102,20 @@ impl Iterator for BestProximity {
|
|||||||
fn next(&mut self) -> Option<Self::Item> {
|
fn next(&mut self) -> Option<Self::Item> {
|
||||||
let mut output: Option<(u32, Vec<Vec<u32>>)> = None;
|
let mut output: Option<(u32, Vec<Vec<u32>>)> = None;
|
||||||
|
|
||||||
unimplemented!("we must use and update self.best_proximity");
|
|
||||||
|
|
||||||
loop {
|
loop {
|
||||||
let start = Path::new(&self.positions)?;
|
|
||||||
let result = dijkstra(
|
let result = dijkstra(
|
||||||
&start,
|
&Path::new(&self.positions)?,
|
||||||
|p| p.successors(&self.positions),
|
|p| p.successors(&self.positions),
|
||||||
|p| self.is_path_successful(p) && output.as_ref().map_or(true, |paths| !paths.1.contains(&p.0)),
|
|p| self.is_path_successful(p) && output.as_ref().map_or(true, |paths| !paths.1.contains(&p.0)),
|
||||||
);
|
);
|
||||||
|
|
||||||
match result {
|
match dbg!(result) {
|
||||||
Some((mut paths, proximity)) => {
|
Some((mut paths, _)) => {
|
||||||
let positions = paths.pop().unwrap();
|
let positions = paths.pop().unwrap();
|
||||||
|
let proximity = positions.proximity();
|
||||||
|
|
||||||
// If the current output is
|
// If the current output is
|
||||||
match &mut output {
|
match dbg!(&mut output) {
|
||||||
Some((best_proximity, paths)) => {
|
Some((best_proximity, paths)) => {
|
||||||
// If the shortest path we found is bigger than the one requested
|
// If the shortest path we found is bigger than the one requested
|
||||||
// it means that we found all the paths with the same proximity and can
|
// it means that we found all the paths with the same proximity and can
|
||||||
@ -108,6 +135,10 @@ impl Iterator for BestProximity {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if let Some((proximity, _)) = output.as_ref() {
|
||||||
|
self.best_proximity = proximity + 1;
|
||||||
|
}
|
||||||
|
|
||||||
output
|
output
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -125,15 +156,20 @@ mod tests {
|
|||||||
];
|
];
|
||||||
let mut iter = BestProximity::new(positions);
|
let mut iter = BestProximity::new(positions);
|
||||||
|
|
||||||
assert_eq!(iter.next(), Some((1+2, vec![vec![0], vec![1], vec![3]]))); // 3
|
assert_eq!(iter.next(), Some((1+2, vec![vec![0, 1, 3]]))); // 3
|
||||||
eprintln!("------------------");
|
eprintln!("------------------");
|
||||||
assert_eq!(iter.next(), Some((2+2, vec![vec![2], vec![1], vec![3]]))); // 4
|
assert_eq!(iter.next(), Some((2+2, vec![vec![2, 1, 3]]))); // 4
|
||||||
// assert_eq!(iter.next(), Some((3+2, vec![3, 1, 3]))); // 5
|
eprintln!("------------------");
|
||||||
// assert_eq!(iter.next(), Some((1+5, vec![0, 1, 6]))); // 6
|
assert_eq!(iter.next(), Some((3+2, vec![vec![3, 1, 3]]))); // 5
|
||||||
// assert_eq!(iter.next(), Some((4+2, vec![4, 1, 3]))); // 6
|
eprintln!("------------------");
|
||||||
// assert_eq!(iter.next(), Some((2+5, vec![2, 1, 6]))); // 7
|
assert_eq!(iter.next(), Some((1+5, vec![vec![0, 1, 6], vec![4, 1, 3]]))); // 6
|
||||||
// assert_eq!(iter.next(), Some((3+5, vec![3, 1, 6]))); // 8
|
eprintln!("------------------");
|
||||||
// assert_eq!(iter.next(), Some((4+5, vec![4, 1, 6]))); // 9
|
assert_eq!(iter.next(), Some((2+5, vec![vec![2, 1, 6]]))); // 7
|
||||||
// assert_eq!(iter.next(), None);
|
eprintln!("------------------");
|
||||||
|
assert_eq!(iter.next(), Some((3+5, vec![vec![3, 1, 6]]))); // 8
|
||||||
|
eprintln!("------------------");
|
||||||
|
assert_eq!(iter.next(), Some((4+5, vec![vec![4, 1, 6]]))); // 9
|
||||||
|
eprintln!("------------------");
|
||||||
|
assert_eq!(iter.next(), None);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user