Skip to content

Commit

Permalink
semantic: Remove recursion in minimum_n_keys
Browse files Browse the repository at this point in the history
Done as part of the effort to remove all the recursion crate wide.

Use the `TreeLike` trait to iterate over policy nodes and remove the
recursive call in `semantic::Policy::minimum_n_keys`.
  • Loading branch information
tcharding committed Oct 12, 2023
1 parent dbb4f23 commit dceced4
Showing 1 changed file with 26 additions and 20 deletions.
46 changes: 26 additions & 20 deletions src/policy/semantic.rs
Original file line number Diff line number Diff line change
Expand Up @@ -619,28 +619,34 @@ impl<Pk: MiniscriptKey> Policy<Pk> {
///
/// Returns `None` if the policy is not satisfiable.
pub fn minimum_n_keys(&self) -> Option<usize> {
match *self {
Policy::Unsatisfiable => None,
Policy::Trivial => Some(0),
Policy::Key(..) => Some(1),
Policy::After(..)
| Policy::Older(..)
| Policy::Sha256(..)
| Policy::Hash256(..)
| Policy::Ripemd160(..)
| Policy::Hash160(..) => Some(0),
Policy::Threshold(k, ref subs) => {
let mut sublens: Vec<usize> =
subs.iter().filter_map(|p| p.minimum_n_keys()).collect();
if sublens.len() < k {
// Not enough branches are satisfiable
None
} else {
sublens.sort_unstable();
Some(sublens[0..k].iter().cloned().sum::<usize>())
use Policy::*;

let mut minimum_n_keys = vec![];
for data in Arc::new(self).post_order_iter() {
let minimum_n_keys_for_child_n = |n| minimum_n_keys[data.child_indices[n]];

let minimum_n_key = match data.node {
Unsatisfiable => None,
Trivial | After(..) | Older(..) | Sha256(..) | Hash256(..) | Ripemd160(..)
| Hash160(..) => Some(0),
Key(..) => Some(1),
Threshold(k, ref subs) => {
let mut sublens = (0..subs.len())
.filter_map(minimum_n_keys_for_child_n)
.collect::<Vec<usize>>();
if sublens.len() < *k {
// Not enough branches are satisfiable
None
} else {
sublens.sort_unstable();
Some(sublens[0..*k].iter().cloned().sum::<usize>())
}
}
}
};
minimum_n_keys.push(minimum_n_key);
}
// Ok to unwrap because we know we processed at least one node.
minimum_n_keys.pop().unwrap()
}
}

Expand Down

0 comments on commit dceced4

Please sign in to comment.