Skip to main content

WeightedCollection

Struct WeightedCollection 

Source
pub struct WeightedCollection<T> {
    items: Vec<(T, f64)>,
    total_weight: f64,
}
Expand description

A collection of items with associated weights for probabilistic selection.

Weights must be positive (> 0.0); items with non-positive weights are treated as having zero probability for pick_one / pick_index and are placed at the end of the shuffled output in into_shuffled.

§Examples

use hopr_statistics::WeightedCollection;

let wc = WeightedCollection::new(vec![("rare", 0.1), ("common", 10.0)]);
let picked = wc.pick_one().expect("non-empty collection");
assert!(picked == "rare" || picked == "common");

Fields§

§items: Vec<(T, f64)>§total_weight: f64

Pre-computed sum of positive weights (cached to avoid recomputing on every pick).

Implementations§

Source§

impl<T> WeightedCollection<T>

Source

pub fn new(items: Vec<(T, f64)>) -> Self

Create a new weighted collection from items paired with their weights.

Source

pub fn is_empty(&self) -> bool

Returns true if the collection contains no items.

Source

pub fn len(&self) -> usize

Returns the number of items in the collection.

Source

pub fn iter(&self) -> impl Iterator<Item = &(T, f64)>

Iterates over (item, weight) pairs.

Source

pub fn pick_index(&self) -> Option<usize>

Returns the index of a randomly selected item, weighted by probability proportional to its weight.

Returns None if the collection is empty or all weights are non-positive.

Source§

impl<T> WeightedCollection<T>

Source

pub fn pick_ref(&self) -> Option<&T>

Pick a reference to one item at random, with probability proportional to its weight.

Returns None if the collection is empty or all weights are non-positive.

Source§

impl<T: Clone> WeightedCollection<T>

Source

pub fn pick_one(&self) -> Option<T>

Pick one item at random, with probability proportional to its weight.

Returns None if the collection is empty or all weights are non-positive.

Source§

impl<T> WeightedCollection<T>

Source

pub fn into_shuffled(self) -> Vec<T>

Consume the collection and return items in a weighted random permutation.

Uses the Efraimidis–Spirakis algorithm: each item is assigned a key random()^(1/weight) and the items are sorted by descending key. Higher-weight items appear earlier with higher probability, but all items retain a nonzero chance of appearing at any position.

Auto Trait Implementations§

§

impl<T> Freeze for WeightedCollection<T>

§

impl<T> RefUnwindSafe for WeightedCollection<T>
where T: RefUnwindSafe,

§

impl<T> Send for WeightedCollection<T>
where T: Send,

§

impl<T> Sync for WeightedCollection<T>
where T: Sync,

§

impl<T> Unpin for WeightedCollection<T>
where T: Unpin,

§

impl<T> UnwindSafe for WeightedCollection<T>
where T: UnwindSafe,

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.