Struct EdgeValueFn
pub struct EdgeValueFn<C, W> {
initial: C,
min: Option<C>,
value_fn: Arc<dyn Fn(C, &W, usize) -> C + Sync + Send>,
}Expand description
A graph edge value function implementing a fold over path edges.
The penalty is a penalizing multiplier applied to edges that lack
probe-based quality observations (e.g. only on-chain capacity or only
immediate connectivity data). It scales the accumulated value downward,
making unprobed edges less attractive than measured ones while still
allowing path discovery. A value of 1.0 means no penalty; lower
values (e.g. 0.5) increasingly penalize unprobed edges.
Use one of the named constructors to create the appropriate variant:
EdgeValueFn::forward— full graph traversal in the forward directionEdgeValueFn::returning— full graph traversal in the return directionEdgeValueFn::forward_without_self_loopback— simple forward paths without final loopback
Fields§
§initial: C§min: Option<C>§value_fn: Arc<dyn Fn(C, &W, usize) -> C + Sync + Send>Implementations§
§impl<W> EdgeValueFn<f64, W>where
W: EdgeObservableRead + Send + 'static,
impl<W> EdgeValueFn<f64, W>where
W: EdgeObservableRead + Send + 'static,
pub fn forward(
length: NonZero<usize>,
penalty: f64,
min_ack_rate: f64,
) -> EdgeValueFn<f64, W>
pub fn forward( length: NonZero<usize>, penalty: f64, min_ack_rate: f64, ) -> EdgeValueFn<f64, W>
Build a forward HOPR value function for full graph traversals.
penalty is clamped to [0.0, 1.0] — the penalizing multiplier applied
to edges lacking probe-based quality observations.
min_ack_rate is clamped to [0.0, 1.0] — the minimum acceptable message
acknowledgment rate for the immediate peer. Edges with an ack rate below this
threshold are rejected.
- First edge: requires connectivity and intermediate capacity; scores by the better of immediate/intermediate observations, then applies the ack rate modifier.
- Last edge: accepts intermediate capacity or immediate connectivity; penalizes when neither is available
(last hop is not monetized). When
length == 1the single edge is both first and last; the ack rate modifier is applied when immediate QoS data is available. - Intermediate edges: require capacity; penalize when unprobed.
pub fn returning(
length: NonZero<usize>,
penalty: f64,
min_ack_rate: f64,
) -> EdgeValueFn<f64, W>
pub fn returning( length: NonZero<usize>, penalty: f64, min_ack_rate: f64, ) -> EdgeValueFn<f64, W>
Build a HOPR value function for full graph traversals in the return direction.
penalty is clamped to [0.0, 1.0] — the penalizing multiplier applied
to edges lacking probe-based quality observations.
min_ack_rate is clamped to [0.0, 1.0] — the minimum acceptable message
acknowledgment rate for the immediate peer. Edges with an ack rate below this
threshold are rejected.
Used when the planner (me) constructs the return path dest -> relay -> me.
The first edge (dest -> relay) has relaxed requirements compared to
EdgeValueFn::forward because the planner lacks intermediate QoS data.
- Last edge (relay -> me): requires immediate connectivity; applies the ack rate modifier.
- All other edges: require intermediate capacity; the
penaltypenalizing multiplier is applied when probe scores are absent.
pub fn forward_without_self_loopback(
penalty: f64,
min_ack_rate: f64,
) -> EdgeValueFn<f64, W>
pub fn forward_without_self_loopback( penalty: f64, min_ack_rate: f64, ) -> EdgeValueFn<f64, W>
Build a value function for simple forward paths without the final loopback.
penalty is clamped to [0.0, 1.0] — the penalizing multiplier applied
to edges lacking probe-based quality observations.
min_ack_rate is clamped to [0.0, 1.0] — the minimum acceptable message
acknowledgment rate for the immediate peer. Edges with an ack rate below this
threshold are rejected.
- First edge: same as
EdgeValueFn::forward. - All other edges: require capacity; the
penaltypenalizing multiplier is applied when probe scores are absent.
Trait Implementations§
§impl<C, W> Clone for EdgeValueFn<C, W>where
C: Clone,
impl<C, W> Clone for EdgeValueFn<C, W>where
C: Clone,
§fn clone(&self) -> EdgeValueFn<C, W>
fn clone(&self) -> EdgeValueFn<C, W>
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read more§impl<C, W> ValueFn for EdgeValueFn<C, W>
impl<C, W> ValueFn for EdgeValueFn<C, W>
type Value = C
type Weight = W
§fn initial_value(&self) -> <EdgeValueFn<C, W> as ValueFn>::Value
fn initial_value(&self) -> <EdgeValueFn<C, W> as ValueFn>::Value
§fn min_value(&self) -> Option<<EdgeValueFn<C, W> as ValueFn>::Value>
fn min_value(&self) -> Option<<EdgeValueFn<C, W> as ValueFn>::Value>
§fn into_value_fn(
self,
) -> Arc<dyn Fn(<EdgeValueFn<C, W> as ValueFn>::Value, &<EdgeValueFn<C, W> as ValueFn>::Weight, usize) -> <EdgeValueFn<C, W> as ValueFn>::Value + Sync + Send>
fn into_value_fn( self, ) -> Arc<dyn Fn(<EdgeValueFn<C, W> as ValueFn>::Value, &<EdgeValueFn<C, W> as ValueFn>::Weight, usize) -> <EdgeValueFn<C, W> as ValueFn>::Value + Sync + Send>
Auto Trait Implementations§
impl<C, W> Freeze for EdgeValueFn<C, W>where
C: Freeze,
impl<C, W> !RefUnwindSafe for EdgeValueFn<C, W>
impl<C, W> Send for EdgeValueFn<C, W>where
C: Send,
impl<C, W> Sync for EdgeValueFn<C, W>where
C: Sync,
impl<C, W> Unpin for EdgeValueFn<C, W>where
C: Unpin,
impl<C, W> !UnwindSafe for EdgeValueFn<C, W>
Blanket Implementations§
§impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
§impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§impl<T> Conv for T
impl<T> Conv for T
§impl<T> FmtForward for T
impl<T> FmtForward for T
§fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
self to use its Binary implementation when Debug-formatted.§fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
self to use its Display implementation when
Debug-formatted.§fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
self to use its LowerExp implementation when
Debug-formatted.§fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
self to use its LowerHex implementation when
Debug-formatted.§fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
self to use its Octal implementation when Debug-formatted.§fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
self to use its Pointer implementation when
Debug-formatted.§fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
self to use its UpperExp implementation when
Debug-formatted.§fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
self to use its UpperHex implementation when
Debug-formatted.§fn fmt_list(self) -> FmtList<Self>where
&'a Self: for<'a> IntoIterator,
fn fmt_list(self) -> FmtList<Self>where
&'a Self: for<'a> IntoIterator,
§impl<T> FutureExt for T
impl<T> FutureExt for T
§fn with_context(self, otel_cx: Context) -> WithContext<Self> ⓘ
fn with_context(self, otel_cx: Context) -> WithContext<Self> ⓘ
§fn with_current_context(self) -> WithContext<Self> ⓘ
fn with_current_context(self) -> WithContext<Self> ⓘ
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more§impl<T> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere
T: ?Sized,
§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
self and passes that borrow into the pipe function. Read more§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
self and passes that borrow into the pipe function. Read more§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
§fn pipe_borrow_mut<'a, B, R>(
&'a mut self,
func: impl FnOnce(&'a mut B) -> R,
) -> R
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
self, then passes self.as_ref() into the pipe function.§fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
self, then passes self.as_mut() into the pipe
function.§fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
self, then passes self.deref() into the pipe function.§impl<T> Pointable for T
impl<T> Pointable for T
§impl<T> PolicyExt for Twhere
T: ?Sized,
impl<T> PolicyExt for Twhere
T: ?Sized,
§impl<T> Tap for T
impl<T> Tap for T
§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
Borrow<B> of a value. Read more§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
BorrowMut<B> of a value. Read more§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
AsRef<R> view of a value. Read more§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
AsMut<R> view of a value. Read more§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
Deref::Target of a value. Read more§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
Deref::Target of a value. Read more§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
.tap() only in debug builds, and is erased in release builds.§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
.tap_mut() only in debug builds, and is erased in release
builds.§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
.tap_borrow() only in debug builds, and is erased in release
builds.§fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
.tap_borrow_mut() only in debug builds, and is erased in release
builds.§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
.tap_ref() only in debug builds, and is erased in release
builds.§fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
.tap_ref_mut() only in debug builds, and is erased in release
builds.§fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
.tap_deref() only in debug builds, and is erased in release
builds.