Skip to content

Commit

Permalink
Merge pull request #523 from chewing/optimize-conversion-1
Browse files Browse the repository at this point in the history
refactor(conv): Only calculate paths once
  • Loading branch information
kanru committed May 6, 2024
2 parents e95821c + dc015fb commit b740c20
Show file tree
Hide file tree
Showing 2 changed files with 24 additions and 15 deletions.
25 changes: 15 additions & 10 deletions src/conversion/chewing.rs
Expand Up @@ -37,20 +37,25 @@ impl ChewingEngine {
.fold(vec![], |acc, interval| glue_fn(comp, acc, interval))
};
let fast_dp_clone = fast_dp.clone();
let mut cached_paths = None;
let slow_search = iter::once_with(move || {
if comp.is_empty() {
return vec![];
}
let intervals = self.find_intervals(dict, comp);
let paths = self.find_k_paths(Self::MAX_OUT_PATHS, comp.len(), intervals);
trace!("paths: {:#?}", paths);
debug_assert!(!paths.is_empty());

let mut trimmed_paths = self.trim_paths(paths);
debug_assert!(!trimmed_paths.is_empty());

trimmed_paths.sort_by(|a, b| b.cmp(a));
trimmed_paths
cached_paths
.get_or_insert_with(|| {
let intervals = self.find_intervals(dict, comp);
let paths = self.find_k_paths(Self::MAX_OUT_PATHS, comp.len(), intervals);
trace!("paths: {:#?}", paths);
debug_assert!(!paths.is_empty());

let mut trimmed_paths = self.trim_paths(paths);
debug_assert!(!trimmed_paths.is_empty());

trimmed_paths.sort_by(|a, b| b.cmp(a));
trimmed_paths
})
.to_vec()
})
.flatten()
.map(|p| {
Expand Down
14 changes: 9 additions & 5 deletions src/editor/mod.rs
Expand Up @@ -506,11 +506,15 @@ impl SharedState {
self.nth_conversion = 0;
}
fn conversion(&self) -> Vec<Interval> {
self.conv
.convert(&self.dict, self.com.as_ref())
.cycle()
.nth(self.nth_conversion)
.unwrap()
if self.nth_conversion > 0 {
let paths: Vec<_> = self.conv.convert(&self.dict, self.com.as_ref()).collect();
paths[self.nth_conversion % paths.len()].clone()
} else {
self.conv
.convert(&self.dict, self.com.as_ref())
.next()
.unwrap()
}
}
fn intervals(&self) -> impl Iterator<Item = Interval> {
self.conversion().into_iter()
Expand Down

0 comments on commit b740c20

Please sign in to comment.