Skip to content

Commit

Permalink
Use IndexSet instead of FxHashSet
Browse files Browse the repository at this point in the history
  • Loading branch information
samueltardieu committed Jan 3, 2025
1 parent 263e2e4 commit e418671
Showing 1 changed file with 8 additions and 13 deletions.
21 changes: 8 additions & 13 deletions src/directed/idastar.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
//! algorithm](https://en.wikipedia.org/wiki/Iterative_deepening_A*).
use num_traits::Zero;
use rustc_hash::FxHashSet;
use indexmap::IndexSet;
use std::hash::Hash;

/// Compute a shortest path using the [IDA* search
Expand Down Expand Up @@ -86,9 +86,8 @@ where
FS: FnMut(&N) -> bool,
{
let mut bound = heuristic(start);
let mut path = vec![start.clone()];
let mut seen = FxHashSet::default();
seen.insert(start.clone());
let mut path = IndexSet::default();
path.insert(start.clone());
loop {
match search(
&mut path,
Expand All @@ -97,7 +96,6 @@ where
&mut successors,
&mut heuristic,
&mut success,
&mut seen,
) {
Path::Found(path, cost) => return Some((path, cost)),
Path::Minimum(min) => {
Expand All @@ -118,13 +116,12 @@ enum Path<N, C> {
}

fn search<N, C, FN, IN, FH, FS>(
path: &mut Vec<N>,
path: &mut IndexSet<N>,
cost: C,
bound: C,
successors: &mut FN,
heuristic: &mut FH,
success: &mut FS,
seen: &mut FxHashSet<N>,
) -> Path<N, C>
where
N: Eq + Clone + Hash,
Expand All @@ -141,12 +138,12 @@ where
return Path::Minimum(f);
}
if success(start) {
return Path::Found(path.clone(), f);
return Path::Found(path.iter().cloned().collect(), f);
}
let mut neighbs: Vec<(N, C, C)> = successors(start)
.into_iter()
.filter_map(|(n, c)| {
(!seen.contains(&n)).then(|| {
(!path.contains(&n)).then(|| {
let h = heuristic(&n);
(n, c, c + h)
})
Expand All @@ -157,22 +154,20 @@ where
};
let mut min = None;
for (node, extra, _) in neighbs {
seen.insert(node.clone());
path.push(node);
let (idx, _) = path.insert_full(node);
match search(
path,
cost + extra,
bound,
successors,
heuristic,
success,
seen,
) {
found_path @ Path::Found(_, _) => return found_path,
Path::Minimum(m) if !min.is_some_and(|n| n < m) => min = Some(m),
_ => (),
}
seen.remove(&path.pop().unwrap());
path.swap_remove_index(idx);
}
min.map_or(Path::Impossible, Path::Minimum)
}

0 comments on commit e418671

Please sign in to comment.