Struct rand::distributions::range::Range
[−]
[src]
pub struct Range<X> { // some fields omitted }
rand
): use rand
from crates.io
Sample values uniformly between two bounds.
This gives a uniform distribution (assuming the RNG used to sample
it is itself uniform & the SampleRange
implementation for the
given type is correct), even for edge cases like low = 0
,
high = 170
, for which a naive modulo operation would return
numbers less than 85 with double the probability to those greater
than 85.
Types should attempt to sample in [low, high)
, i.e., not
including high
, but this may be very difficult. All the
primitive integer types satisfy this property, and the float types
normally satisfy it, but rounding may mean high
can occur.
Methods
impl<X: SampleRange + PartialOrd> Range<X>
[src]
fn new(low: X, high: X) -> Range<X>
rand
): use rand
from crates.io
Create a new Range
instance that samples uniformly from
[low, high)
. Panics if low >= high
.
Trait Implementations
impl<Sup: SampleRange> Sample<Sup> for Range<Sup>
[src]
fn sample<R: Rng>(&mut self, rng: &mut R) -> Sup
Generate a random value of Support
, using rng
as the source of randomness. Read more
impl<Sup: SampleRange> IndependentSample<Sup> for Range<Sup>
[src]
fn ind_sample<R: Rng>(&self, rng: &mut R) -> Sup
Generate a random value.