From: Jeffrey Czyz Date: Thu, 20 Jan 2022 14:47:46 +0000 (-0600) Subject: f - remove Probability enum X-Git-Url: http://git.bitcoin.ninja/?a=commitdiff_plain;h=51b0652d32fd22753a384102932527b3f986e8e0;p=rust-lightning f - remove Probability enum --- diff --git a/lightning/src/routing/scoring.rs b/lightning/src/routing/scoring.rs index 9e2f8132e..8e9a002dd 100644 --- a/lightning/src/routing/scoring.rs +++ b/lightning/src/routing/scoring.rs @@ -504,13 +504,6 @@ struct DirectedChannelLiquidity> { capacity_msat: u64, } -/// The likelihood of an event occurring. -enum Probability { - Zero, - One, - Ratio { numerator: u64, denominator: u64 }, -} - impl> ProbabilisticScorer { /// Creates a new scorer using the given scoring parameters for sending payments from a node /// through a network graph. @@ -589,21 +582,17 @@ impl ChannelLiquidity { impl> DirectedChannelLiquidity { /// Returns the success probability of routing the given HTLC `amount_msat` through the channel /// in this direction. - fn success_probability(&self, amount_msat: u64) -> Probability { + fn success_probability(&self, amount_msat: u64) -> f64 { let max_liquidity_msat = self.max_liquidity_msat(); let min_liquidity_msat = core::cmp::min(self.min_liquidity_msat(), max_liquidity_msat); if amount_msat > max_liquidity_msat { - Probability::Zero - } else if amount_msat < min_liquidity_msat { - Probability::One + 0.0 + } else if amount_msat <= min_liquidity_msat { + 1.0 } else { let numerator = max_liquidity_msat + 1 - amount_msat; let denominator = max_liquidity_msat + 1 - min_liquidity_msat; - if numerator == denominator { - Probability::One - } else { - Probability::Ratio { numerator, denominator } - } + numerator as f64 / denominator as f64 } } @@ -673,13 +662,12 @@ impl> Score for ProbabilisticScorer { .unwrap_or(&ChannelLiquidity::new()) .as_directed(source, target, capacity_msat) .success_probability(amount_msat); - match success_probability { - Probability::Zero => u64::max_value(), - Probability::One => 0, - Probability::Ratio { numerator, denominator } => { - let success_probability = numerator as f64 / denominator as f64; - (-(success_probability.log10()) * liquidity_penalty_multiplier_msat as f64) as u64 - }, + if success_probability == 0.0 { + u64::max_value() + } else if success_probability == 1.0 { + 0 + } else { + (-(success_probability.log10()) * liquidity_penalty_multiplier_msat as f64) as u64 } }